mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-12 06:52:25 +00:00
02a7b4ebdf
Allow-list all Python code in tree for use with the black linter, and re-format all code in-tree accordingly. To produce this patch I did all of the following: 1. Make changes to tools/lint/black.yml to remove include: stanza and update list of source extensions. 2. Run ./mach lint --linter black --fix 3. Make some ad-hoc manual updates to python/mozbuild/mozbuild/test/configure/test_configure.py -- it has some hard-coded line numbers that the reformat breaks. 4. Make some ad-hoc manual updates to `testing/marionette/client/setup.py`, `testing/marionette/harness/setup.py`, and `testing/firefox-ui/harness/setup.py`, which have hard-coded regexes that break after the reformat. 5. Add a set of exclusions to black.yml. These will be deleted in a follow-up bug (1672023). # ignore-this-changeset Differential Revision: https://phabricator.services.mozilla.com/D94045
113 lines
3.2 KiB
Python
113 lines
3.2 KiB
Python
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
from __future__ import absolute_import, print_function, unicode_literals
|
|
|
|
import argparse
|
|
import functools
|
|
import logging
|
|
import os
|
|
import sys
|
|
|
|
from six import iteritems
|
|
|
|
from mach.decorators import (
|
|
CommandProvider,
|
|
Command,
|
|
)
|
|
|
|
from mozbuild.base import (
|
|
MachCommandBase,
|
|
MachCommandConditions as conditions,
|
|
BinaryNotFoundException,
|
|
)
|
|
|
|
SUPPORTED_APPS = ["firefox", "android", "thunderbird"]
|
|
|
|
|
|
def create_parser_tests():
|
|
from marionette_harness.runtests import MarionetteArguments
|
|
from mozlog.structured import commandline
|
|
|
|
parser = MarionetteArguments()
|
|
commandline.add_logging_group(parser)
|
|
return parser
|
|
|
|
|
|
def run_marionette(tests, binary=None, topsrcdir=None, **kwargs):
|
|
from mozlog.structured import commandline
|
|
|
|
from marionette_harness.runtests import MarionetteTestRunner, MarionetteHarness
|
|
|
|
parser = create_parser_tests()
|
|
|
|
args = argparse.Namespace(tests=tests)
|
|
|
|
args.binary = binary
|
|
args.logger = kwargs.pop("log", None)
|
|
|
|
for k, v in iteritems(kwargs):
|
|
setattr(args, k, v)
|
|
|
|
parser.verify_usage(args)
|
|
|
|
if not args.logger:
|
|
args.logger = commandline.setup_logging(
|
|
"Marionette Unit Tests", args, {"mach": sys.stdout}
|
|
)
|
|
failed = MarionetteHarness(MarionetteTestRunner, args=vars(args)).run()
|
|
if failed > 0:
|
|
return 1
|
|
else:
|
|
return 0
|
|
|
|
|
|
@CommandProvider
|
|
class MarionetteTest(MachCommandBase):
|
|
@Command(
|
|
"marionette-test",
|
|
category="testing",
|
|
description="Remote control protocol to Gecko, used for browser automation.",
|
|
conditions=[functools.partial(conditions.is_buildapp_in, apps=SUPPORTED_APPS)],
|
|
parser=create_parser_tests,
|
|
)
|
|
def marionette_test(self, tests, **kwargs):
|
|
if "test_objects" in kwargs:
|
|
tests = []
|
|
for obj in kwargs["test_objects"]:
|
|
tests.append(obj["file_relpath"])
|
|
del kwargs["test_objects"]
|
|
|
|
if not tests:
|
|
if conditions.is_thunderbird(self):
|
|
tests = [
|
|
os.path.join(
|
|
self.topsrcdir, "comm/testing/marionette/unit-tests.ini"
|
|
)
|
|
]
|
|
else:
|
|
tests = [
|
|
os.path.join(
|
|
self.topsrcdir,
|
|
"testing/marionette/harness/marionette_harness/tests/unit-tests.ini",
|
|
)
|
|
]
|
|
|
|
if not kwargs.get("binary") and (
|
|
conditions.is_firefox(self) or conditions.is_thunderbird(self)
|
|
):
|
|
try:
|
|
kwargs["binary"] = self.get_binary_path("app")
|
|
except BinaryNotFoundException as e:
|
|
self.log(
|
|
logging.ERROR,
|
|
"marionette-test",
|
|
{"error": str(e)},
|
|
"ERROR: {error}",
|
|
)
|
|
self.log(logging.INFO, "marionette-test", {"help": e.help()}, "{help}")
|
|
return 1
|
|
|
|
return run_marionette(tests, topsrcdir=self.topsrcdir, **kwargs)
|