def wrap_test(test_name, test_method, *argv): sys.stdout.write(test_name + " ... ") try: test_method(*argv) print green_ok() except AssertionError: print red_failed() raise
def integration_tests(deno_exe, test_filter=None): assert os.path.isfile(deno_exe) tests = sorted([ filename for filename in os.listdir(tests_path) if filename.endswith(".test") ]) assert len(tests) > 0 for test_filename in tests: if test_filter and test_filter not in test_filename: continue 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(" ") check_stderr = str2bool(test.get("check_stderr", "false")) stderr = subprocess.STDOUT if check_stderr else open(os.devnull, 'w') output_abs = os.path.join(root_path, test.get("output", "")) with open(output_abs, 'r') as f: expected_out = f.read() cmd = [deno_exe] + args sys.stdout.write("tests/%s ... " % (test_filename)) sys.stdout.flush() actual_code = 0 try: actual_out = subprocess.check_output(cmd, universal_newlines=True, stderr=stderr) 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) actual_out = strip_ansi_codes(actual_out) if pattern_match(expected_out, actual_out) != True: print red_failed() print "Expected output does not match actual." print "Expected output: \n" + expected_out print "Actual output: \n" + actual_out sys.exit(1) print green_ok()
def integration_tests(deno_executable): assert os.path.isfile(deno_executable) tests = sorted([ filename for filename in os.listdir(tests_path) if filename.endswith(".test") ]) assert len(tests) > 0 for test_filename in tests: 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(" ") output_abs = os.path.join(root_path, test.get("output", "")) with open(output_abs, 'r') as f: expected_out = f.read() cmd = [deno_executable] + args print "test %s" % (test_filename) print " ".join(cmd) actual_code = 0 try: actual_out = subprocess.check_output(cmd, universal_newlines=True) 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) if pattern_match(expected_out, actual_out) != True: print "... " + red_failed() print "Expected output does not match actual." print "Expected output: \n" + expected_out print "Actual output: \n" + actual_out sys.exit(1) print "... " + green_ok()