2012-05-21 15:12:37 +04:00
|
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
2012-03-31 08:42:20 +04:00
|
|
|
|
|
|
|
import os, sys
|
|
|
|
import glob
|
2012-04-13 02:14:10 +04:00
|
|
|
import optparse
|
|
|
|
import traceback
|
2012-03-31 08:42:20 +04:00
|
|
|
import WebIDL
|
|
|
|
|
|
|
|
class TestHarness(object):
|
2012-04-13 02:14:10 +04:00
|
|
|
def __init__(self, test, verbose):
|
|
|
|
self.test = test
|
|
|
|
self.verbose = verbose
|
|
|
|
self.printed_intro = False
|
|
|
|
|
|
|
|
def start(self):
|
|
|
|
if self.verbose:
|
|
|
|
self.maybe_print_intro()
|
|
|
|
|
|
|
|
def finish(self):
|
|
|
|
if self.verbose or self.printed_intro:
|
|
|
|
print "Finished test %s" % self.test
|
|
|
|
|
|
|
|
def maybe_print_intro(self):
|
|
|
|
if not self.printed_intro:
|
|
|
|
print "Starting test %s" % self.test
|
|
|
|
self.printed_intro = True
|
|
|
|
|
|
|
|
def test_pass(self, msg):
|
|
|
|
if self.verbose:
|
|
|
|
print "TEST-PASS | %s" % msg
|
|
|
|
|
|
|
|
def test_fail(self, msg):
|
|
|
|
self.maybe_print_intro()
|
|
|
|
print "TEST-UNEXPECTED-FAIL | %s" % msg
|
|
|
|
|
2012-03-31 08:42:20 +04:00
|
|
|
def ok(self, condition, msg):
|
|
|
|
if condition:
|
2012-04-13 02:14:10 +04:00
|
|
|
self.test_pass(msg)
|
2012-03-31 08:42:20 +04:00
|
|
|
else:
|
2012-04-13 02:14:10 +04:00
|
|
|
self.test_fail(msg)
|
2012-03-31 08:42:20 +04:00
|
|
|
|
|
|
|
def check(self, a, b, msg):
|
|
|
|
if a == b:
|
2012-04-13 02:14:10 +04:00
|
|
|
self.test_pass(msg)
|
2012-03-31 08:42:20 +04:00
|
|
|
else:
|
2012-04-13 02:14:10 +04:00
|
|
|
self.test_fail(msg)
|
2012-03-31 08:42:20 +04:00
|
|
|
print "\tGot %s expected %s" % (a, b)
|
|
|
|
|
2012-04-13 02:14:10 +04:00
|
|
|
def run_tests(tests, verbose):
|
|
|
|
testdir = os.path.join(os.path.dirname(__file__), 'tests')
|
|
|
|
if not tests:
|
|
|
|
tests = glob.iglob(os.path.join(testdir, "*.py"))
|
|
|
|
sys.path.append(testdir)
|
2012-03-31 08:42:20 +04:00
|
|
|
|
|
|
|
for test in tests:
|
|
|
|
(testpath, ext) = os.path.splitext(os.path.basename(test))
|
|
|
|
_test = __import__(testpath, globals(), locals(), ['WebIDLTest'])
|
2012-04-13 02:14:10 +04:00
|
|
|
|
|
|
|
harness = TestHarness(test, verbose)
|
|
|
|
harness.start()
|
|
|
|
try:
|
|
|
|
_test.WebIDLTest.__call__(WebIDL.Parser(), harness)
|
2012-06-12 18:22:05 +04:00
|
|
|
except Exception, ex:
|
|
|
|
print "TEST-UNEXPECTED-FAIL | Unhandled exception in test %s: %s" % (testpath, ex)
|
2012-04-13 02:14:10 +04:00
|
|
|
traceback.print_exc()
|
|
|
|
finally:
|
|
|
|
harness.finish()
|
2012-03-31 08:42:20 +04:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2012-04-13 02:14:10 +04:00
|
|
|
usage = """%prog [OPTIONS] [TESTS]
|
|
|
|
Where TESTS are relative to the tests directory."""
|
|
|
|
parser = optparse.OptionParser(usage=usage)
|
|
|
|
parser.add_option('-q', '--quiet', action='store_false', dest='verbose', default=True,
|
|
|
|
help="Don't print passing tests.")
|
|
|
|
options, tests = parser.parse_args()
|
|
|
|
|
|
|
|
run_tests(tests, verbose=options.verbose)
|