2018-11-05 06:52:31 +11:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
2019-01-22 04:03:30 +09:00
|
|
|
# Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
2018-11-05 06:52:31 +11:00
|
|
|
# Given a deno executable, this script executes several integration tests with
|
|
|
|
# it. The tests are stored in /tests/ and each is specified in a .yaml file
|
|
|
|
# where a description, command line, and output are specified. Optionally an
|
|
|
|
# exit code can be specified.
|
|
|
|
#
|
|
|
|
# Usage: integration_tests.py [path to deno executable]
|
|
|
|
import os
|
|
|
|
import re
|
|
|
|
import sys
|
|
|
|
import subprocess
|
2019-02-07 23:11:03 +03:00
|
|
|
import http_server
|
|
|
|
import argparse
|
|
|
|
from util import root_path, tests_path, pattern_match, \
|
|
|
|
green_ok, red_failed, rmtree, executable_suffix
|
2018-11-05 06:52:31 +11:00
|
|
|
|
2019-02-07 20:07:20 -05:00
|
|
|
|
|
|
|
def strip_ansi_codes(s):
|
|
|
|
ansi_escape = re.compile(r'\x1B\[[0-?]*[ -/]*[@-~]')
|
|
|
|
return ansi_escape.sub('', s)
|
|
|
|
|
|
|
|
|
2018-11-05 06:52:31 +11:00
|
|
|
def read_test(file_name):
|
|
|
|
with open(file_name, "r") as f:
|
|
|
|
test_file = f.read()
|
|
|
|
lines = test_file.splitlines()
|
|
|
|
test_dict = {}
|
|
|
|
for line in lines:
|
2019-02-01 22:28:31 -08:00
|
|
|
if line.strip().startswith("#"):
|
|
|
|
# skip comments
|
|
|
|
continue
|
2018-11-05 06:52:31 +11:00
|
|
|
key, value = re.split(r":\s+", line)
|
|
|
|
test_dict[key] = value
|
|
|
|
return test_dict
|
|
|
|
|
|
|
|
|
2018-12-10 17:50:41 -05:00
|
|
|
def str2bool(v):
|
|
|
|
if v == "true":
|
|
|
|
return True
|
|
|
|
elif v == "false":
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
raise ValueError("Bad boolean value")
|
|
|
|
|
|
|
|
|
2019-02-12 02:57:26 +09:00
|
|
|
def integration_tests(deno_exe, test_filter=None):
|
2019-02-02 01:58:27 -05:00
|
|
|
assert os.path.isfile(deno_exe)
|
2018-11-05 06:52:31 +11:00
|
|
|
tests = sorted([
|
|
|
|
filename for filename in os.listdir(tests_path)
|
|
|
|
if filename.endswith(".test")
|
|
|
|
])
|
|
|
|
assert len(tests) > 0
|
|
|
|
for test_filename in tests:
|
2019-02-02 01:58:27 -05:00
|
|
|
if test_filter and test_filter not in test_filename:
|
|
|
|
continue
|
|
|
|
|
2018-11-05 06:52:31 +11:00
|
|
|
test_abs = os.path.join(tests_path, test_filename)
|
|
|
|
test = read_test(test_abs)
|
|
|
|
exit_code = int(test.get("exit_code", 0))
|
|
|
|
args = test.get("args", "").split(" ")
|
2018-12-10 17:50:41 -05:00
|
|
|
|
|
|
|
check_stderr = str2bool(test.get("check_stderr", "false"))
|
2019-02-07 20:07:20 -05:00
|
|
|
|
|
|
|
stderr = subprocess.STDOUT if check_stderr else open(os.devnull, 'w')
|
2018-12-10 17:50:41 -05:00
|
|
|
|
2018-11-05 06:52:31 +11:00
|
|
|
output_abs = os.path.join(root_path, test.get("output", ""))
|
|
|
|
with open(output_abs, 'r') as f:
|
|
|
|
expected_out = f.read()
|
2019-02-02 01:58:27 -05:00
|
|
|
cmd = [deno_exe] + args
|
2019-02-07 20:07:20 -05:00
|
|
|
sys.stdout.write("tests/%s ... " % (test_filename))
|
|
|
|
sys.stdout.flush()
|
2018-11-05 06:52:31 +11:00
|
|
|
actual_code = 0
|
|
|
|
try:
|
2018-12-10 17:50:41 -05:00
|
|
|
actual_out = subprocess.check_output(
|
|
|
|
cmd, universal_newlines=True, stderr=stderr)
|
2018-11-05 06:52:31 +11:00
|
|
|
except subprocess.CalledProcessError as e:
|
|
|
|
actual_code = e.returncode
|
|
|
|
actual_out = e.output
|
|
|
|
|
|
|
|
if exit_code != actual_code:
|
|
|
|
print "... " + red_failed()
|
|
|
|
print "Expected exit code %d but got %d" % (exit_code, actual_code)
|
|
|
|
print "Output:"
|
|
|
|
print actual_out
|
|
|
|
sys.exit(1)
|
|
|
|
|
2019-02-07 20:07:20 -05:00
|
|
|
actual_out = strip_ansi_codes(actual_out)
|
|
|
|
|
2018-11-05 06:52:31 +11:00
|
|
|
if pattern_match(expected_out, actual_out) != True:
|
2019-02-07 20:07:20 -05:00
|
|
|
print red_failed()
|
2018-11-05 06:52:31 +11:00
|
|
|
print "Expected output does not match actual."
|
|
|
|
print "Expected output: \n" + expected_out
|
|
|
|
print "Actual output: \n" + actual_out
|
|
|
|
sys.exit(1)
|
|
|
|
|
2019-02-07 20:07:20 -05:00
|
|
|
print green_ok()
|
2018-11-05 06:52:31 +11:00
|
|
|
|
2019-02-12 02:57:26 +09:00
|
|
|
|
2019-02-07 23:11:03 +03:00
|
|
|
def main():
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument("--filter", help="Run specific tests")
|
2019-02-12 02:57:26 +09:00
|
|
|
parser.add_argument(
|
|
|
|
"--release", help="Use release build of Deno", action="store_true")
|
2019-02-07 23:11:03 +03:00
|
|
|
parser.add_argument("--executable", help="Use external executable of Deno")
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
target = "release" if args.release else "debug"
|
|
|
|
|
|
|
|
build_dir = None
|
|
|
|
if "DENO_BUILD_PATH" in os.environ:
|
|
|
|
build_dir = os.environ["DENO_BUILD_PATH"]
|
|
|
|
else:
|
|
|
|
build_dir = os.path.join(root_path, "target", target)
|
|
|
|
|
|
|
|
deno_dir = os.path.join(build_dir, ".deno_test")
|
|
|
|
if os.path.isdir(deno_dir):
|
|
|
|
rmtree(deno_dir)
|
|
|
|
os.environ["DENO_DIR"] = deno_dir
|
|
|
|
|
|
|
|
deno_exe = os.path.join(build_dir, "deno" + executable_suffix)
|
|
|
|
if args.executable:
|
|
|
|
deno_exe = args.executable
|
|
|
|
|
|
|
|
http_server.spawn()
|
|
|
|
|
|
|
|
integration_tests(deno_exe, args.filter)
|
2018-11-05 06:52:31 +11:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2019-02-07 23:11:03 +03:00
|
|
|
sys.exit(main())
|