6b52a54b9a
testrunner assumes that each test suite has a single extension for base tests. ".mjs" extension can be used for ECMAScript modules in addition to the standard extension ".js" we use for the base tests. This CL generalizes the {TestLoader} to accept multiple extensions for a single test suite. R=mathias@chromium.org TBR=machenbach@chromium.org CC=gsathya@chromium.org Bug: v8:9395 Change-Id: Ibc155f4963472fe9f989458cd839f3642ffbddea Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1675961 Reviewed-by: Mathias Bynens <mathias@chromium.org> Reviewed-by: Tamer Tas <tmrts@chromium.org> Commit-Queue: Mathias Bynens <mathias@chromium.org> Auto-Submit: Tamer Tas <tmrts@chromium.org> Cr-Commit-Position: refs/heads/master@{#62356}
84 lines
2.5 KiB
Python
84 lines
2.5 KiB
Python
# Copyright 2018 the V8 project authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
import os
|
|
import re
|
|
|
|
from testrunner.local import testsuite
|
|
from testrunner.objects import testcase
|
|
|
|
ANY_JS = ".any.js"
|
|
WPT_ROOT = "/wasm/jsapi/"
|
|
META_SCRIPT_REGEXP = re.compile(r"META:\s*script=(.*)")
|
|
META_TIMEOUT_REGEXP = re.compile(r"META:\s*timeout=(.*)")
|
|
|
|
|
|
class TestLoader(testsuite.JSTestLoader):
|
|
@property
|
|
def extensions(self):
|
|
return [ANY_JS]
|
|
|
|
|
|
class TestSuite(testsuite.TestSuite):
|
|
def __init__(self, *args, **kwargs):
|
|
super(TestSuite, self).__init__(*args, **kwargs)
|
|
self.mjsunit_js = os.path.join(os.path.dirname(self.root), "mjsunit",
|
|
"mjsunit.js")
|
|
self.test_root = os.path.join(self.root, "data", "test", "js-api")
|
|
self._test_loader.test_root = self.test_root
|
|
|
|
def _test_loader_class(self):
|
|
return TestLoader
|
|
|
|
def _test_class(self):
|
|
return TestCase
|
|
|
|
|
|
class TestCase(testcase.D8TestCase):
|
|
def _get_timeout_param(self):
|
|
source = self.get_source()
|
|
timeout_params = META_TIMEOUT_REGEXP.findall(source)
|
|
if not timeout_params:
|
|
return None
|
|
|
|
if timeout_params[0] in ["long"]:
|
|
return timeout_params[0]
|
|
else:
|
|
print("unknown timeout param %s in %s%s"
|
|
% (timeout_params[0], self.path, ANY_JS))
|
|
return None
|
|
|
|
def _get_files_params(self):
|
|
files = [os.path.join(self.suite.mjsunit_js),
|
|
os.path.join(self.suite.root, "testharness.js")]
|
|
|
|
source = self.get_source()
|
|
for script in META_SCRIPT_REGEXP.findall(source):
|
|
if script.startswith(WPT_ROOT):
|
|
# Matched an absolute path, strip the root and replace it with our
|
|
# local root.
|
|
script = os.path.join(self.suite.test_root, script[len(WPT_ROOT):])
|
|
elif not script.startswith("/"):
|
|
# Matched a relative path, prepend this test's directory.
|
|
thisdir = os.path.dirname(self._get_source_path())
|
|
script = os.path.join(thisdir, script)
|
|
else:
|
|
raise Exception("Unexpected absolute path for script: \"%s\"" % script);
|
|
|
|
files.append(script)
|
|
|
|
files.extend([
|
|
self._get_source_path(),
|
|
os.path.join(self.suite.root, "testharness-after.js")
|
|
])
|
|
return files
|
|
|
|
def _get_source_path(self):
|
|
# All tests are named `path/name.any.js`
|
|
return os.path.join(self.suite.test_root, self.path + ANY_JS)
|
|
|
|
|
|
def GetSuite(*args, **kwargs):
|
|
return TestSuite(*args, **kwargs)
|