2019-01-22 04:03:30 +09:00
|
|
|
# Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
2018-09-25 13:30:09 -07:00
|
|
|
from util import pattern_match, parse_exit_code, shell_quote_win
|
2018-10-11 16:56:50 -04:00
|
|
|
import util
|
|
|
|
import os
|
|
|
|
import sys
|
2018-08-10 10:38:32 -07:00
|
|
|
|
|
|
|
|
|
|
|
def pattern_match_test():
|
|
|
|
print "Testing util.pattern_match()..."
|
|
|
|
# yapf: disable
|
|
|
|
fixtures = [("foobarbaz", "foobarbaz", True),
|
|
|
|
("[WILDCARD]", "foobarbaz", True),
|
|
|
|
("foobar", "foobarbaz", False),
|
|
|
|
("foo[WILDCARD]baz", "foobarbaz", True),
|
|
|
|
("foo[WILDCARD]baz", "foobazbar", False),
|
|
|
|
("foo[WILDCARD]baz[WILDCARD]qux", "foobarbazqatqux", True),
|
|
|
|
("foo[WILDCARD]", "foobar", True),
|
|
|
|
("foo[WILDCARD]baz[WILDCARD]", "foobarbazqat", True)]
|
|
|
|
# yapf: enable
|
|
|
|
|
|
|
|
# Iterate through the fixture lists, testing each one
|
|
|
|
for (pattern, string, expected) in fixtures:
|
|
|
|
actual = pattern_match(pattern, string)
|
2018-11-30 03:27:41 -05:00
|
|
|
assert expected == actual, \
|
|
|
|
"expected %s for\nExpected:\n%s\nTo equal actual:\n%s" % (
|
2018-08-10 10:38:32 -07:00
|
|
|
expected, pattern, string)
|
|
|
|
|
|
|
|
assert pattern_match("foo[BAR]baz", "foobarbaz",
|
|
|
|
"[BAR]") == True, "expected wildcard to be set"
|
|
|
|
assert pattern_match("foo[BAR]baz", "foobazbar",
|
|
|
|
"[BAR]") == False, "expected wildcard to be set"
|
|
|
|
|
|
|
|
|
2018-08-19 03:00:34 -04:00
|
|
|
def parse_exit_code_test():
|
|
|
|
print "Testing util.parse_exit_code()..."
|
|
|
|
assert 54 == parse_exit_code('hello_error54_world')
|
|
|
|
assert 1 == parse_exit_code('hello_error_world')
|
|
|
|
assert 0 == parse_exit_code('hello_world')
|
|
|
|
|
|
|
|
|
2018-09-25 13:30:09 -07:00
|
|
|
def shell_quote_win_test():
|
|
|
|
print "Testing util.shell_quote_win()..."
|
|
|
|
assert 'simple' == shell_quote_win('simple')
|
|
|
|
assert 'roof/\\isoprojection' == shell_quote_win('roof/\\isoprojection')
|
|
|
|
assert '"with space"' == shell_quote_win('with space')
|
|
|
|
assert '"embedded""quote"' == shell_quote_win('embedded"quote')
|
|
|
|
assert '"a""b""""c\\d\\\\""e\\\\\\\\"' == shell_quote_win(
|
|
|
|
'a"b""c\\d\\"e\\\\')
|
|
|
|
|
|
|
|
|
2018-10-11 16:56:50 -04:00
|
|
|
def parse_unit_test_output_test():
|
|
|
|
print "Testing util.parse_unit_test_output()..."
|
|
|
|
# This is an example of a successful unit test output.
|
|
|
|
output = open(
|
|
|
|
os.path.join(util.root_path, "tools/testdata/unit_test_output1.txt"))
|
|
|
|
(actual, expected) = util.parse_unit_test_output(output, False)
|
|
|
|
assert actual == 96
|
|
|
|
assert expected == 96
|
|
|
|
|
|
|
|
# This is an example of a silently dying unit test.
|
|
|
|
output = open(
|
|
|
|
os.path.join(util.root_path, "tools/testdata/unit_test_output2.txt"))
|
|
|
|
(actual, expected) = util.parse_unit_test_output(output, False)
|
|
|
|
assert actual == None
|
|
|
|
assert expected == 96
|
|
|
|
|
|
|
|
# This is an example of compiling before successful unit tests.
|
|
|
|
output = open(
|
|
|
|
os.path.join(util.root_path, "tools/testdata/unit_test_output3.txt"))
|
|
|
|
(actual, expected) = util.parse_unit_test_output(output, False)
|
|
|
|
assert actual == 96
|
|
|
|
assert expected == 96
|
|
|
|
|
|
|
|
# Check what happens on empty output.
|
|
|
|
from StringIO import StringIO
|
|
|
|
output = StringIO("\n\n\n")
|
|
|
|
(actual, expected) = util.parse_unit_test_output(output, False)
|
|
|
|
assert actual == None
|
|
|
|
assert expected == None
|
|
|
|
|
|
|
|
|
2018-10-15 16:44:35 -04:00
|
|
|
def parse_wrk_output_test():
|
|
|
|
print "Testing util.parse_wrk_output_test()..."
|
|
|
|
f = open(os.path.join(util.root_path, "tools/testdata/wrk1.txt"))
|
2019-03-24 23:36:27 -04:00
|
|
|
stats = util.parse_wrk_output(f.read())
|
|
|
|
assert stats['req_per_sec'] == 1837
|
|
|
|
assert stats['max_latency'] == 34.96
|
|
|
|
|
|
|
|
f2 = open(os.path.join(util.root_path, "tools/testdata/wrk2.txt"))
|
|
|
|
stats2 = util.parse_wrk_output(f2.read())
|
|
|
|
assert stats2['req_per_sec'] == 53435
|
|
|
|
assert stats2['max_latency'] == 0.00125
|
|
|
|
|
|
|
|
f3 = open(os.path.join(util.root_path, "tools/testdata/wrk3.txt"))
|
|
|
|
stats3 = util.parse_wrk_output(f3.read())
|
|
|
|
assert stats3['req_per_sec'] == 96037
|
|
|
|
assert stats3['max_latency'] == 1630.0
|
2018-10-15 16:44:35 -04:00
|
|
|
|
|
|
|
|
2018-08-10 10:38:32 -07:00
|
|
|
def util_test():
|
|
|
|
pattern_match_test()
|
2018-08-19 03:00:34 -04:00
|
|
|
parse_exit_code_test()
|
2018-09-25 13:30:09 -07:00
|
|
|
shell_quote_win_test()
|
2018-10-11 16:56:50 -04:00
|
|
|
parse_unit_test_output_test()
|
2018-10-15 16:44:35 -04:00
|
|
|
parse_wrk_output_test()
|
2018-08-19 03:00:34 -04:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
util_test()
|