diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 09:22:09 +0000 |
commit | 43a97878ce14b72f0981164f87f2e35e14151312 (patch) | |
tree | 620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/annotation-model/tools/make_tests.py | |
parent | Initial commit. (diff) | |
download | firefox-upstream.tar.xz firefox-upstream.zip |
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/annotation-model/tools/make_tests.py')
-rw-r--r-- | testing/web-platform/tests/annotation-model/tools/make_tests.py | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/testing/web-platform/tests/annotation-model/tools/make_tests.py b/testing/web-platform/tests/annotation-model/tools/make_tests.py new file mode 100644 index 0000000000..e8bb1aec5a --- /dev/null +++ b/testing/web-platform/tests/annotation-model/tools/make_tests.py @@ -0,0 +1,102 @@ +# This tool creates .html test files for the WPT harness from corresponding .test +# files that it finds in the tree for this test collection. + +from __future__ import print_function + +import re +import time +import json +import fnmatch +import os +import shutil +import sys +import argparse + +TESTTREE = '..' +DEFDIR = '../definitions' +MANUAL_TEMPLATE = 'template_manual' +JS_TEMPLATE = 'template_js' + +parser = argparse.ArgumentParser() + +parser.add_argument('--examples', action="store_const", const=1) + +args = parser.parse_args() + +# pull in the template + +manualTemplate = open(MANUAL_TEMPLATE, "r").read() +autoTemplate = open(JS_TEMPLATE, "r").read() + +defList = [] +defnames = "" + +# find all of the definitions +for curdir, subdirList, fileList in os.walk(DEFDIR, topdown=True): + for file in fnmatch.filter(fileList, "*.json"): + theFile = os.path.join(curdir, file) + try: + testJSON = json.load(open(theFile, "r")) + except ValueError as e: + print("parse of " + theFile + " failed: " + e[0]) + else: + theFile = re.sub("\.\./", "", theFile) + defList.append(theFile) + +if (len(defList)): + defNames = '"' + '",\n "'.join(defList) + '"' + + +# iterate over the folders looking for .test files + +for curdir, subdirList, fileList in os.walk(TESTTREE, topdown=True): + # skip the definitions directory + subdirList[:] = [d for d in subdirList if d != "definitions"] + # skip the examples directory + if args.examples != 1: + subdirList[:] = [d for d in subdirList if d != "examples"] + + for file in fnmatch.filter(fileList, "*.test"): +# for each .test file, create a corresponding .html file using the appropriate +# template + theFile = os.path.join(curdir, file) + try: + testJSON = json.load(open(theFile, "r")) + except ValueError as e: + print("parse of " + theFile + " failed: " + e[0]) + else: + try: + testType = testJSON['testType'] + except: + testType = "manual" + + templateFile = manualTemplate + suffix = "-manual.html" + + if testType == "automated": + templateFile = autoTemplate + suffix = ".html" + + rfile = re.sub("\.\./", "", file) + # interesting pattern is {{TESTFILE}} + tcopy = re.sub("{{TESTFILE}}", rfile, templateFile) + + tcopy = re.sub("{{SCHEMADEFS}}", defNames, tcopy) + + try: + title = testJSON['name'] + except: + title = file + tcopy = re.sub("{{TESTTITLE}}", title, tcopy) + + # target file is basename of theFile + '-manual.html' + target = re.sub("\.test",suffix, theFile) + + try: + out = open(target, "w") + out.write(tcopy) + out.close() + except: + print("Failed to create "+target) + else: + print("Created " + target) |