Chromium Code Reviews| Index: test/test262/testcfg.py |
| diff --git a/test/test262/testcfg.py b/test/test262/testcfg.py |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..0ac52d8bd7c294714b8289a30a9b5f5709cc58ff |
| --- /dev/null |
| +++ b/test/test262/testcfg.py |
| @@ -0,0 +1,139 @@ |
| +# Copyright 2011 the V8 project authors. All rights reserved. |
| +# Redistribution and use in source and binary forms, with or without |
| +# modification, are permitted provided that the following conditions are |
| +# met: |
| +# |
| +# * Redistributions of source code must retain the above copyright |
| +# notice, this list of conditions and the following disclaimer. |
| +# * Redistributions in binary form must reproduce the above |
| +# copyright notice, this list of conditions and the following |
| +# disclaimer in the documentation and/or other materials provided |
| +# with the distribution. |
| +# * Neither the name of Google Inc. nor the names of its |
| +# contributors may be used to endorse or promote products derived |
| +# from this software without specific prior written permission. |
| +# |
| +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| + |
| + |
| +import test |
| +import os |
| +from os.path import join, exists |
| + |
| + |
| +TEST_262_HARNESS = ['sta.js'] |
| + |
| + |
| +class Test262TestCase(test.TestCase): |
| + |
| + def __init__(self, filename, path, context, root, mode, framework): |
| + super(Test262TestCase, self).__init__(context, path, mode) |
| + self.filename = filename |
| + self.framework = framework |
| + self.root = root |
| + |
| + def IsNegative(self): |
| + return self.filename.endswith('-n.js') |
| + |
| + def GetLabel(self): |
| + return "%s test262 %s %s" % (self.mode, self.GetGroup(), self.GetName()) |
| + |
| + def IsFailureOutput(self, output): |
| + if output.exit_code != 0: |
| + return True |
| + return 'FAILED!' in output.stdout |
| + |
| + def GetCommand(self): |
| + result = self.context.GetVmCommand(self, self.mode) |
| + result += ['-e', 'var window = this'] |
| + result += self.framework |
| + result.append(self.filename) |
| + return result |
| + |
| + def GetName(self): |
| + return self.path[-1] |
| + |
| + def GetGroup(self): |
| + return self.path[0] |
| + |
| + def GetSource(self): |
| + return open(self.filename).read() |
| + |
| + |
| +class Test262TestConfiguration(test.TestConfiguration): |
| + |
| + def __init__(self, context, root): |
| + super(Test262TestConfiguration, self).__init__(context, root) |
| + |
| + def AddIETestCenter(self, tests, current_path, path, mode): |
| + current_root = join(self.root, 'data', 'test', 'suite', 'ietestcenter') |
| + harness = [join(self.root, 'jquery.js')] |
| + harness += [join(self.root, 'data', 'test', 'harness', f) for f in TEST_262_HARNESS] |
|
Rico
2011/03/21 10:23:53
Long line
Martin Maly
2011/03/28 20:04:21
Done.
|
| + harness += [join(self.root, 'harness-adapt.js')] |
| + for root, dirs, files in os.walk(current_root): |
| + for dotted in [x for x in dirs if x.startswith('.')]: |
| + dirs.remove(dotted) |
| + dirs.sort() |
| + root_path = root[len(self.root):].split(os.path.sep) |
| + root_path = current_path + [x for x in root_path if x] |
| + files.sort() |
| + for file in files: |
| + if file.endswith('.js'): |
| + if self.Contains(path, root_path): |
| + test_path = ['ietestcenter', file[:-3]] |
| + test = Test262TestCase(join(root, file), test_path, self.context, |
| + self.root, mode, harness) |
| + tests.append(test) |
| + |
| + def AddSputnikConvertedTests(self, tests, current_path, path, mode): |
| + current_root = join(self.root, 'data', 'test', 'suite', 'sputnik_converted') |
| + harness = [join(self.root, 'jquery.js')] |
| + harness += [join(self.root, 'data', 'test', 'harness', f) for f in TEST_262_HARNESS] |
|
Rico
2011/03/21 10:23:53
Long line
Martin Maly
2011/03/28 20:04:21
Done.
|
| + harness += [join(self.root, 'harness-adapt.js')] |
| + for root, dirs, files in os.walk(current_root): |
| + for dotted in [x for x in dirs if x.startswith('.')]: |
| + dirs.remove(dotted) |
| + dirs.sort() |
| + root_path = root[len(self.root):].split(os.path.sep) |
| + root_path = current_path + [x for x in root_path if x] |
| + files.sort() |
| + for file in files: |
| + if file.endswith('.js'): |
| + if self.Contains(path, root_path): |
| + test_path = ['sputnik_converted', file[:-3]] |
| + test = Test262TestCase(join(root, file), test_path, self.context, |
| + self.root, mode, harness) |
| + tests.append(test) |
| + |
| + def AddSputnikTests(self, tests, current_path, path, mode): |
| + # To be implemented |
| + pass |
| + |
| + def ListTests(self, current_path, path, mode): |
| + tests = [] |
| + self.AddIETestCenter(tests, current_path, path, mode) |
| + self.AddSputnikConvertedTests(tests, current_path, path, mode) |
| + self.AddSputnikTests(tests, current_path, path, mode) |
| + return tests |
| + |
| + def GetBuildRequirements(self): |
| + return ['sample', 'sample=shell'] |
| + |
| + def GetTestStatus(self, sections, defs): |
| + status_file = join(self.root, 'test262.status') |
| + if exists(status_file): |
| + test.ReadConfigurationInto(status_file, sections, defs) |
| + |
| + |
| +def GetConfiguration(context, root): |
| + return Test262TestConfiguration(context, root) |