summaryrefslogtreecommitdiff
path: root/cli/tests
diff options
context:
space:
mode:
Diffstat (limited to 'cli/tests')
-rw-r--r--cli/tests/006_url_imports.ts2
-rw-r--r--cli/tests/019_media_types.ts16
-rw-r--r--cli/tests/022_info_flag_script.out18
-rw-r--r--cli/tests/035_no_fetch_flag.out2
-rw-r--r--cli/tests/README.md4
-rw-r--r--cli/tests/integration_tests.rs426
-rw-r--r--cli/tests/tty_tests.rs18
-rw-r--r--cli/tests/util/mod.rs218
8 files changed, 416 insertions, 288 deletions
diff --git a/cli/tests/006_url_imports.ts b/cli/tests/006_url_imports.ts
index b2c7db270..109cb603e 100644
--- a/cli/tests/006_url_imports.ts
+++ b/cli/tests/006_url_imports.ts
@@ -1,3 +1,3 @@
-import { printHello } from "http://localhost:4545/tests/subdir/mod2.ts";
+import { printHello } from "http://localhost:4545/cli/tests/subdir/mod2.ts";
printHello();
console.log("success");
diff --git a/cli/tests/019_media_types.ts b/cli/tests/019_media_types.ts
index 5f1f862a0..cc99be83b 100644
--- a/cli/tests/019_media_types.ts
+++ b/cli/tests/019_media_types.ts
@@ -2,14 +2,14 @@
// based on the URL containing `.t#.` strings, which exercises the different
// mapping of media types end to end.
-import { loaded as loadedTs1 } from "http://localhost:4545/tests/subdir/mt_text_typescript.t1.ts";
-import { loaded as loadedTs2 } from "http://localhost:4545/tests/subdir/mt_video_vdn.t2.ts";
-import { loaded as loadedTs3 } from "http://localhost:4545/tests/subdir/mt_video_mp2t.t3.ts";
-import { loaded as loadedTs4 } from "http://localhost:4545/tests/subdir/mt_application_x_typescript.t4.ts";
-import { loaded as loadedJs1 } from "http://localhost:4545/tests/subdir/mt_text_javascript.j1.js";
-import { loaded as loadedJs2 } from "http://localhost:4545/tests/subdir/mt_application_ecmascript.j2.js";
-import { loaded as loadedJs3 } from "http://localhost:4545/tests/subdir/mt_text_ecmascript.j3.js";
-import { loaded as loadedJs4 } from "http://localhost:4545/tests/subdir/mt_application_x_javascript.j4.js";
+import { loaded as loadedTs1 } from "http://localhost:4545/cli/tests/subdir/mt_text_typescript.t1.ts";
+import { loaded as loadedTs2 } from "http://localhost:4545/cli/tests/subdir/mt_video_vdn.t2.ts";
+import { loaded as loadedTs3 } from "http://localhost:4545/cli/tests/subdir/mt_video_mp2t.t3.ts";
+import { loaded as loadedTs4 } from "http://localhost:4545/cli/tests/subdir/mt_application_x_typescript.t4.ts";
+import { loaded as loadedJs1 } from "http://localhost:4545/cli/tests/subdir/mt_text_javascript.j1.js";
+import { loaded as loadedJs2 } from "http://localhost:4545/cli/tests/subdir/mt_application_ecmascript.j2.js";
+import { loaded as loadedJs3 } from "http://localhost:4545/cli/tests/subdir/mt_text_ecmascript.j3.js";
+import { loaded as loadedJs4 } from "http://localhost:4545/cli/tests/subdir/mt_application_x_javascript.j4.js";
console.log(
"success",
diff --git a/cli/tests/022_info_flag_script.out b/cli/tests/022_info_flag_script.out
index 519e7cf6b..48eef7365 100644
--- a/cli/tests/022_info_flag_script.out
+++ b/cli/tests/022_info_flag_script.out
@@ -3,12 +3,12 @@ type: TypeScript
compiled: [WILDCARD].js
map: [WILDCARD].js.map
deps:
-http://127.0.0.1:4545/tests/019_media_types.ts
- ├── http://localhost:4545/tests/subdir/mt_text_typescript.t1.ts
- ├── http://localhost:4545/tests/subdir/mt_video_vdn.t2.ts
- ├── http://localhost:4545/tests/subdir/mt_video_mp2t.t3.ts
- ├── http://localhost:4545/tests/subdir/mt_application_x_typescript.t4.ts
- ├── http://localhost:4545/tests/subdir/mt_text_javascript.j1.js
- ├── http://localhost:4545/tests/subdir/mt_application_ecmascript.j2.js
- ├── http://localhost:4545/tests/subdir/mt_text_ecmascript.j3.js
- └── http://localhost:4545/tests/subdir/mt_application_x_javascript.j4.js
+http://127.0.0.1:4545/cli/tests/019_media_types.ts
+ ├── http://localhost:4545/cli/tests/subdir/mt_text_typescript.t1.ts
+ ├── http://localhost:4545/cli/tests/subdir/mt_video_vdn.t2.ts
+ ├── http://localhost:4545/cli/tests/subdir/mt_video_mp2t.t3.ts
+ ├── http://localhost:4545/cli/tests/subdir/mt_application_x_typescript.t4.ts
+ ├── http://localhost:4545/cli/tests/subdir/mt_text_javascript.j1.js
+ ├── http://localhost:4545/cli/tests/subdir/mt_application_ecmascript.j2.js
+ ├── http://localhost:4545/cli/tests/subdir/mt_text_ecmascript.j3.js
+ └── http://localhost:4545/cli/tests/subdir/mt_application_x_javascript.j4.js
diff --git a/cli/tests/035_no_fetch_flag.out b/cli/tests/035_no_fetch_flag.out
index 0c835830c..26f020aa5 100644
--- a/cli/tests/035_no_fetch_flag.out
+++ b/cli/tests/035_no_fetch_flag.out
@@ -1 +1 @@
-Cannot resolve module "http://127.0.0.1:4545/tests/019_media_types.ts"
+Cannot resolve module "http://127.0.0.1:4545/cli/tests/019_media_types.ts"
diff --git a/cli/tests/README.md b/cli/tests/README.md
index dc199196d..fe9071926 100644
--- a/cli/tests/README.md
+++ b/cli/tests/README.md
@@ -3,5 +3,5 @@
This path contains integration tests. See integration_tests.rs for the index.
TODO(ry) Currently //tests is a symlink to //cli/tests, to simplify transition.
-In the future //tests should be removed when all references to //tests are
-updated.
+In the future the symlink should be removed when all the many references have
+been updated to the new path.
diff --git a/cli/tests/integration_tests.rs b/cli/tests/integration_tests.rs
index 86de4fa6a..b9946e1f9 100644
--- a/cli/tests/integration_tests.rs
+++ b/cli/tests/integration_tests.rs
@@ -1,21 +1,82 @@
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
#[macro_use]
-extern crate log;
+extern crate lazy_static;
+extern crate tempfile;
+mod util;
+use util::*;
-use deno_cli::colors::strip_ansi_codes;
-use os_pipe::pipe;
-use std::env;
-use std::io::Read;
-use std::io::Write;
-use std::path::PathBuf;
-use std::process::Command;
-use std::process::Stdio;
+#[test]
+fn benchmark_test() {
+ run_python_script("tools/benchmark_test.py")
+}
+
+#[test]
+fn deno_dir_test() {
+ let g = http_server();
+ run_python_script("tools/deno_dir_test.py");
+ drop(g);
+}
+
+// TODO(#2933): Rewrite this test in rust.
+#[test]
+fn fetch_test() {
+ let g = http_server();
+ run_python_script("tools/fetch_test.py");
+ drop(g);
+}
+
+// TODO(#2933): Rewrite this test in rust.
+#[test]
+fn fmt_test() {
+ let g = http_server();
+ run_python_script("tools/fmt_test.py");
+ drop(g);
+}
+
+#[test]
+fn js_unit_tests() {
+ let g = http_server();
+ let mut deno = deno_cmd()
+ .current_dir(root_path())
+ .arg("run")
+ .arg("--reload")
+ .arg("--allow-run")
+ .arg("--allow-env")
+ .arg("js/unit_test_runner.ts")
+ .spawn()
+ .expect("failed to spawn script");
+ let status = deno.wait().expect("failed to wait for the child process");
+ assert_eq!(Some(0), status.code());
+ assert!(status.success());
+ drop(g);
+}
+
+// TODO(#2933): Rewrite this test in rust.
+#[test]
+fn repl_test() {
+ run_python_script("tools/repl_test.py")
+}
+
+#[test]
+fn setup_test() {
+ run_python_script("tools/setup_test.py")
+}
+
+#[test]
+fn target_test() {
+ run_python_script("tools/target_test.py")
+}
+
+#[test]
+fn util_test() {
+ run_python_script("tools/util_test.py")
+}
macro_rules! itest(
($name:ident {$( $key:ident: $value:expr,)*}) => {
#[test]
fn $name() {
- (IntegrationTest {
+ (CheckOutputIntegrationTest {
$(
$key: $value,
)*
@@ -27,180 +88,187 @@ macro_rules! itest(
itest!(_001_hello {
args: "run --reload 001_hello.js",
- output: "tests/001_hello.js.out",
+ output: "001_hello.js.out",
});
itest!(_002_hello {
args: "run --reload 002_hello.ts",
- output: "tests/002_hello.ts.out",
+ output: "002_hello.ts.out",
});
itest!(_003_relative_import {
args: "run --reload 003_relative_import.ts",
- output: "tests/003_relative_import.ts.out",
+ output: "003_relative_import.ts.out",
});
itest!(_004_set_timeout {
args: "run --reload 004_set_timeout.ts",
- output: "tests/004_set_timeout.ts.out",
+ output: "004_set_timeout.ts.out",
});
itest!(_005_more_imports {
args: "run --reload 005_more_imports.ts",
- output: "tests/005_more_imports.ts.out",
+ output: "005_more_imports.ts.out",
});
itest!(_006_url_imports {
args: "run --reload 006_url_imports.ts",
- output: "tests/006_url_imports.ts.out",
+ output: "006_url_imports.ts.out",
+ http_server: true,
});
itest!(_012_async {
args: "run --reload 012_async.ts",
- output: "tests/012_async.ts.out",
+ output: "012_async.ts.out",
});
itest!(_013_dynamic_import {
args: "013_dynamic_import.ts --reload --allow-read",
- output: "tests/013_dynamic_import.ts.out",
+ output: "013_dynamic_import.ts.out",
});
itest!(_014_duplicate_import {
args: "014_duplicate_import.ts --reload --allow-read",
- output: "tests/014_duplicate_import.ts.out",
+ output: "014_duplicate_import.ts.out",
});
itest!(_015_duplicate_parallel_import {
args: "015_duplicate_parallel_import.js --reload --allow-read",
- output: "tests/015_duplicate_parallel_import.js.out",
+ output: "015_duplicate_parallel_import.js.out",
});
itest!(_016_double_await {
args: "run --allow-read --reload 016_double_await.ts",
- output: "tests/016_double_await.ts.out",
+ output: "016_double_await.ts.out",
});
itest!(_017_import_redirect {
args: "run --reload 017_import_redirect.ts",
- output: "tests/017_import_redirect.ts.out",
+ output: "017_import_redirect.ts.out",
});
itest!(_018_async_catch {
args: "run --reload 018_async_catch.ts",
- output: "tests/018_async_catch.ts.out",
+ output: "018_async_catch.ts.out",
});
itest!(_019_media_types {
args: "run --reload 019_media_types.ts",
- output: "tests/019_media_types.ts.out",
+ output: "019_media_types.ts.out",
+ http_server: true,
});
itest!(_020_json_modules {
args: "run --reload 020_json_modules.ts",
- output: "tests/020_json_modules.ts.out",
+ output: "020_json_modules.ts.out",
});
itest!(_021_mjs_modules {
args: "run --reload 021_mjs_modules.ts",
- output: "tests/021_mjs_modules.ts.out",
+ output: "021_mjs_modules.ts.out",
});
itest!(_022_info_flag_script {
- args: "info http://127.0.0.1:4545/tests/019_media_types.ts",
- output: "tests/022_info_flag_script.out",
+ args: "info http://127.0.0.1:4545/cli/tests/019_media_types.ts",
+ output: "022_info_flag_script.out",
+ http_server: true,
});
itest!(_023_no_ext_with_headers {
args: "run --reload 023_no_ext_with_headers",
- output: "tests/023_no_ext_with_headers.out",
+ output: "023_no_ext_with_headers.out",
});
// FIXME(bartlomieju): this test should use remote file
// itest!(_024_import_no_ext_with_headers {
// args: "run --reload 024_import_no_ext_with_headers.ts",
-// output: "tests/024_import_no_ext_with_headers.ts.out",
+// output: "024_import_no_ext_with_headers.ts.out",
// });
itest!(_025_hrtime {
args: "run --allow-hrtime --reload 025_hrtime.ts",
- output: "tests/025_hrtime.ts.out",
+ output: "025_hrtime.ts.out",
});
itest!(_025_reload_js_type_error {
args: "run --reload 025_reload_js_type_error.js",
- output: "tests/025_reload_js_type_error.js.out",
+ output: "025_reload_js_type_error.js.out",
});
itest!(_026_redirect_javascript {
args: "run --reload 026_redirect_javascript.js",
- output: "tests/026_redirect_javascript.js.out",
+ output: "026_redirect_javascript.js.out",
+ http_server: true,
});
itest!(_026_workers {
args: "run --reload 026_workers.ts",
- output: "tests/026_workers.ts.out",
+ output: "026_workers.ts.out",
});
itest!(_027_redirect_typescript {
args: "run --reload 027_redirect_typescript.ts",
- output: "tests/027_redirect_typescript.ts.out",
+ output: "027_redirect_typescript.ts.out",
+ http_server: true,
});
itest!(_028_args {
args: "run --reload 028_args.ts --arg1 val1 --arg2=val2 -- arg3 arg4",
- output: "tests/028_args.ts.out",
+ output: "028_args.ts.out",
});
itest!(_029_eval {
args: "eval console.log(\"hello\")",
- output: "tests/029_eval.out",
+ output: "029_eval.out",
});
itest!(_030_xeval {
args: "xeval console.log($.toUpperCase())",
input: Some("a\nb\n\nc"),
- output: "tests/030_xeval.out",
+ output: "030_xeval.out",
});
itest!(_031_xeval_replvar {
args: "xeval -I val console.log(val.toUpperCase());",
input: Some("a\nb\n\nc"),
- output: "tests/031_xeval_replvar.out",
+ output: "031_xeval_replvar.out",
});
itest!(_032_xeval_delim {
args: "xeval -d DELIM console.log($.toUpperCase());",
input: Some("aDELIMbDELIMDELIMc"),
- output: "tests/032_xeval_delim.out",
+ output: "032_xeval_delim.out",
});
itest!(_033_import_map {
args:
"run --reload --importmap=importmaps/import_map.json importmaps/test.ts",
- output: "tests/033_import_map.out",
+ output: "033_import_map.out",
});
itest!(_034_onload {
args: "run --reload 034_onload/main.ts",
- output: "tests/034_onload.out",
+ output: "034_onload.out",
});
itest!(_035_no_fetch_flag {
- args: "--reload --no-fetch http://127.0.0.1:4545/tests/019_media_types.ts",
- output: "tests/035_no_fetch_flag.out",
+ args:
+ "--reload --no-fetch http://127.0.0.1:4545/cli/tests/019_media_types.ts",
+ output: "035_no_fetch_flag.out",
exit_code: 1,
check_stderr: true,
+ http_server: true,
});
itest!(_036_import_map_fetch {
args:
"fetch --reload --importmap=importmaps/import_map.json importmaps/test.ts",
- output: "tests/036_import_map_fetch.out",
+ output: "036_import_map_fetch.out",
});
itest!(_037_current_thread {
args: "run --current-thread --reload 034_onload/main.ts",
- output: "tests/034_onload.out",
+ output: "034_onload.out",
});
itest!(_038_checkjs {
@@ -208,72 +276,72 @@ itest!(_038_checkjs {
args: "run --reload --config 038_checkjs.tsconfig.json 038_checkjs.js",
check_stderr: true,
exit_code: 1,
- output: "tests/038_checkjs.js.out",
+ output: "038_checkjs.js.out",
});
itest!(_039_worker_deno_ns {
args: "run --reload 039_worker_deno_ns.ts",
- output: "tests/039_worker_deno_ns.ts.out",
+ output: "039_worker_deno_ns.ts.out",
});
itest!(_040_worker_blob {
args: "run --reload 040_worker_blob.ts",
- output: "tests/040_worker_blob.ts.out",
+ output: "040_worker_blob.ts.out",
});
itest!(_041_dyn_import_eval {
args: "eval import('./subdir/mod4.js').then(console.log)",
- output: "tests/041_dyn_import_eval.out",
+ output: "041_dyn_import_eval.out",
});
itest!(_041_info_flag {
args: "info",
- output: "tests/041_info_flag.out",
+ output: "041_info_flag.out",
});
itest!(_042_dyn_import_evalcontext {
args: "run --allow-read --reload 042_dyn_import_evalcontext.ts",
- output: "tests/042_dyn_import_evalcontext.ts.out",
+ output: "042_dyn_import_evalcontext.ts.out",
});
itest!(async_error {
exit_code: 1,
args: "run --reload async_error.ts",
check_stderr: true,
- output: "tests/async_error.ts.out",
+ output: "async_error.ts.out",
});
itest!(circular1 {
args: "run --reload circular1.js",
- output: "tests/circular1.js.out",
+ output: "circular1.js.out",
});
itest!(config {
args: "run --reload --config config.tsconfig.json config.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/config.ts.out",
+ output: "config.ts.out",
});
itest!(error_001 {
args: "run --reload error_001.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_001.ts.out",
+ output: "error_001.ts.out",
});
itest!(error_002 {
args: "run --reload error_002.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_002.ts.out",
+ output: "error_002.ts.out",
});
itest!(error_003_typescript {
args: "run --reload error_003_typescript.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_003_typescript.ts.out",
+ output: "error_003_typescript.ts.out",
});
// Supposing that we've already attempted to run error_003_typescript.ts
@@ -284,363 +352,187 @@ itest!(error_003_typescript2 {
args: "run error_003_typescript.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_003_typescript.ts.out",
+ output: "error_003_typescript.ts.out",
});
itest!(error_004_missing_module {
args: "run --reload error_004_missing_module.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_004_missing_module.ts.out",
+ output: "error_004_missing_module.ts.out",
});
itest!(error_005_missing_dynamic_import {
args: "run --reload error_005_missing_dynamic_import.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_005_missing_dynamic_import.ts.out",
+ output: "error_005_missing_dynamic_import.ts.out",
});
itest!(error_006_import_ext_failure {
args: "run --reload error_006_import_ext_failure.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_006_import_ext_failure.ts.out",
+ output: "error_006_import_ext_failure.ts.out",
});
itest!(error_007_any {
args: "run --reload error_007_any.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_007_any.ts.out",
+ output: "error_007_any.ts.out",
});
itest!(error_008_checkjs {
args: "run --reload error_008_checkjs.js",
check_stderr: true,
exit_code: 1,
- output: "tests/error_008_checkjs.js.out",
+ output: "error_008_checkjs.js.out",
});
itest!(error_011_bad_module_specifier {
args: "run --reload error_011_bad_module_specifier.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_011_bad_module_specifier.ts.out",
+ output: "error_011_bad_module_specifier.ts.out",
});
itest!(error_012_bad_dynamic_import_specifier {
args: "run --reload error_012_bad_dynamic_import_specifier.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_012_bad_dynamic_import_specifier.ts.out",
+ output: "error_012_bad_dynamic_import_specifier.ts.out",
});
itest!(error_013_missing_script {
args: "run --reload missing_file_name",
check_stderr: true,
exit_code: 1,
- output: "tests/error_013_missing_script.out",
+ output: "error_013_missing_script.out",
});
itest!(error_014_catch_dynamic_import_error {
args: "error_014_catch_dynamic_import_error.js --reload --allow-read",
- output: "tests/error_014_catch_dynamic_import_error.js.out",
+ output: "error_014_catch_dynamic_import_error.js.out",
});
itest!(error_015_dynamic_import_permissions {
args: "--reload --no-prompt error_015_dynamic_import_permissions.js",
- output: "tests/error_015_dynamic_import_permissions.out",
+ output: "error_015_dynamic_import_permissions.out",
check_stderr: true,
exit_code: 1,
+ http_server: true,
});
// We have an allow-net flag but not allow-read, it should still result in error.
itest!(error_016_dynamic_import_permissions2 {
args:
"--no-prompt --reload --allow-net error_016_dynamic_import_permissions2.js",
- output: "tests/error_016_dynamic_import_permissions2.out",
+ output: "error_016_dynamic_import_permissions2.out",
check_stderr: true,
exit_code: 1,
+ http_server: true,
});
itest!(error_stack {
args: "run --reload error_stack.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_stack.ts.out",
+ output: "error_stack.ts.out",
});
itest!(error_syntax {
args: "run --reload error_syntax.js",
check_stderr: true,
exit_code: 1,
- output: "tests/error_syntax.js.out",
+ output: "error_syntax.js.out",
});
itest!(error_type_definitions {
args: "run --reload error_type_definitions.ts",
check_stderr: true,
exit_code: 1,
- output: "tests/error_type_definitions.ts.out",
+ output: "error_type_definitions.ts.out",
});
itest!(exit_error42 {
exit_code: 42,
args: "run --reload exit_error42.ts",
- output: "tests/exit_error42.ts.out",
+ output: "exit_error42.ts.out",
});
itest!(https_import {
args: "run --reload https_import.ts",
- output: "tests/https_import.ts.out",
+ output: "https_import.ts.out",
});
itest!(if_main {
args: "run --reload if_main.ts",
- output: "tests/if_main.ts.out",
+ output: "if_main.ts.out",
});
itest!(import_meta {
args: "run --reload import_meta.ts",
- output: "tests/import_meta.ts.out",
+ output: "import_meta.ts.out",
});
itest!(seed_random {
args: "run --seed=100 seed_random.js",
- output: "tests/seed_random.js.out",
+ output: "seed_random.js.out",
});
itest!(type_definitions {
args: "run --reload type_definitions.ts",
- output: "tests/type_definitions.ts.out",
+ output: "type_definitions.ts.out",
});
itest!(types {
args: "types",
- output: "tests/types.out",
+ output: "types.out",
});
itest!(unbuffered_stderr {
args: "run --reload unbuffered_stderr.ts",
check_stderr: true,
- output: "tests/unbuffered_stderr.ts.out",
+ output: "unbuffered_stderr.ts.out",
});
itest!(unbuffered_stdout {
args: "run --reload unbuffered_stdout.ts",
- output: "tests/unbuffered_stdout.ts.out",
+ output: "unbuffered_stdout.ts.out",
});
itest!(v8_flags {
args: "run --v8-flags=--expose-gc v8_flags.js",
- output: "tests/v8_flags.js.out",
+ output: "v8_flags.js.out",
});
itest!(v8_help {
args: "--v8-options",
- output: "tests/v8_help.out",
+ output: "v8_help.out",
});
itest!(version {
args: "version",
- output: "tests/version.out",
+ output: "version.out",
});
itest!(version_long_flag {
args: "--version",
- output: "tests/version.out",
+ output: "version.out",
});
itest!(version_short_flag {
args: "-v",
- output: "tests/version.out",
+ output: "version.out",
});
itest!(wasm {
args: "run wasm.ts",
- output: "tests/wasm.ts.out",
+ output: "wasm.ts.out",
});
itest!(wasm_async {
args: "wasm_async.js",
- output: "tests/wasm_async.out",
+ output: "wasm_async.out",
});
-
-///////////////////////////
-
-#[derive(Debug, Default)]
-struct IntegrationTest {
- args: &'static str,
- output: &'static str,
- input: Option<&'static str>,
- exit_code: i32,
- check_stderr: bool,
-}
-
-impl IntegrationTest {
- pub fn run(&self) {
- let args = self.args.split_whitespace();
- let root = PathBuf::from(concat!(env!("CARGO_MANIFEST_DIR"), "/.."));
- let mut target = "debug";
-
- if let Ok(build_mode) = env::var("DENO_BUILD_MODE") {
- if build_mode == "release" {
- target = "release";
- }
- }
-
- let bin = root.join(format!("target/{}/deno", target));
- debug!("root path {}", root.display());
- debug!("bin path {}", bin.display());
-
- let (mut reader, writer) = pipe().unwrap();
- let mut command = Command::new(bin);
- command.args(args);
- command.current_dir(root.join("tests"));
- command.stdin(Stdio::piped());
- command.stderr(Stdio::null());
-
- if self.check_stderr {
- let writer_clone = writer.try_clone().unwrap();
- command.stderr(writer_clone);
- }
-
- command.stdout(writer);
-
- let mut process = command.spawn().expect("failed to execute process");
-
- if let Some(input) = self.input {
- let mut p_stdin = process.stdin.take().unwrap();
- write!(p_stdin, "{}", input).unwrap();
- }
-
- // Very important when using pipes: This parent process is still
- // holding its copies of the write ends, and we have to close them
- // before we read, otherwise the read end will never report EOF. The
- // Command object owns the writers now, and dropping it closes them.
- drop(command);
-
- let mut actual = String::new();
- reader.read_to_string(&mut actual).unwrap();
-
- let status = process.wait().expect("failed to finish process");
- let exit_code = status.code().unwrap();
-
- actual = strip_ansi_codes(&actual).to_string();
-
- if self.exit_code != exit_code {
- println!("OUTPUT\n{}\nOUTPUT", actual);
- panic!(
- "bad exit code, expected: {:?}, actual: {:?}",
- self.exit_code, exit_code
- );
- }
-
- let output_path = root.join(self.output);
- debug!("output path {}", output_path.display());
- let expected =
- std::fs::read_to_string(output_path).expect("cannot read output");
-
- if !wildcard_match(&expected, &actual) {
- println!("OUTPUT\n{}\nOUTPUT", actual);
- println!("EXPECTED\n{}\nEXPECTED", expected);
- panic!("pattern match failed");
- }
- }
-}
-
-fn wildcard_match(pattern: &str, s: &str) -> bool {
- pattern_match(pattern, s, "[WILDCARD]")
-}
-
-fn pattern_match(pattern: &str, s: &str, wildcard: &str) -> bool {
- // Normalize line endings
- let s = s.replace("\r\n", "\n");
- let pattern = pattern.replace("\r\n", "\n");
-
- if pattern == wildcard {
- return true;
- }
-
- let parts = pattern.split(wildcard).collect::<Vec<&str>>();
- if parts.len() == 1 {
- return pattern == s;
- }
-
- if !s.starts_with(parts[0]) {
- return false;
- }
-
- let mut t = s.split_at(parts[0].len());
-
- for (i, part) in parts.iter().enumerate() {
- if i == 0 {
- continue;
- }
- dbg!(part, i);
- if i == parts.len() - 1 && (*part == "" || *part == "\n") {
- dbg!("exit 1 true", i);
- return true;
- }
- if let Some(found) = t.1.find(*part) {
- dbg!("found ", found);
- t = t.1.split_at(found + part.len());
- } else {
- dbg!("exit false ", i);
- return false;
- }
- }
-
- dbg!("end ", t.1.len());
- t.1.is_empty()
-}
-
-#[test]
-fn test_wildcard_match() {
- let fixtures = vec![
- ("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),
- // check with different line endings
- ("foo[WILDCARD]\nbaz[WILDCARD]\n", "foobar\nbazqat\n", true),
- (
- "foo[WILDCARD]\nbaz[WILDCARD]\n",
- "foobar\r\nbazqat\r\n",
- true,
- ),
- (
- "foo[WILDCARD]\r\nbaz[WILDCARD]\n",
- "foobar\nbazqat\r\n",
- true,
- ),
- (
- "foo[WILDCARD]\r\nbaz[WILDCARD]\r\n",
- "foobar\nbazqat\n",
- true,
- ),
- (
- "foo[WILDCARD]\r\nbaz[WILDCARD]\r\n",
- "foobar\r\nbazqat\r\n",
- true,
- ),
- ];
-
- // Iterate through the fixture lists, testing each one
- for (pattern, string, expected) in fixtures {
- let actual = wildcard_match(pattern, string);
- dbg!(pattern, string, expected);
- assert_eq!(actual, expected);
- }
-}
-
-#[test]
-fn test_pattern_match() {
- assert!(pattern_match("foo[BAR]baz", "foobarbaz", "[BAR]"));
- assert!(!pattern_match("foo[BAR]baz", "foobazbar", "[BAR]"));
-}
diff --git a/cli/tests/tty_tests.rs b/cli/tests/tty_tests.rs
new file mode 100644
index 000000000..413d39caf
--- /dev/null
+++ b/cli/tests/tty_tests.rs
@@ -0,0 +1,18 @@
+// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
+#[macro_use]
+extern crate lazy_static;
+extern crate tempfile;
+mod util;
+use util::*;
+
+// TODO(#2933): Rewrite these tests in rust.
+// TODO(ry) These tests can't run in parallel.
+#[test]
+fn tty_tests() {
+ let g = http_server();
+ run_python_script("tools/complex_permissions_test.py");
+ run_python_script("tools/permission_prompt_test.py");
+ // TODO(ry) is_tty_test is not passing on travis when run with "cargo test"
+ // run_python_script("tools/is_tty_test.py");
+ drop(g);
+}
diff --git a/cli/tests/util/mod.rs b/cli/tests/util/mod.rs
new file mode 100644
index 000000000..a91e5367b
--- /dev/null
+++ b/cli/tests/util/mod.rs
@@ -0,0 +1,218 @@
+//! Test utilites shared between integration_tests.rs and tty_tests.rs
+use deno_cli::colors::strip_ansi_codes;
+pub use deno_cli::test_util::*;
+use os_pipe::pipe;
+use std::io::Read;
+use std::io::Write;
+use std::process::Command;
+use std::process::Stdio;
+use tempfile::TempDir;
+
+lazy_static! {
+ static ref DENO_DIR: TempDir = { TempDir::new().expect("tempdir fail") };
+}
+
+#[allow(dead_code)]
+pub fn deno_cmd() -> Command {
+ let mut c = Command::new(deno_exe_path());
+ c.env("DENO_DIR", DENO_DIR.path());
+ c
+}
+
+pub fn run_python_script(script: &str) {
+ let output = Command::new("python")
+ .env("DENO_DIR", DENO_DIR.path())
+ .current_dir(root_path())
+ .arg(script)
+ .arg(format!("--executable={}", deno_exe_path().display()))
+ .env("DENO_BUILD_PATH", target_dir())
+ .output()
+ .expect("failed to spawn script");
+ if !output.status.success() {
+ let stdout = String::from_utf8(output.stdout).unwrap();
+ let stderr = String::from_utf8(output.stderr).unwrap();
+ panic!(
+ "{} executed with failing error code\n{}{}",
+ script, stdout, stderr
+ );
+ }
+}
+
+#[derive(Debug, Default)]
+pub struct CheckOutputIntegrationTest {
+ pub args: &'static str,
+ pub output: &'static str,
+ pub input: Option<&'static str>,
+ pub exit_code: i32,
+ pub check_stderr: bool,
+ pub http_server: bool,
+}
+
+impl CheckOutputIntegrationTest {
+ #[allow(dead_code)]
+ pub fn run(&self) {
+ let args = self.args.split_whitespace();
+ let root = root_path();
+ let deno_exe = deno_exe_path();
+ println!("root path {}", root.display());
+ println!("deno_exe path {}", deno_exe.display());
+
+ let http_server_guard = if self.http_server {
+ Some(http_server())
+ } else {
+ None
+ };
+
+ let (mut reader, writer) = pipe().unwrap();
+ let tests_dir = root.join("cli").join("tests");
+ let mut command = deno_cmd();
+ command.args(args);
+ command.current_dir(&tests_dir);
+ command.stdin(Stdio::piped());
+ command.stderr(Stdio::null());
+
+ if self.check_stderr {
+ let writer_clone = writer.try_clone().unwrap();
+ command.stderr(writer_clone);
+ }
+
+ command.stdout(writer);
+
+ let mut process = command.spawn().expect("failed to execute process");
+
+ if let Some(input) = self.input {
+ let mut p_stdin = process.stdin.take().unwrap();
+ write!(p_stdin, "{}", input).unwrap();
+ }
+
+ // Very important when using pipes: This parent process is still
+ // holding its copies of the write ends, and we have to close them
+ // before we read, otherwise the read end will never report EOF. The
+ // Command object owns the writers now, and dropping it closes them.
+ drop(command);
+
+ let mut actual = String::new();
+ reader.read_to_string(&mut actual).unwrap();
+
+ let status = process.wait().expect("failed to finish process");
+ let exit_code = status.code().unwrap();
+
+ drop(http_server_guard);
+
+ actual = strip_ansi_codes(&actual).to_string();
+
+ if self.exit_code != exit_code {
+ println!("OUTPUT\n{}\nOUTPUT", actual);
+ panic!(
+ "bad exit code, expected: {:?}, actual: {:?}",
+ self.exit_code, exit_code
+ );
+ }
+
+ let output_path = tests_dir.join(self.output);
+ println!("output path {}", output_path.display());
+ let expected =
+ std::fs::read_to_string(output_path).expect("cannot read output");
+
+ if !wildcard_match(&expected, &actual) {
+ println!("OUTPUT\n{}\nOUTPUT", actual);
+ println!("EXPECTED\n{}\nEXPECTED", expected);
+ panic!("pattern match failed");
+ }
+ }
+}
+
+fn wildcard_match(pattern: &str, s: &str) -> bool {
+ pattern_match(pattern, s, "[WILDCARD]")
+}
+
+fn pattern_match(pattern: &str, s: &str, wildcard: &str) -> bool {
+ // Normalize line endings
+ let s = s.replace("\r\n", "\n");
+ let pattern = pattern.replace("\r\n", "\n");
+
+ if pattern == wildcard {
+ return true;
+ }
+
+ let parts = pattern.split(wildcard).collect::<Vec<&str>>();
+ if parts.len() == 1 {
+ return pattern == s;
+ }
+
+ if !s.starts_with(parts[0]) {
+ return false;
+ }
+
+ let mut t = s.split_at(parts[0].len());
+
+ for (i, part) in parts.iter().enumerate() {
+ if i == 0 {
+ continue;
+ }
+ dbg!(part, i);
+ if i == parts.len() - 1 && (*part == "" || *part == "\n") {
+ dbg!("exit 1 true", i);
+ return true;
+ }
+ if let Some(found) = t.1.find(*part) {
+ dbg!("found ", found);
+ t = t.1.split_at(found + part.len());
+ } else {
+ dbg!("exit false ", i);
+ return false;
+ }
+ }
+
+ dbg!("end ", t.1.len());
+ t.1.is_empty()
+}
+
+#[test]
+fn test_wildcard_match() {
+ let fixtures = vec![
+ ("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),
+ // check with different line endings
+ ("foo[WILDCARD]\nbaz[WILDCARD]\n", "foobar\nbazqat\n", true),
+ (
+ "foo[WILDCARD]\nbaz[WILDCARD]\n",
+ "foobar\r\nbazqat\r\n",
+ true,
+ ),
+ (
+ "foo[WILDCARD]\r\nbaz[WILDCARD]\n",
+ "foobar\nbazqat\r\n",
+ true,
+ ),
+ (
+ "foo[WILDCARD]\r\nbaz[WILDCARD]\r\n",
+ "foobar\nbazqat\n",
+ true,
+ ),
+ (
+ "foo[WILDCARD]\r\nbaz[WILDCARD]\r\n",
+ "foobar\r\nbazqat\r\n",
+ true,
+ ),
+ ];
+
+ // Iterate through the fixture lists, testing each one
+ for (pattern, string, expected) in fixtures {
+ let actual = wildcard_match(pattern, string);
+ dbg!(pattern, string, expected);
+ assert_eq!(actual, expected);
+ }
+}
+
+#[test]
+fn test_pattern_match() {
+ assert!(pattern_match("foo[BAR]baz", "foobarbaz", "[BAR]"));
+ assert!(!pattern_match("foo[BAR]baz", "foobazbar", "[BAR]"));
+}