2018-10-17 19:00:16 +00:00
|
|
|
# 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=(.*)")
|
2019-02-21 12:36:52 +00:00
|
|
|
META_TIMEOUT_REGEXP = re.compile(r"META:\s*timeout=(.*)")
|
2018-10-17 19:00:16 +00:00
|
|
|
|
2019-08-27 14:14:34 +00:00
|
|
|
proposal_flags = [{
|
|
|
|
'name': 'reference-types',
|
2020-06-09 15:54:14 +00:00
|
|
|
'flags': ['--experimental-wasm-reftypes',
|
2020-06-16 07:00:12 +00:00
|
|
|
'--no-experimental-wasm-bulk-memory',
|
|
|
|
'--wasm-staging']
|
2019-08-27 14:14:34 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
'name': 'bulk-memory-operations',
|
2020-06-16 07:00:12 +00:00
|
|
|
'flags': ['--experimental-wasm-bulk-memory',
|
|
|
|
'--wasm-staging']
|
2019-08-28 11:26:02 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
'name': 'js-types',
|
|
|
|
'flags': ['--experimental-wasm-type-reflection',
|
2020-07-02 13:13:23 +00:00
|
|
|
'--wasm-staging']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
'name': 'tail-call',
|
|
|
|
'flags': ['--experimental-wasm-tail-call',
|
2020-06-16 07:00:12 +00:00
|
|
|
'--wasm-staging']
|
2019-09-05 10:44:10 +00:00
|
|
|
},
|
Reland "[wasm-simd] Stage SIMD"
This reverts commit e8976cf93a65b97b10d0bdd41cb07577bdb6f959.
Reason for revert: Mark f32x4_cmp as fail, lowering is not fully implemented yet.
Original change's description:
> Revert "[wasm-simd] Stage SIMD"
>
> This reverts commit 1d2726dd0b4ae2d063ca01fbab71fbaeab2e02e5.
>
> Reason for revert: ODROID failure: https://ci.chromium.org/p/v8/builders/ci/V8%20Arm%20-%20debug/15814?
>
> Original change's description:
> > [wasm-simd] Stage SIMD
> >
> > SIMD has been pretty stable for a while now, we are not expecting big
> > changes (like opcode renumbers), there might be new instructions added,
> > and they will all be backwards-compatible.
> >
> > The reference interpreter in the SIMD proposal is now capable of
> > generating JS files for all test cases, so we can now run them.
> >
> > There is a bit of tweaking necessary, since SIMD tests are in
> > tests/core/simd subfolder in the spec, so we need to change the glob
> > into a find that will traverse into subdirectory.
> >
> > Bug: v8:10835
> > Change-Id: I1f7e3cf37f21b2aa2537d1e34242da2373bbf626
> > Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2378587
> > Commit-Queue: Zhi An Ng <zhin@chromium.org>
> > Reviewed-by: Andreas Haas <ahaas@chromium.org>
> > Cr-Commit-Position: refs/heads/master@{#69793}
>
> TBR=bbudge@chromium.org,ahaas@chromium.org,zhin@chromium.org
>
> Change-Id: I3a90c616109ca048691d97ab45698bc15a678e18
> No-Presubmit: true
> No-Tree-Checks: true
> No-Try: true
> Bug: v8:10835
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2402379
> Reviewed-by: Shu-yu Guo <syg@chromium.org>
> Commit-Queue: Shu-yu Guo <syg@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#69794}
TBR=bbudge@chromium.org,ahaas@chromium.org,zhin@chromium.org,syg@chromium.org
# Not skipping CQ checks because this is a reland.
Bug: v8:10835
Change-Id: I3d87dd2adba6ada2ec3ebf5e13bff378a74b03e8
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2402386
Reviewed-by: Zhi An Ng <zhin@chromium.org>
Reviewed-by: Andreas Haas <ahaas@chromium.org>
Commit-Queue: Zhi An Ng <zhin@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69817}
2020-09-10 00:16:53 +00:00
|
|
|
{
|
|
|
|
'name': 'simd',
|
|
|
|
'flags': ['--experimental-wasm-simd',
|
|
|
|
'--wasm-staging']
|
|
|
|
},
|
2019-09-05 10:44:10 +00:00
|
|
|
]
|
2019-08-27 14:14:34 +00:00
|
|
|
|
2019-02-05 14:00:49 +00:00
|
|
|
|
|
|
|
class TestLoader(testsuite.JSTestLoader):
|
|
|
|
@property
|
2019-06-25 11:29:36 +00:00
|
|
|
def extensions(self):
|
|
|
|
return [ANY_JS]
|
2019-02-05 14:00:49 +00:00
|
|
|
|
|
|
|
|
2018-10-17 19:00:16 +00:00
|
|
|
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")
|
2019-08-27 14:14:34 +00:00
|
|
|
self.test_root = os.path.join(self.root, "tests")
|
2019-02-05 14:00:49 +00:00
|
|
|
self._test_loader.test_root = self.test_root
|
2018-10-17 19:00:16 +00:00
|
|
|
|
2019-02-05 14:00:49 +00:00
|
|
|
def _test_loader_class(self):
|
|
|
|
return TestLoader
|
2018-10-17 19:00:16 +00:00
|
|
|
|
|
|
|
def _test_class(self):
|
|
|
|
return TestCase
|
|
|
|
|
2019-08-27 14:14:34 +00:00
|
|
|
def get_proposal_path_identifier(proposal):
|
|
|
|
return os.sep.join(['proposals', proposal['name']])
|
2018-10-17 19:00:16 +00:00
|
|
|
|
|
|
|
class TestCase(testcase.D8TestCase):
|
2019-02-21 12:36:52 +00:00
|
|
|
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
|
|
|
|
|
2018-10-17 19:00:16 +00:00
|
|
|
def _get_files_params(self):
|
2019-08-27 14:14:34 +00:00
|
|
|
files = [self.suite.mjsunit_js,
|
2020-06-16 07:00:12 +00:00
|
|
|
os.path.join(self.suite.root, "third_party", "testharness.js"),
|
|
|
|
os.path.join(self.suite.root, "testharness-additions.js"),
|
|
|
|
os.path.join(self.suite.root, "report.js")]
|
2018-10-17 19:00:16 +00:00
|
|
|
|
|
|
|
source = self.get_source()
|
2019-08-27 14:14:34 +00:00
|
|
|
current_dir = os.path.dirname(self._get_source_path())
|
2018-10-17 19:00:16 +00:00
|
|
|
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.
|
2019-08-27 14:14:34 +00:00
|
|
|
found = False
|
|
|
|
for proposal in proposal_flags:
|
|
|
|
if get_proposal_path_identifier(proposal) in current_dir:
|
|
|
|
found = True
|
|
|
|
script = os.path.join(self.suite.test_root,
|
|
|
|
os.sep.join(['proposals', proposal['name']]),
|
|
|
|
script[len(WPT_ROOT):])
|
|
|
|
if not found:
|
|
|
|
script = os.path.join(self.suite.test_root, script[len(WPT_ROOT):])
|
2018-10-17 19:00:16 +00:00
|
|
|
elif not script.startswith("/"):
|
|
|
|
# Matched a relative path, prepend this test's directory.
|
2019-08-27 14:14:34 +00:00
|
|
|
script = os.path.join(current_dir, script)
|
2018-10-17 19:00:16 +00:00
|
|
|
else:
|
|
|
|
raise Exception("Unexpected absolute path for script: \"%s\"" % script);
|
|
|
|
|
|
|
|
files.append(script)
|
|
|
|
|
2020-06-16 07:00:12 +00:00
|
|
|
files.extend([self._get_source_path(),
|
|
|
|
os.path.join(self.suite.root, "after.js")])
|
2018-10-17 19:00:16 +00:00
|
|
|
return files
|
|
|
|
|
2019-08-27 14:14:34 +00:00
|
|
|
def _get_source_flags(self):
|
|
|
|
for proposal in proposal_flags:
|
|
|
|
if get_proposal_path_identifier(proposal) in self.path:
|
|
|
|
return proposal['flags']
|
2020-06-16 07:00:12 +00:00
|
|
|
return ['--wasm-staging']
|
2019-08-27 14:14:34 +00:00
|
|
|
|
2018-10-17 19:00:16 +00:00
|
|
|
def _get_source_path(self):
|
|
|
|
# All tests are named `path/name.any.js`
|
2019-02-05 14:00:49 +00:00
|
|
|
return os.path.join(self.suite.test_root, self.path + ANY_JS)
|
2018-10-17 19:00:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
def GetSuite(*args, **kwargs):
|
|
|
|
return TestSuite(*args, **kwargs)
|