mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-11-09 04:39:03 +02:00
MozReview-Commit-ID: E83aHzA3aTa --HG-- rename : testing/web-platform/tests/conformance-checkers/html/elements/style/scoped-as-div-child-isvalid.html => testing/web-platform/tests/conformance-checkers/html/elements/style/scoped-as-div-child-novalid.html rename : testing/web-platform/tests/conformance-checkers/html/elements/style/scoped-multiple-adjacent-isvalid.html => testing/web-platform/tests/conformance-checkers/html/elements/style/scoped-multiple-adjacent-novalid.html rename : testing/web-platform/tests/conformance-checkers/html/elements/style/scoped-isvalid.html => testing/web-platform/tests/conformance-checkers/html/elements/style/scoped-novalid.html rename : testing/web-platform/tests/mediacapture-streams/GUM-api.html => testing/web-platform/tests/mediacapture-streams/GUM-api.https.html rename : testing/web-platform/tests/mediacapture-streams/GUM-deny.html => testing/web-platform/tests/mediacapture-streams/GUM-deny.https.html rename : testing/web-platform/tests/mediacapture-streams/GUM-empty-option-param.html => testing/web-platform/tests/mediacapture-streams/GUM-empty-option-param.https.html rename : testing/web-platform/tests/mediacapture-streams/GUM-unknownkey-option-param.html => testing/web-platform/tests/mediacapture-streams/GUM-unknownkey-option-param.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaDevices-enumerateDevices.html => testing/web-platform/tests/mediacapture-streams/MediaDevices-enumerateDevices.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaDevices-getUserMedia.html => testing/web-platform/tests/mediacapture-streams/MediaDevices-getUserMedia.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-MediaElement-preload-none.html => testing/web-platform/tests/mediacapture-streams/MediaStream-MediaElement-preload-none.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-MediaElement-srcObject.html => testing/web-platform/tests/mediacapture-streams/MediaStream-MediaElement-srcObject.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-add-audio-track.html => testing/web-platform/tests/mediacapture-streams/MediaStream-add-audio-track.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-audio-only.html => testing/web-platform/tests/mediacapture-streams/MediaStream-audio-only.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-finished-add.html => testing/web-platform/tests/mediacapture-streams/MediaStream-finished-add.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-gettrackid.html => testing/web-platform/tests/mediacapture-streams/MediaStream-gettrackid.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-id-manual.html => testing/web-platform/tests/mediacapture-streams/MediaStream-id-manual.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-idl.html => testing/web-platform/tests/mediacapture-streams/MediaStream-idl.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-removetrack.html => testing/web-platform/tests/mediacapture-streams/MediaStream-removetrack.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStream-video-only.html => testing/web-platform/tests/mediacapture-streams/MediaStream-video-only.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-MediaElement-disabled-audio-is-silence.html => testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-MediaElement-disabled-audio-is-silence.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-MediaElement-disabled-video-is-black.html => testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-MediaElement-disabled-video-is-black.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-end.html => testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-end.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-id.html => testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-id.https.html rename : testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-init.html => testing/web-platform/tests/mediacapture-streams/MediaStreamTrack-init.https.html
120 lines
3.3 KiB
Python
120 lines
3.3 KiB
Python
#!/usr/bin/env python
|
|
import argparse
|
|
import imp
|
|
import os
|
|
import sys
|
|
|
|
import manifest
|
|
from . import vcs
|
|
from .log import get_logger
|
|
from .tree import GitTree, NoVCSTree
|
|
|
|
here = os.path.dirname(__file__)
|
|
localpaths = imp.load_source("localpaths", os.path.abspath(os.path.join(here, os.pardir, "localpaths.py")))
|
|
|
|
def update(tests_root, url_base, manifest, ignore_local=False):
|
|
if vcs.is_git_repo(tests_root):
|
|
tests_tree = GitTree(tests_root, url_base)
|
|
remove_missing_local = False
|
|
else:
|
|
tests_tree = NoVCSTree(tests_root, url_base)
|
|
remove_missing_local = not ignore_local
|
|
|
|
if not ignore_local:
|
|
local_changes = tests_tree.local_changes()
|
|
else:
|
|
local_changes = None
|
|
|
|
manifest.update(tests_root,
|
|
url_base,
|
|
tests_tree.current_rev(),
|
|
tests_tree.committed_changes(manifest.rev),
|
|
local_changes,
|
|
remove_missing_local=remove_missing_local)
|
|
|
|
|
|
def update_from_cli(**kwargs):
|
|
tests_root = kwargs["tests_root"]
|
|
path = kwargs["path"]
|
|
assert tests_root is not None
|
|
|
|
m = None
|
|
logger = get_logger()
|
|
|
|
if not kwargs.get("rebuild", False):
|
|
try:
|
|
m = manifest.load(tests_root, path)
|
|
except manifest.ManifestVersionMismatch:
|
|
logger.info("Manifest version changed, rebuilding")
|
|
m = None
|
|
else:
|
|
logger.info("Updating manifest")
|
|
|
|
if m is None:
|
|
m = manifest.Manifest(None)
|
|
|
|
|
|
update(tests_root,
|
|
kwargs["url_base"],
|
|
m,
|
|
ignore_local=kwargs.get("ignore_local", False))
|
|
manifest.write(m, path)
|
|
|
|
|
|
def abs_path(path):
|
|
return os.path.abspath(os.path.expanduser(path))
|
|
|
|
|
|
def create_parser():
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument(
|
|
"-p", "--path", type=abs_path, help="Path to manifest file.")
|
|
parser.add_argument(
|
|
"--tests-root", type=abs_path, help="Path to root of tests.")
|
|
parser.add_argument(
|
|
"-r", "--rebuild", action="store_true", default=False,
|
|
help="Force a full rebuild of the manifest.")
|
|
parser.add_argument(
|
|
"--ignore-local", action="store_true", default=False,
|
|
help="Don't include uncommitted local changes in the manifest.")
|
|
parser.add_argument(
|
|
"--url-base", action="store", default="/",
|
|
help="Base url to use as the mount point for tests in this manifest.")
|
|
return parser
|
|
|
|
|
|
def find_top_repo():
|
|
path = here
|
|
rv = None
|
|
while path != "/":
|
|
if vcs.is_git_repo(path):
|
|
rv = path
|
|
path = os.path.abspath(os.path.join(path, os.pardir))
|
|
|
|
return rv
|
|
|
|
def main(default_tests_root=None):
|
|
opts = create_parser().parse_args()
|
|
|
|
if opts.tests_root is None:
|
|
tests_root = None
|
|
if default_tests_root is not None:
|
|
tests_root = default_tests_root
|
|
else:
|
|
tests_root = find_top_repo()
|
|
|
|
if tests_root is None:
|
|
print >> sys.stderr, """No git repo found; could not determine test root.
|
|
Run again with --test-root"""
|
|
sys.exit(1)
|
|
|
|
opts.tests_root = tests_root
|
|
|
|
if opts.path is None:
|
|
opts.path = os.path.join(opts.tests_root, "MANIFEST.json")
|
|
|
|
update_from_cli(**vars(opts))
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|