gecko-dev/testing/web-platform/tests/tools/manifest/update.py
James Graham 01d463c115 Bug 1279809 - Update web-platform-tests to revision 664c6072db0f96031ff775f4a6c0a744e77c3265, a=testonly
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
2016-06-23 10:36:47 +01:00

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()