summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/annotation-model/tools/make_tests.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
commit43a97878ce14b72f0981164f87f2e35e14151312 (patch)
tree620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/annotation-model/tools/make_tests.py
parentInitial commit. (diff)
downloadfirefox-43a97878ce14b72f0981164f87f2e35e14151312.tar.xz
firefox-43a97878ce14b72f0981164f87f2e35e14151312.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.py102
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)