mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-24 05:44:10 +00:00
servo: Merge #6279 - Add flake8 to the tidy process for Python files (from frewsxcv:flake8); r=jdm
Fixes #6236 Also included in this commit are the changes need to make flake8 pass for the existing python file Source-Repo: https://github.com/servo/servo Source-Revision: ccfe29d8f284dedc0101045d574a98fb1f69aa62
This commit is contained in:
parent
026692ccea
commit
5ddbba3c32
@ -7,19 +7,22 @@
|
|||||||
# option. This file may not be copied, modified, or distributed
|
# option. This file may not be copied, modified, or distributed
|
||||||
# except according to those terms.
|
# except according to those terms.
|
||||||
|
|
||||||
# A set of simple pretty printers for gdb to make debugging Servo a bit easier.
|
"""
|
||||||
|
A set of simple pretty printers for gdb to make debugging Servo a bit easier.
|
||||||
|
|
||||||
# To load these, you need to add something like the following
|
To load these, you need to add something like the following to your .gdbinit file:
|
||||||
# to your .gdbinit file.
|
|
||||||
#python
|
python
|
||||||
#import sys
|
import sys
|
||||||
#sys.path.insert(0, '/home/<path to git checkout>/servo/src/etc')
|
sys.path.insert(0, '/home/<path to git checkout>/servo/src/etc')
|
||||||
#import servo_gdb
|
import servo_gdb
|
||||||
#servo_gdb.register_printers(None)
|
servo_gdb.register_printers(None)
|
||||||
#end
|
end
|
||||||
|
"""
|
||||||
|
|
||||||
import gdb
|
import gdb
|
||||||
|
|
||||||
|
|
||||||
# Print Au in both raw value and CSS pixels
|
# Print Au in both raw value and CSS pixels
|
||||||
class AuPrinter:
|
class AuPrinter:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -27,9 +30,10 @@ class AuPrinter:
|
|||||||
|
|
||||||
def to_string(self):
|
def to_string(self):
|
||||||
i32_type = gdb.lookup_type("i32")
|
i32_type = gdb.lookup_type("i32")
|
||||||
au = self.val.cast(i32_type);
|
au = self.val.cast(i32_type)
|
||||||
return "{0}px".format(au / 60.0)
|
return "{0}px".format(au / 60.0)
|
||||||
|
|
||||||
|
|
||||||
# Print a U8 bitfield as binary
|
# Print a U8 bitfield as binary
|
||||||
class BitFieldU8Printer:
|
class BitFieldU8Printer:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -37,9 +41,10 @@ class BitFieldU8Printer:
|
|||||||
|
|
||||||
def to_string(self):
|
def to_string(self):
|
||||||
u8_type = gdb.lookup_type("u8")
|
u8_type = gdb.lookup_type("u8")
|
||||||
value = self.val.cast(u8_type);
|
value = self.val.cast(u8_type)
|
||||||
return "[{0:#010b}]".format(int(value))
|
return "[{0:#010b}]".format(int(value))
|
||||||
|
|
||||||
|
|
||||||
# Print a struct with fields as children
|
# Print a struct with fields as children
|
||||||
class ChildPrinter:
|
class ChildPrinter:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -48,12 +53,13 @@ class ChildPrinter:
|
|||||||
def children(self):
|
def children(self):
|
||||||
children = []
|
children = []
|
||||||
for f in self.val.type.fields():
|
for f in self.val.type.fields():
|
||||||
children.append( (f.name, self.val[f.name]) )
|
children.append((f.name, self.val[f.name]))
|
||||||
return children
|
return children
|
||||||
|
|
||||||
def to_string(self):
|
def to_string(self):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
# Allow a trusted node to be dereferenced in the debugger
|
# Allow a trusted node to be dereferenced in the debugger
|
||||||
class TrustedNodeAddressPrinter:
|
class TrustedNodeAddressPrinter:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -67,6 +73,7 @@ class TrustedNodeAddressPrinter:
|
|||||||
def to_string(self):
|
def to_string(self):
|
||||||
return self.val.address
|
return self.val.address
|
||||||
|
|
||||||
|
|
||||||
# Extract a node type ID from enum
|
# Extract a node type ID from enum
|
||||||
class NodeTypeIdPrinter:
|
class NodeTypeIdPrinter:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -75,9 +82,10 @@ class NodeTypeIdPrinter:
|
|||||||
def to_string(self):
|
def to_string(self):
|
||||||
u8_ptr_type = gdb.lookup_type("u8").pointer()
|
u8_ptr_type = gdb.lookup_type("u8").pointer()
|
||||||
enum_0 = self.val.address.cast(u8_ptr_type).dereference()
|
enum_0 = self.val.address.cast(u8_ptr_type).dereference()
|
||||||
enum_type = self.val.type.fields()[int(enum_0)].type;
|
enum_type = self.val.type.fields()[int(enum_0)].type
|
||||||
return str(enum_type).lstrip('struct ')
|
return str(enum_type).lstrip('struct ')
|
||||||
|
|
||||||
|
|
||||||
# Printer for std::Option<>
|
# Printer for std::Option<>
|
||||||
class OptionPrinter:
|
class OptionPrinter:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -111,6 +119,7 @@ class OptionPrinter:
|
|||||||
def to_string(self):
|
def to_string(self):
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
# Useful for debugging when type is unknown
|
# Useful for debugging when type is unknown
|
||||||
class TestPrinter:
|
class TestPrinter:
|
||||||
def __init__(self, val):
|
def __init__(self, val):
|
||||||
@ -129,13 +138,15 @@ type_map = [
|
|||||||
('Option', OptionPrinter),
|
('Option', OptionPrinter),
|
||||||
]
|
]
|
||||||
|
|
||||||
def lookup_servo_type (val):
|
|
||||||
|
def lookup_servo_type(val):
|
||||||
val_type = str(val.type)
|
val_type = str(val.type)
|
||||||
for (type_name, printer) in type_map:
|
for (type_name, printer) in type_map:
|
||||||
if val_type == type_name or val_type.endswith("::"+type_name):
|
if val_type == type_name or val_type.endswith("::" + type_name):
|
||||||
return printer(val)
|
return printer(val)
|
||||||
return None
|
return None
|
||||||
#return TestPrinter(val)
|
# return TestPrinter(val)
|
||||||
|
|
||||||
|
|
||||||
def register_printers(obj):
|
def register_printers(obj):
|
||||||
gdb.pretty_printers.append(lookup_servo_type)
|
gdb.pretty_printers.append(lookup_servo_type)
|
||||||
|
BIN
servo/python/dependencies/flake8-2.4.1-py2.py3-none-any.whl
Normal file
BIN
servo/python/dependencies/flake8-2.4.1-py2.py3-none-any.whl
Normal file
Binary file not shown.
BIN
servo/python/dependencies/pep8-1.5.7-py2.py3-none-any.whl
Normal file
BIN
servo/python/dependencies/pep8-1.5.7-py2.py3-none-any.whl
Normal file
Binary file not shown.
BIN
servo/python/dependencies/pyflakes-0.9.0-py2.py3-none-any.whl
Normal file
BIN
servo/python/dependencies/pyflakes-0.9.0-py2.py3-none-any.whl
Normal file
Binary file not shown.
@ -59,4 +59,4 @@ licenses = [
|
|||||||
# except according to those terms.
|
# except according to those terms.
|
||||||
""",
|
""",
|
||||||
|
|
||||||
]
|
] # noqa: Indicate to flake8 that we do not want to check indentation here
|
||||||
|
@ -98,7 +98,7 @@ def bootstrap(topdir):
|
|||||||
|
|
||||||
for category, meta in CATEGORIES.items():
|
for category, meta in CATEGORIES.items():
|
||||||
mach.define_category(category, meta['short'], meta['long'],
|
mach.define_category(category, meta['short'], meta['long'],
|
||||||
meta['priority'])
|
meta['priority'])
|
||||||
|
|
||||||
for path in MACH_MODULES:
|
for path in MACH_MODULES:
|
||||||
mach.load_commands_from_file(os.path.join(topdir, path))
|
mach.load_commands_from_file(os.path.join(topdir, path))
|
||||||
|
@ -40,7 +40,8 @@ def download(desc, src, dst):
|
|||||||
with open(dst, 'wb') as fd:
|
with open(dst, 'wb') as fd:
|
||||||
while True:
|
while True:
|
||||||
chunk = resp.read(chunk_size)
|
chunk = resp.read(chunk_size)
|
||||||
if not chunk: break
|
if not chunk:
|
||||||
|
break
|
||||||
recved += len(chunk)
|
recved += len(chunk)
|
||||||
if not dumb:
|
if not dumb:
|
||||||
pct = recved * 100.0 / fsize
|
pct = recved * 100.0 / fsize
|
||||||
@ -61,6 +62,7 @@ def download(desc, src, dst):
|
|||||||
|
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
|
||||||
def extract(src, dst, movedir=None):
|
def extract(src, dst, movedir=None):
|
||||||
tarfile.open(src).extractall(dst)
|
tarfile.open(src).extractall(dst)
|
||||||
|
|
||||||
|
@ -58,13 +58,14 @@ def notify_win(title, text):
|
|||||||
FLASHW_TIMERNOFG = 0x0C
|
FLASHW_TIMERNOFG = 0x0C
|
||||||
|
|
||||||
params = FLASHWINDOW(sizeof(FLASHWINDOW),
|
params = FLASHWINDOW(sizeof(FLASHWINDOW),
|
||||||
windll.kernel32.GetConsoleWindow(),
|
windll.kernel32.GetConsoleWindow(),
|
||||||
FLASHW_CAPTION | FLASHW_TRAY | FLASHW_TIMERNOFG, 3, 0)
|
FLASHW_CAPTION | FLASHW_TRAY | FLASHW_TIMERNOFG, 3, 0)
|
||||||
FlashWindowEx(params)
|
FlashWindowEx(params)
|
||||||
|
|
||||||
|
|
||||||
def notify_darwin(title, text):
|
def notify_darwin(title, text):
|
||||||
import Foundation, objc
|
import Foundation
|
||||||
|
import objc
|
||||||
|
|
||||||
NSUserNotification = objc.lookUpClass("NSUserNotification")
|
NSUserNotification = objc.lookUpClass("NSUserNotification")
|
||||||
NSUserNotificationCenter = objc.lookUpClass("NSUserNotificationCenter")
|
NSUserNotificationCenter = objc.lookUpClass("NSUserNotificationCenter")
|
||||||
@ -291,7 +292,7 @@ class MachCommands(CommandBase):
|
|||||||
opts += ["--release"]
|
opts += ["--release"]
|
||||||
|
|
||||||
opts += ["--target", "arm-linux-androideabi"]
|
opts += ["--target", "arm-linux-androideabi"]
|
||||||
env=self.build_env(gonk=True)
|
env = self.build_env(gonk=True)
|
||||||
build_start = time()
|
build_start = time()
|
||||||
with cd(path.join("ports", "gonk")):
|
with cd(path.join("ports", "gonk")):
|
||||||
ret = subprocess.call(["cargo", "build"] + opts, env=env)
|
ret = subprocess.call(["cargo", "build"] + opts, env=env)
|
||||||
@ -304,7 +305,6 @@ class MachCommands(CommandBase):
|
|||||||
|
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
|
|
||||||
@Command('build-tests',
|
@Command('build-tests',
|
||||||
description='Build the Servo test suites',
|
description='Build the Servo test suites',
|
||||||
category='build')
|
category='build')
|
||||||
@ -329,7 +329,6 @@ class MachCommands(CommandBase):
|
|||||||
@CommandArgument('--verbose', '-v',
|
@CommandArgument('--verbose', '-v',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
help='Print verbose output')
|
help='Print verbose output')
|
||||||
|
|
||||||
@CommandArgument('params', nargs='...',
|
@CommandArgument('params', nargs='...',
|
||||||
help="Command-line arguments to be passed through to Cargo")
|
help="Command-line arguments to be passed through to Cargo")
|
||||||
def clean(self, manifest_path, params, verbose=False):
|
def clean(self, manifest_path, params, verbose=False):
|
||||||
|
@ -165,7 +165,7 @@ class CommandBase(object):
|
|||||||
|
|
||||||
print("The %s profile is not built. Please run './mach build%s' "
|
print("The %s profile is not built. Please run './mach build%s' "
|
||||||
"and try again." % ("release" if release else "dev",
|
"and try again." % ("release" if release else "dev",
|
||||||
" --release" if release else ""))
|
" --release" if release else ""))
|
||||||
sys.exit()
|
sys.exit()
|
||||||
|
|
||||||
def build_env(self, gonk=False, hosts_file_path=None):
|
def build_env(self, gonk=False, hosts_file_path=None):
|
||||||
|
@ -36,8 +36,8 @@ class MachCommands(CommandBase):
|
|||||||
|
|
||||||
if self.context.topdir == getcwd():
|
if self.context.topdir == getcwd():
|
||||||
with cd(path.join('components', 'servo')):
|
with cd(path.join('components', 'servo')):
|
||||||
return subprocess.call(["cargo"] + params,
|
return subprocess.call(
|
||||||
env=self.build_env())
|
["cargo"] + params, env=self.build_env())
|
||||||
return subprocess.call(['cargo'] + params,
|
return subprocess.call(['cargo'] + params,
|
||||||
env=self.build_env())
|
env=self.build_env())
|
||||||
|
|
||||||
@ -51,7 +51,7 @@ class MachCommands(CommandBase):
|
|||||||
'--package', '-p', default=None,
|
'--package', '-p', default=None,
|
||||||
help='Updates selected package')
|
help='Updates selected package')
|
||||||
@CommandArgument(
|
@CommandArgument(
|
||||||
'--all-packages','-a',action='store_true',
|
'--all-packages', '-a', action='store_true',
|
||||||
help='Updates all packages')
|
help='Updates all packages')
|
||||||
def cargo_update(self, params=None, package=None, all_packages=None):
|
def cargo_update(self, params=None, package=None, all_packages=None):
|
||||||
self.update_cargo(params, package, all_packages)
|
self.update_cargo(params, package, all_packages)
|
||||||
@ -63,10 +63,10 @@ class MachCommands(CommandBase):
|
|||||||
'params', default=None, nargs='...',
|
'params', default=None, nargs='...',
|
||||||
help='Command-line arguments to be passed through to cargo update')
|
help='Command-line arguments to be passed through to cargo update')
|
||||||
@CommandArgument(
|
@CommandArgument(
|
||||||
'--package','-p',default=None,
|
'--package', '-p', default=None,
|
||||||
help='Updates selected package')
|
help='Updates selected package')
|
||||||
@CommandArgument(
|
@CommandArgument(
|
||||||
'--all-packages','-a',action='store_true',
|
'--all-packages', '-a', action='store_true',
|
||||||
help='Updates all packages')
|
help='Updates all packages')
|
||||||
def update_cargo(self, params=None, package=None, all_packages=None):
|
def update_cargo(self, params=None, package=None, all_packages=None):
|
||||||
if not params:
|
if not params:
|
||||||
|
@ -12,7 +12,6 @@ from __future__ import print_function, unicode_literals
|
|||||||
import os
|
import os
|
||||||
import os.path as path
|
import os.path as path
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
|
||||||
from shutil import copytree, rmtree, copy2
|
from shutil import copytree, rmtree, copy2
|
||||||
|
|
||||||
from mach.registrar import Registrar
|
from mach.registrar import Registrar
|
||||||
@ -49,7 +48,7 @@ class MachCommands(CommandBase):
|
|||||||
'debugger being used. The following arguments '
|
'debugger being used. The following arguments '
|
||||||
'have no effect without this.')
|
'have no effect without this.')
|
||||||
@CommandArgument('--debugger', default=None, type=str,
|
@CommandArgument('--debugger', default=None, type=str,
|
||||||
help='Name of debugger to use.')
|
help='Name of debugger to use.')
|
||||||
@CommandArgument(
|
@CommandArgument(
|
||||||
'params', nargs='...',
|
'params', nargs='...',
|
||||||
help="Command-line arguments to be passed through to Servo")
|
help="Command-line arguments to be passed through to Servo")
|
||||||
@ -74,8 +73,8 @@ class MachCommands(CommandBase):
|
|||||||
return 1
|
return 1
|
||||||
|
|
||||||
# Prepend the debugger args.
|
# Prepend the debugger args.
|
||||||
args = ([self.debuggerInfo.path] + self.debuggerInfo.args
|
args = ([self.debuggerInfo.path] + self.debuggerInfo.args +
|
||||||
+ args + params)
|
args + params)
|
||||||
else:
|
else:
|
||||||
args = args + params
|
args = args + params
|
||||||
|
|
||||||
@ -84,7 +83,7 @@ class MachCommands(CommandBase):
|
|||||||
except OSError as e:
|
except OSError as e:
|
||||||
if e.errno == 2:
|
if e.errno == 2:
|
||||||
print("Servo Binary can't be found! Run './mach build'"
|
print("Servo Binary can't be found! Run './mach build'"
|
||||||
" and try again!")
|
" and try again!")
|
||||||
else:
|
else:
|
||||||
raise e
|
raise e
|
||||||
|
|
||||||
@ -132,8 +131,7 @@ class MachCommands(CommandBase):
|
|||||||
help="Command-line arguments to be passed through to cargo doc")
|
help="Command-line arguments to be passed through to cargo doc")
|
||||||
def doc(self, params):
|
def doc(self, params):
|
||||||
self.ensure_bootstrapped()
|
self.ensure_bootstrapped()
|
||||||
if not path.exists(path.join(
|
if not path.exists(path.join(self.config["tools"]["rust-root"], "doc")):
|
||||||
self.config["tools"]["rust-root"], "doc")):
|
|
||||||
Registrar.dispatch("bootstrap-rust-docs", context=self.context)
|
Registrar.dispatch("bootstrap-rust-docs", context=self.context)
|
||||||
rust_docs = path.join(self.config["tools"]["rust-root"], "doc")
|
rust_docs = path.join(self.config["tools"]["rust-root"], "doc")
|
||||||
docs = path.join(
|
docs = path.join(
|
||||||
|
@ -281,7 +281,6 @@ class MachCommands(CommandBase):
|
|||||||
execfile(run_file, run_globals)
|
execfile(run_file, run_globals)
|
||||||
return run_globals["update_tests"](**kwargs)
|
return run_globals["update_tests"](**kwargs)
|
||||||
|
|
||||||
|
|
||||||
def ensure_wpt_virtualenv(self):
|
def ensure_wpt_virtualenv(self):
|
||||||
virtualenv_path = path.join("tests", "wpt", "_virtualenv")
|
virtualenv_path = path.join("tests", "wpt", "_virtualenv")
|
||||||
python = self.get_exec("python2", "python")
|
python = self.get_exec("python2", "python")
|
||||||
@ -295,8 +294,8 @@ class MachCommands(CommandBase):
|
|||||||
execfile(activate_path, dict(__file__=activate_path))
|
execfile(activate_path, dict(__file__=activate_path))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import wptrunner
|
import wptrunner # noqa
|
||||||
from wptrunner.browsers import servo
|
from wptrunner.browsers import servo # noqa
|
||||||
except ImportError:
|
except ImportError:
|
||||||
subprocess.check_call(["pip", "install", "-r",
|
subprocess.check_call(["pip", "install", "-r",
|
||||||
path.join("tests", "wpt", "harness", "requirements.txt")])
|
path.join("tests", "wpt", "harness", "requirements.txt")])
|
||||||
@ -311,7 +310,7 @@ class MachCommands(CommandBase):
|
|||||||
# before the virtualenv is initalised it doesn't see the blessings module so we don't
|
# before the virtualenv is initalised it doesn't see the blessings module so we don't
|
||||||
# get coloured output. Setting the blessings global explicitly fixes that.
|
# get coloured output. Setting the blessings global explicitly fixes that.
|
||||||
from mozlog.structured.formatters import machformatter
|
from mozlog.structured.formatters import machformatter
|
||||||
import blessings
|
import blessings # noqa
|
||||||
machformatter.blessings = blessings
|
machformatter.blessings = blessings
|
||||||
|
|
||||||
def get_exec(self, name, default=None):
|
def get_exec(self, name, default=None):
|
||||||
|
@ -7,17 +7,21 @@
|
|||||||
# option. This file may not be copied, modified, or distributed
|
# option. This file may not be copied, modified, or distributed
|
||||||
# except according to those terms.
|
# except according to those terms.
|
||||||
|
|
||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import fnmatch
|
import fnmatch
|
||||||
import itertools
|
import itertools
|
||||||
import re
|
import re
|
||||||
|
import sys
|
||||||
from licenseck import licenses
|
from licenseck import licenses
|
||||||
|
|
||||||
filetypes_to_check = [".rs", ".rc", ".cpp", ".c", ".h", ".py"]
|
filetypes_to_check = [".rs", ".rc", ".cpp", ".c", ".h", ".py"]
|
||||||
reftest_directories = ["tests/ref"]
|
reftest_directories = ["tests/ref"]
|
||||||
reftest_filetype = ".list"
|
reftest_filetype = ".list"
|
||||||
|
python_dependencies = [
|
||||||
|
"./python/dependencies/flake8-2.4.1-py2.py3-none-any.whl",
|
||||||
|
"./python/dependencies/pep8-1.5.7-py2.py3-none-any.whl",
|
||||||
|
"./python/dependencies/pyflakes-0.9.0-py2.py3-none-any.whl",
|
||||||
|
]
|
||||||
|
|
||||||
ignored_files = [
|
ignored_files = [
|
||||||
# Upstream
|
# Upstream
|
||||||
@ -80,12 +84,14 @@ def check_length(idx, line):
|
|||||||
if len(line) >= 120:
|
if len(line) >= 120:
|
||||||
yield (idx + 1, "(much) overlong line")
|
yield (idx + 1, "(much) overlong line")
|
||||||
|
|
||||||
|
|
||||||
def check_whatwg_url(idx, line):
|
def check_whatwg_url(idx, line):
|
||||||
match = re.search(r"https://html\.spec\.whatwg\.org/multipage/[\w-]+\.html#([\w\:-]+)", line)
|
match = re.search(r"https://html\.spec\.whatwg\.org/multipage/[\w-]+\.html#([\w\:-]+)", line)
|
||||||
if match is not None:
|
if match is not None:
|
||||||
preferred_link = "https://html.spec.whatwg.org/multipage/#{}".format(match.group(1))
|
preferred_link = "https://html.spec.whatwg.org/multipage/#{}".format(match.group(1))
|
||||||
yield (idx + 1, "link to WHATWG may break in the future, use this format instead: {}".format(preferred_link))
|
yield (idx + 1, "link to WHATWG may break in the future, use this format instead: {}".format(preferred_link))
|
||||||
|
|
||||||
|
|
||||||
def check_whitespace(idx, line):
|
def check_whitespace(idx, line):
|
||||||
if line[-1] == "\n":
|
if line[-1] == "\n":
|
||||||
line = line[:-1]
|
line = line[:-1]
|
||||||
@ -101,6 +107,7 @@ def check_whitespace(idx, line):
|
|||||||
if "\r" in line:
|
if "\r" in line:
|
||||||
yield (idx + 1, "CR on line")
|
yield (idx + 1, "CR on line")
|
||||||
|
|
||||||
|
|
||||||
def check_by_line(contents):
|
def check_by_line(contents):
|
||||||
lines = contents.splitlines(True)
|
lines = contents.splitlines(True)
|
||||||
for idx, line in enumerate(lines):
|
for idx, line in enumerate(lines):
|
||||||
@ -113,6 +120,25 @@ def check_by_line(contents):
|
|||||||
yield error
|
yield error
|
||||||
|
|
||||||
|
|
||||||
|
def check_flake8(file_paths):
|
||||||
|
from flake8.main import check_file
|
||||||
|
|
||||||
|
ignore = {
|
||||||
|
"W291", # trailing whitespace; the standard tidy process will enforce no trailing whitespace
|
||||||
|
"E501", # 80 character line length; the standard tidy process will enforce line length
|
||||||
|
}
|
||||||
|
|
||||||
|
num_errors = 0
|
||||||
|
|
||||||
|
for file_path in file_paths:
|
||||||
|
if os.path.splitext(file_path)[-1].lower() != ".py":
|
||||||
|
continue
|
||||||
|
|
||||||
|
num_errors += check_file(file_path, ignore=ignore)
|
||||||
|
|
||||||
|
return num_errors
|
||||||
|
|
||||||
|
|
||||||
def collect_errors_for_files(files_to_check, checking_functions):
|
def collect_errors_for_files(files_to_check, checking_functions):
|
||||||
for file_name in files_to_check:
|
for file_name in files_to_check:
|
||||||
with open(file_name, "r") as fp:
|
with open(file_name, "r") as fp:
|
||||||
@ -129,7 +155,7 @@ def check_reftest_order(files_to_check):
|
|||||||
split_lines = fp.read().splitlines()
|
split_lines = fp.read().splitlines()
|
||||||
lines = filter(lambda l: len(l) > 0 and l[0] != '#', split_lines)
|
lines = filter(lambda l: len(l) > 0 and l[0] != '#', split_lines)
|
||||||
for idx, line in enumerate(lines[:-1]):
|
for idx, line in enumerate(lines[:-1]):
|
||||||
next_line = lines[idx+1]
|
next_line = lines[idx + 1]
|
||||||
current = get_reftest_names(line)
|
current = get_reftest_names(line)
|
||||||
next = get_reftest_names(next_line)
|
next = get_reftest_names(next_line)
|
||||||
if current is not None and next is not None and current > next:
|
if current is not None and next is not None and current > next:
|
||||||
@ -146,9 +172,13 @@ def get_reftest_names(line):
|
|||||||
|
|
||||||
|
|
||||||
def scan():
|
def scan():
|
||||||
|
sys.path += python_dependencies
|
||||||
|
|
||||||
all_files = collect_file_names()
|
all_files = collect_file_names()
|
||||||
files_to_check = filter(should_check, all_files)
|
files_to_check = filter(should_check, all_files)
|
||||||
|
|
||||||
|
num_flake8_errors = check_flake8(files_to_check)
|
||||||
|
|
||||||
checking_functions = [check_license, check_by_line]
|
checking_functions = [check_license, check_by_line]
|
||||||
errors = collect_errors_for_files(files_to_check, checking_functions)
|
errors = collect_errors_for_files(files_to_check, checking_functions)
|
||||||
|
|
||||||
@ -158,7 +188,7 @@ def scan():
|
|||||||
|
|
||||||
errors = list(itertools.chain(errors, r_errors))
|
errors = list(itertools.chain(errors, r_errors))
|
||||||
|
|
||||||
if errors:
|
if errors or num_flake8_errors:
|
||||||
for error in errors:
|
for error in errors:
|
||||||
print("{}:{}: {}".format(*error))
|
print("{}:{}: {}".format(*error))
|
||||||
return 1
|
return 1
|
||||||
|
@ -22,24 +22,24 @@ import urlparse
|
|||||||
# See https://github.com/servo/servo/issues/6210 and
|
# See https://github.com/servo/servo/issues/6210 and
|
||||||
# https://github.com/servo/servo/issues/6211
|
# https://github.com/servo/servo/issues/6211
|
||||||
JQUERY_MODULES = [
|
JQUERY_MODULES = [
|
||||||
#"ajax", # panics
|
# "ajax", # panics
|
||||||
#"attributes",
|
# "attributes",
|
||||||
#"callbacks",
|
# "callbacks",
|
||||||
#"core", # mozjs crash
|
# "core", # mozjs crash
|
||||||
#"css",
|
# "css",
|
||||||
#"data",
|
# "data",
|
||||||
#"deferred",
|
# "deferred",
|
||||||
#"dimensions",
|
# "dimensions",
|
||||||
#"effects",
|
# "effects",
|
||||||
#"event", # panics
|
# "event", # panics
|
||||||
#"manipulation", # mozjs crash
|
# "manipulation", # mozjs crash
|
||||||
#"offset",
|
# "offset",
|
||||||
#"queue",
|
# "queue",
|
||||||
"selector",
|
"selector",
|
||||||
#"serialize",
|
# "serialize",
|
||||||
#"support",
|
# "support",
|
||||||
#"traversing",
|
# "traversing",
|
||||||
#"wrap"
|
# "wrap"
|
||||||
]
|
]
|
||||||
|
|
||||||
# Port to run the HTTP server on for jQuery.
|
# Port to run the HTTP server on for jQuery.
|
||||||
@ -48,6 +48,7 @@ TEST_SERVER_PORT = 8192
|
|||||||
# A regex for matching console.log output lines from the test runner.
|
# A regex for matching console.log output lines from the test runner.
|
||||||
REGEX_PATTERN = "^\[jQuery test\] \[([0-9]+)/([0-9]+)/([0-9]+)] (.*)"
|
REGEX_PATTERN = "^\[jQuery test\] \[([0-9]+)/([0-9]+)/([0-9]+)] (.*)"
|
||||||
|
|
||||||
|
|
||||||
# The result of a single test group.
|
# The result of a single test group.
|
||||||
class TestResult:
|
class TestResult:
|
||||||
def __init__(self, success, fail, total, text):
|
def __init__(self, success, fail, total, text):
|
||||||
@ -94,7 +95,7 @@ def parse_string_to_results(buffer):
|
|||||||
# Run servo and print / parse the results for a specific jQuery test module.
|
# Run servo and print / parse the results for a specific jQuery test module.
|
||||||
def run_servo(servo_exe, module):
|
def run_servo(servo_exe, module):
|
||||||
url = "http://localhost:{0}/jquery/test/?module={1}".format(TEST_SERVER_PORT, module)
|
url = "http://localhost:{0}/jquery/test/?module={1}".format(TEST_SERVER_PORT, module)
|
||||||
args = [ servo_exe, url, "-z", "-f" ]
|
args = [servo_exe, url, "-z", "-f"]
|
||||||
proc = subprocess.Popen(args, stdout=subprocess.PIPE)
|
proc = subprocess.Popen(args, stdout=subprocess.PIPE)
|
||||||
while True:
|
while True:
|
||||||
line = proc.stdout.readline()
|
line = proc.stdout.readline()
|
||||||
@ -107,26 +108,31 @@ def run_servo(servo_exe, module):
|
|||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
# Build the filename for an expected results file.
|
# Build the filename for an expected results file.
|
||||||
def module_filename(module):
|
def module_filename(module):
|
||||||
return 'expected_{0}.txt'.format(module)
|
return 'expected_{0}.txt'.format(module)
|
||||||
|
|
||||||
|
|
||||||
# Read an existing set of expected results to compare against.
|
# Read an existing set of expected results to compare against.
|
||||||
def read_existing_results(module):
|
def read_existing_results(module):
|
||||||
with open(module_filename(module), 'r') as file:
|
with open(module_filename(module), 'r') as file:
|
||||||
buffer = file.read()
|
buffer = file.read()
|
||||||
return parse_string_to_results(buffer)
|
return parse_string_to_results(buffer)
|
||||||
|
|
||||||
|
|
||||||
# Write a set of results to file
|
# Write a set of results to file
|
||||||
def write_results(module, results):
|
def write_results(module, results):
|
||||||
with open(module_filename(module), 'w') as file:
|
with open(module_filename(module), 'w') as file:
|
||||||
for result in test_results.itervalues():
|
for result in test_results.itervalues():
|
||||||
file.write(result.text + '\n')
|
file.write(result.text + '\n')
|
||||||
|
|
||||||
|
|
||||||
# Print usage if command line args are incorrect
|
# Print usage if command line args are incorrect
|
||||||
def print_usage():
|
def print_usage():
|
||||||
print("USAGE: {0} servo_binary jquery_base_dir test|update".format(sys.argv[0]))
|
print("USAGE: {0} servo_binary jquery_base_dir test|update".format(sys.argv[0]))
|
||||||
|
|
||||||
|
|
||||||
# Run a simple HTTP server to serve up the jQuery test suite
|
# Run a simple HTTP server to serve up the jQuery test suite
|
||||||
def run_http_server():
|
def run_http_server():
|
||||||
class ThreadingSimpleServer(SocketServer.ThreadingMixIn,
|
class ThreadingSimpleServer(SocketServer.ThreadingMixIn,
|
||||||
|
@ -38,7 +38,7 @@ def PowerCollector(OutputDir, Benchmarks, LayoutThreads, Renderer):
|
|||||||
powerTiming = 1
|
powerTiming = 1
|
||||||
ExperimentNum = 21
|
ExperimentNum = 21
|
||||||
for ExpNum in range(1, ExperimentNum):
|
for ExpNum in range(1, ExperimentNum):
|
||||||
for layoutT in range(1, LayoutThreads+1):
|
for layoutT in range(1, LayoutThreads + 1):
|
||||||
print(" layoutT=%d ExpNum=%d" % (layoutT, ExpNum))
|
print(" layoutT=%d ExpNum=%d" % (layoutT, ExpNum))
|
||||||
PowerFiles = path.join(
|
PowerFiles = path.join(
|
||||||
power_dir, "power-Layout%d-set%d.csv" % (layoutT, ExpNum))
|
power_dir, "power-Layout%d-set%d.csv" % (layoutT, ExpNum))
|
||||||
@ -71,7 +71,7 @@ def PowerParser(OutputDir, LayoutThreads):
|
|||||||
ResultFile.write("LayoutThreads, MeanPower, MaxPower , MinPower, MeanTime , MaxTime, "
|
ResultFile.write("LayoutThreads, MeanPower, MaxPower , MinPower, MeanTime , MaxTime, "
|
||||||
"MinTime \n")
|
"MinTime \n")
|
||||||
|
|
||||||
for layoutT in range(1, LayoutThreads+1):
|
for layoutT in range(1, LayoutThreads + 1):
|
||||||
MaxTime = 0
|
MaxTime = 0
|
||||||
MinTime = 1000000
|
MinTime = 1000000
|
||||||
MaxPower = 0
|
MaxPower = 0
|
||||||
@ -132,8 +132,8 @@ def PowerParser(OutputDir, LayoutThreads):
|
|||||||
TimeGen = TimeGen + TotalTime
|
TimeGen = TimeGen + TotalTime
|
||||||
PowerGen = PowerGen + TotalPower
|
PowerGen = PowerGen + TotalPower
|
||||||
|
|
||||||
TotalPower = PowerGen / float(ExperimentNum-1)
|
TotalPower = PowerGen / float(ExperimentNum - 1)
|
||||||
TotalTime = TimeGen / float(ExperimentNum-1)
|
TotalTime = TimeGen / float(ExperimentNum - 1)
|
||||||
ResultFile.write(str(layoutT) + " , " + str(TotalPower) + " , " +
|
ResultFile.write(str(layoutT) + " , " + str(TotalPower) + " , " +
|
||||||
str(MaxPower) + " , " + str(MinPower) + " , " +
|
str(MaxPower) + " , " + str(MinPower) + " , " +
|
||||||
str(TotalTime) + " , " + str(MaxTime) + " , " +
|
str(TotalTime) + " , " + str(MaxTime) + " , " +
|
||||||
|
Loading…
x
Reference in New Issue
Block a user