2014-11-11 19:20:57 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
# Copyright 2014 by Sam Mikes. All rights reserved.
|
|
|
|
# This code is governed by the BSD license found in the LICENSE file.
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
import cStringIO
|
|
|
|
from functools import wraps
|
|
|
|
|
|
|
|
sys.path.insert(0, "..")
|
|
|
|
|
|
|
|
import test262
|
|
|
|
|
|
|
|
class TestTest262(unittest.TestCase):
|
|
|
|
|
|
|
|
def test_that_tests_run(self):
|
|
|
|
self.assertEqual(1 + 2, 3)
|
|
|
|
|
|
|
|
class MockTest(object):
|
|
|
|
|
|
|
|
def __init__(self, name, negative):
|
|
|
|
self.name = name
|
|
|
|
self.negative = negative if negative else False
|
|
|
|
self.strict_mode = False
|
|
|
|
|
|
|
|
def GetName(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
def IsNegative(self):
|
|
|
|
return self.negative
|
|
|
|
|
|
|
|
def GetMode(self):
|
|
|
|
if self.strict_mode:
|
|
|
|
return "strict mode"
|
|
|
|
|
|
|
|
return "non-strict mode"
|
|
|
|
|
|
|
|
class MockResult(object):
|
|
|
|
|
|
|
|
def __init__(self, case):
|
|
|
|
self.case = case
|
|
|
|
|
2014-12-01 21:46:34 +01:00
|
|
|
|
2014-11-11 19:20:57 +01:00
|
|
|
|
|
|
|
class TestTestSuite(unittest.TestCase):
|
|
|
|
|
|
|
|
def test_that_tests_run(self):
|
|
|
|
self.assertEqual(1 + 2, 3)
|
|
|
|
|
|
|
|
def test_create_test_suite(self):
|
|
|
|
test_suite = test262.TestSuite(".",
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
None)
|
|
|
|
self.assertNotEqual(test_suite, None)
|
|
|
|
|
|
|
|
def test_summary(self):
|
|
|
|
test_suite = test262.TestSuite(".",
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
None)
|
|
|
|
|
|
|
|
progress = test262.ProgressIndicator(100)
|
|
|
|
progress.succeeded = 98
|
|
|
|
progress.failed = 2
|
|
|
|
|
|
|
|
result = mute(True)(test_suite.PrintSummary)(progress, None)
|
|
|
|
self.assertEqual("""
|
|
|
|
=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- Passed 98 tests (98.0%)
|
|
|
|
- Failed 2 tests (2.0%)
|
|
|
|
""", result)
|
|
|
|
|
|
|
|
def test_summary_logfile(self):
|
|
|
|
test_suite = test262.TestSuite(".",
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
None)
|
|
|
|
|
|
|
|
progress = test262.ProgressIndicator(100)
|
|
|
|
progress.succeeded = 98
|
|
|
|
progress.failed = 2
|
|
|
|
|
|
|
|
fake_log = cStringIO.StringIO()
|
|
|
|
test_suite.logf = fake_log
|
|
|
|
|
|
|
|
result = mute(True)(test_suite.PrintSummary)(progress, True)
|
|
|
|
|
|
|
|
expected_out = """
|
|
|
|
=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- Passed 98 tests (98.0%)
|
|
|
|
- Failed 2 tests (2.0%)
|
|
|
|
"""
|
|
|
|
|
|
|
|
expected_log = """=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- Passed 98 tests (98.0%)
|
|
|
|
- Failed 2 tests (2.0%)
|
|
|
|
"""
|
|
|
|
self.assertEqual(expected_out, result)
|
|
|
|
self.assertEqual(expected_log, fake_log.getvalue())
|
|
|
|
|
|
|
|
|
|
|
|
def test_summary_withfails(self):
|
|
|
|
test_suite = test262.TestSuite(".",
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
None)
|
|
|
|
|
|
|
|
progress = test262.ProgressIndicator(100)
|
|
|
|
progress.succeeded = 98
|
|
|
|
progress.failed = 2
|
|
|
|
progress.failed_tests = [
|
|
|
|
MockResult(MockTest("foo", False)),
|
|
|
|
MockResult(MockTest("bar", True))
|
|
|
|
]
|
|
|
|
|
|
|
|
result = mute(True)(test_suite.PrintSummary)(progress, None)
|
|
|
|
self.assertEqual("""
|
|
|
|
=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- Passed 98 tests (98.0%)
|
|
|
|
- Failed 2 tests (2.0%)
|
|
|
|
|
|
|
|
Failed Tests
|
|
|
|
foo in non-strict mode
|
|
|
|
|
|
|
|
Expected to fail but passed ---
|
|
|
|
bar in non-strict mode
|
|
|
|
""", result)
|
|
|
|
|
|
|
|
|
|
|
|
def test_summary_withfails_andlog(self):
|
|
|
|
test_suite = test262.TestSuite(".",
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
None)
|
|
|
|
|
|
|
|
progress = test262.ProgressIndicator(100)
|
|
|
|
progress.succeeded = 98
|
|
|
|
progress.failed = 2
|
|
|
|
progress.failed_tests = [
|
|
|
|
MockResult(MockTest("foo", False)),
|
|
|
|
MockResult(MockTest("bar", True))
|
|
|
|
]
|
|
|
|
|
|
|
|
fake_log = cStringIO.StringIO()
|
|
|
|
test_suite.logf = fake_log
|
|
|
|
|
|
|
|
expected_out = """
|
|
|
|
=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- Passed 98 tests (98.0%)
|
|
|
|
- Failed 2 tests (2.0%)
|
|
|
|
|
|
|
|
Failed Tests
|
|
|
|
foo in non-strict mode
|
|
|
|
|
|
|
|
Expected to fail but passed ---
|
|
|
|
bar in non-strict mode
|
|
|
|
"""
|
|
|
|
expected_log = """=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- Passed 98 tests (98.0%)
|
|
|
|
- Failed 2 tests (2.0%)
|
|
|
|
Failed Tests
|
|
|
|
foo in non-strict mode
|
|
|
|
Expected to fail but passed ---
|
|
|
|
bar in non-strict mode
|
|
|
|
"""
|
|
|
|
|
|
|
|
result = mute(True)(test_suite.PrintSummary)(progress, True)
|
|
|
|
self.assertEqual(expected_out, result)
|
|
|
|
self.assertEqual(expected_log, fake_log.getvalue())
|
|
|
|
|
|
|
|
|
|
|
|
def test_summary_success_logfile(self):
|
|
|
|
test_suite = test262.TestSuite(".",
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
False,
|
|
|
|
None)
|
|
|
|
|
|
|
|
progress = test262.ProgressIndicator(100)
|
|
|
|
progress.succeeded = 100
|
|
|
|
progress.failed = 0
|
|
|
|
|
|
|
|
fake_log = cStringIO.StringIO()
|
|
|
|
test_suite.logf = fake_log
|
|
|
|
|
|
|
|
result = mute(True)(test_suite.PrintSummary)(progress, True)
|
|
|
|
|
|
|
|
expected_out = """
|
|
|
|
=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- All tests succeeded
|
|
|
|
"""
|
|
|
|
|
|
|
|
expected_log = """=== Summary ===
|
|
|
|
- Ran 100 tests
|
|
|
|
- All tests succeeded
|
|
|
|
"""
|
|
|
|
self.assertEqual(expected_out, result)
|
|
|
|
self.assertEqual(expected_log, fake_log.getvalue())
|
|
|
|
|
|
|
|
|
|
|
|
def test_percent_format(self):
|
|
|
|
self.assertEqual(test262.PercentFormat(1, 100), "1 test (1.0%)")
|
|
|
|
self.assertEqual(test262.PercentFormat(0, 100), "0 tests (0.0%)")
|
|
|
|
self.assertEqual(test262.PercentFormat(99, 100), "99 tests (99.0%)")
|
|
|
|
|
|
|
|
|
|
|
|
# module level utility functions
|
|
|
|
# copied from https://stackoverflow.com/questions/2828953/silence-the-stdout-of-a-function-in-python-without-trashing-sys-stdout-and-resto
|
|
|
|
|
|
|
|
|
|
|
|
def mute(returns_output=False):
|
|
|
|
"""
|
|
|
|
Decorate a function that prints to stdout, intercepting the output.
|
|
|
|
If "returns_output" is True, the function will return a generator
|
|
|
|
yielding the printed lines instead of the return values.
|
|
|
|
|
|
|
|
The decorator litterally hijack sys.stdout during each function
|
|
|
|
execution for ALL THE THREADS, so be careful with what you apply it to
|
|
|
|
and in which context.
|
|
|
|
|
|
|
|
>>> def numbers():
|
|
|
|
print "42"
|
|
|
|
print "1984"
|
|
|
|
...
|
|
|
|
>>> numbers()
|
|
|
|
42
|
|
|
|
1984
|
|
|
|
>>> mute()(numbers)()
|
|
|
|
>>> list(mute(True)(numbers)())
|
|
|
|
['42', '1984']
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
def decorator(func):
|
|
|
|
|
|
|
|
@wraps(func)
|
|
|
|
def wrapper(*args, **kwargs):
|
|
|
|
|
|
|
|
saved_stdout = sys.stdout
|
|
|
|
sys.stdout = cStringIO.StringIO()
|
|
|
|
|
|
|
|
try:
|
|
|
|
out = func(*args, **kwargs)
|
|
|
|
if returns_output:
|
|
|
|
out = sys.stdout.getvalue()
|
|
|
|
finally:
|
|
|
|
sys.stdout = saved_stdout
|
|
|
|
|
|
|
|
return out
|
|
|
|
|
|
|
|
return wrapper
|
|
|
|
|
|
|
|
return decorator
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|
|
|
|
|