2023-01-13 02:59:13 +01:00
|
|
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
|
|
|
|
use std::fs::File;
|
|
|
|
use std::process::Command;
|
|
|
|
use test_util as util;
|
|
|
|
use test_util::TempDir;
|
2023-04-19 17:50:56 -04:00
|
|
|
use util::assert_contains;
|
2023-01-13 02:59:13 +01:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("welcome.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("welcome")
|
|
|
|
};
|
|
|
|
// try this twice to ensure it works with the cache
|
|
|
|
for _ in 0..2 {
|
|
|
|
let output = util::deno_cmd_with_deno_dir(&dir)
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./test_util/std/examples/welcome.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(&exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(output.stdout, "Welcome to Deno!\n".as_bytes());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_args() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("args.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("args")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/args.ts")
|
|
|
|
.arg("a")
|
|
|
|
.arg("b")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.arg("foo")
|
|
|
|
.arg("--bar")
|
|
|
|
.arg("--unstable")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(output.stdout, b"a\nb\nfoo\n--bar\n--unstable\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_error() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("error.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("error")
|
|
|
|
};
|
|
|
|
let testdata_path = util::testdata_path();
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(&testdata_path)
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_error.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.env("NO_COLOR", "1")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
assert_eq!(output.stdout, b"");
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
|
|
|
let stderr = util::strip_ansi_codes(&stderr).to_string();
|
|
|
|
// On Windows, we cannot assert the file path (because '\').
|
|
|
|
// Instead we just check for relevant output.
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(stderr, "error: Uncaught Error: boom!");
|
|
|
|
assert_contains!(stderr, "throw new Error(\"boom!\");");
|
|
|
|
assert_contains!(stderr, "\n at boom (file://");
|
|
|
|
assert_contains!(stderr, "standalone_error.ts:2:11");
|
|
|
|
assert_contains!(stderr, "at foo (file://");
|
|
|
|
assert_contains!(stderr, "standalone_error.ts:5:5");
|
|
|
|
assert_contains!(stderr, "standalone_error.ts:7:1");
|
2023-01-13 02:59:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_error_module_with_imports() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("error.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("error")
|
|
|
|
};
|
|
|
|
let testdata_path = util::testdata_path();
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(&testdata_path)
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_error_module_with_imports_1.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.env("NO_COLOR", "1")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
assert_eq!(output.stdout, b"hello\n");
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
|
|
|
let stderr = util::strip_ansi_codes(&stderr).to_string();
|
|
|
|
// On Windows, we cannot assert the file path (because '\').
|
|
|
|
// Instead we just check for relevant output.
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(stderr, "error: Uncaught Error: boom!");
|
|
|
|
assert_contains!(stderr, "throw new Error(\"boom!\");");
|
|
|
|
assert_contains!(stderr, "\n at file://");
|
|
|
|
assert_contains!(stderr, "standalone_error_module_with_imports_2.ts:2:7");
|
2023-01-13 02:59:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_load_datauri() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("load_datauri.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("load_datauri")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_import_datauri.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(output.stdout, b"Hello Deno!\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
// https://github.com/denoland/deno/issues/13704
|
|
|
|
#[test]
|
|
|
|
fn standalone_follow_redirects() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("follow_redirects.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("follow_redirects")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_follow_redirects.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(output.stdout, b"Hello\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_with_file_exists_error() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let output_path = if cfg!(windows) {
|
|
|
|
dir.path().join(r"args\")
|
|
|
|
} else {
|
|
|
|
dir.path().join("args/")
|
|
|
|
};
|
|
|
|
let file_path = dir.path().join("args");
|
|
|
|
File::create(&file_path).unwrap();
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&output_path)
|
|
|
|
.arg("./compile/args.ts")
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
let expected_stderr = format!(
|
|
|
|
concat!(
|
|
|
|
"Could not compile to file '{}' because its parent directory ",
|
|
|
|
"is an existing file. You can use the `--output <file-path>` flag to ",
|
|
|
|
"provide an alternative name.\n",
|
|
|
|
),
|
|
|
|
file_path.display(),
|
|
|
|
);
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(stderr, &expected_stderr);
|
2023-01-13 02:59:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_with_directory_exists_error() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("args.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("args")
|
|
|
|
};
|
|
|
|
std::fs::create_dir(&exe).unwrap();
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/args.ts")
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
let expected_stderr = format!(
|
|
|
|
concat!(
|
|
|
|
"Could not compile to file '{}' because a directory exists with ",
|
|
|
|
"the same name. You can use the `--output <file-path>` flag to ",
|
|
|
|
"provide an alternative name."
|
|
|
|
),
|
|
|
|
exe.display()
|
|
|
|
);
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(stderr, &expected_stderr);
|
2023-01-13 02:59:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_with_conflict_file_exists_error() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("args.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("args")
|
|
|
|
};
|
|
|
|
std::fs::write(&exe, b"SHOULD NOT BE OVERWRITTEN").unwrap();
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/args.ts")
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
let expected_stderr = format!(
|
|
|
|
concat!(
|
|
|
|
"Could not compile to file '{}' because the file already exists ",
|
|
|
|
"and cannot be overwritten. Please delete the existing file or ",
|
|
|
|
"use the `--output <file-path` flag to provide an alternative name."
|
|
|
|
),
|
|
|
|
exe.display()
|
|
|
|
);
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(stderr, &expected_stderr);
|
2023-01-13 02:59:13 +01:00
|
|
|
assert!(std::fs::read(&exe)
|
|
|
|
.unwrap()
|
|
|
|
.eq(b"SHOULD NOT BE OVERWRITTEN"));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn compile_and_overwrite_file() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("args.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("args")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/args.ts")
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert!(&exe.exists());
|
|
|
|
|
|
|
|
let recompile_output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/args.ts")
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(recompile_output.status.success());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_runtime_flags() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("flags.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("flags")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--allow-read")
|
|
|
|
.arg("--seed")
|
|
|
|
.arg("1")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_runtime_flags.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
let stdout_str = String::from_utf8(output.stdout).unwrap();
|
|
|
|
assert_eq!(util::strip_ansi_codes(&stdout_str), "0.147205063401058\n");
|
|
|
|
let stderr_str = String::from_utf8(output.stderr).unwrap();
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(
|
|
|
|
util::strip_ansi_codes(&stderr_str),
|
|
|
|
"PermissionDenied: Requires write access"
|
|
|
|
);
|
2023-01-13 02:59:13 +01:00
|
|
|
}
|
|
|
|
|
2023-03-22 15:15:53 +01:00
|
|
|
#[test]
|
|
|
|
fn standalone_ext_flag_ts() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("ext_flag_ts.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("ext_flag_ts")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--ext")
|
|
|
|
.arg("ts")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./file_extensions/ts_without_extension")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let stdout_str = String::from_utf8(output.stdout).unwrap();
|
|
|
|
assert_eq!(
|
|
|
|
util::strip_ansi_codes(&stdout_str),
|
|
|
|
"executing typescript with no extension\n"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_ext_flag_js() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("ext_flag_js.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("ext_flag_js")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--ext")
|
|
|
|
.arg("js")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./file_extensions/js_without_extension")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let stdout_str = String::from_utf8(output.stdout).unwrap();
|
|
|
|
assert_eq!(
|
|
|
|
util::strip_ansi_codes(&stdout_str),
|
|
|
|
"executing javascript with no extension\n"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-01-13 02:59:13 +01:00
|
|
|
#[test]
|
|
|
|
fn standalone_import_map() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("import_map.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("import_map")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--allow-read")
|
|
|
|
.arg("--import-map")
|
|
|
|
.arg("compile/standalone_import_map.json")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_import_map.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn standalone_import_map_config_file() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("import_map.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("import_map")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--allow-read")
|
|
|
|
.arg("--config")
|
|
|
|
.arg("compile/standalone_import_map_config.json")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./compile/standalone_import_map.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
// https://github.com/denoland/deno/issues/12670
|
|
|
|
fn skip_rebundle() {
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("hello_world.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("hello_world")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::testdata_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg("./run/001_hello.js")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.stderr(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
//no "Bundle testdata_path/run/001_hello.js" in output
|
|
|
|
assert!(!String::from_utf8(output.stderr).unwrap().contains("Bundle"));
|
|
|
|
|
|
|
|
let output = Command::new(exe)
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(output.stdout, "Hello World\n".as_bytes());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn check_local_by_default() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("welcome.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("welcome")
|
|
|
|
};
|
|
|
|
let status = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(util::testdata_path().join("./compile/check_local_by_default.ts"))
|
|
|
|
.status()
|
|
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn check_local_by_default2() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("welcome.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("welcome")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.env("NO_COLOR", "1")
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--unstable")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(util::testdata_path().join("./compile/check_local_by_default2.ts"))
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
let stdout = String::from_utf8(output.stdout).unwrap();
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
|
|
|
assert!(stdout.is_empty());
|
2023-04-19 17:50:56 -04:00
|
|
|
assert_contains!(
|
|
|
|
stderr,
|
2023-01-13 02:59:13 +01:00
|
|
|
r#"error: TS2322 [ERROR]: Type '12' is not assignable to type '"b"'."#
|
2023-04-19 17:50:56 -04:00
|
|
|
);
|
2023-01-13 02:59:13 +01:00
|
|
|
}
|
2023-03-05 02:37:54 +01:00
|
|
|
|
2023-03-19 23:32:54 +01:00
|
|
|
#[test]
|
|
|
|
fn workers_basic() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("basic.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("basic")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--no-check")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(util::testdata_path().join("./compile/workers/basic.ts"))
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
let output = Command::new(&exe).output().unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let expected = std::fs::read_to_string(
|
|
|
|
util::testdata_path().join("./compile/workers/basic.out"),
|
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
assert_eq!(String::from_utf8(output.stdout).unwrap(), expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn workers_not_in_module_map() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("not_in_module_map.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("not_in_module_map")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(util::testdata_path().join("./compile/workers/not_in_module_map.ts"))
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
let output = Command::new(&exe).env("NO_COLOR", "").output().unwrap();
|
|
|
|
assert!(!output.status.success());
|
|
|
|
let stderr = String::from_utf8(output.stderr).unwrap();
|
|
|
|
assert!(stderr.starts_with(concat!(
|
|
|
|
"error: Uncaught (in worker \"\") Module not found\n",
|
|
|
|
"error: Uncaught (in promise) Error: Unhandled error in child worker.\n"
|
|
|
|
)));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn workers_with_include_flag() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("workers_with_include_flag.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("workers_with_include_flag")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--include")
|
|
|
|
.arg(util::testdata_path().join("./compile/workers/worker.ts"))
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(util::testdata_path().join("./compile/workers/not_in_module_map.ts"))
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
let output = Command::new(&exe).env("NO_COLOR", "").output().unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let expected_stdout =
|
|
|
|
concat!("Hello from worker!\n", "Received 42\n", "Closing\n");
|
|
|
|
assert_eq!(&String::from_utf8(output.stdout).unwrap(), expected_stdout);
|
|
|
|
}
|
|
|
|
|
2023-03-05 02:37:54 +01:00
|
|
|
#[test]
|
|
|
|
fn dynamic_import() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("dynamic_import.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("dynamic_import")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(util::testdata_path().join("./compile/dynamic_imports/main.ts"))
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
let output = Command::new(&exe).env("NO_COLOR", "").output().unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let expected = std::fs::read_to_string(
|
|
|
|
util::testdata_path().join("./compile/dynamic_imports/main.out"),
|
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
assert_eq!(String::from_utf8(output.stdout).unwrap(), expected);
|
|
|
|
}
|
2023-03-19 00:43:07 +01:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn dynamic_import_unanalyzable() {
|
|
|
|
let _guard = util::http_server();
|
|
|
|
let dir = TempDir::new();
|
|
|
|
let exe = if cfg!(windows) {
|
|
|
|
dir.path().join("dynamic_import_unanalyzable.exe")
|
|
|
|
} else {
|
|
|
|
dir.path().join("dynamic_import_unanalyzable")
|
|
|
|
};
|
|
|
|
let output = util::deno_cmd()
|
|
|
|
.current_dir(util::root_path())
|
|
|
|
.arg("compile")
|
|
|
|
.arg("--allow-read")
|
|
|
|
.arg("--include")
|
|
|
|
.arg(util::testdata_path().join("./compile/dynamic_imports/import1.ts"))
|
|
|
|
.arg("--output")
|
|
|
|
.arg(&exe)
|
|
|
|
.arg(
|
|
|
|
util::testdata_path()
|
|
|
|
.join("./compile/dynamic_imports/main_unanalyzable.ts"),
|
|
|
|
)
|
|
|
|
.output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
|
|
|
|
let output = Command::new(&exe).env("NO_COLOR", "").output().unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
let expected = std::fs::read_to_string(
|
|
|
|
util::testdata_path().join("./compile/dynamic_imports/main.out"),
|
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
assert_eq!(String::from_utf8(output.stdout).unwrap(), expected);
|
|
|
|
}
|