// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license. use std::fs::File; use std::process::Command; use tempfile::TempDir; use test_util as util; #[test] fn compile() { let dir = TempDir::new().unwrap(); 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()) .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] #[cfg(windows)] // https://github.com/denoland/deno/issues/9667 fn compile_windows_ext() { let dir = TempDir::new().unwrap(); let exe = dir.path().join("welcome_9667"); let output = util::deno_cmd() .current_dir(util::root_path()) .arg("compile") .arg("--unstable") .arg("--output") .arg(&exe) .arg("--target") .arg("x86_64-unknown-linux-gnu") .arg("./test_util/std/examples/welcome.ts") // TODO(kt3k): Prints command output to the test log for debugging purpose. // Uncomment this line when this test become stable. //.stdout(std::process::Stdio::piped()) .spawn() .unwrap() .wait_with_output() .unwrap(); assert!(output.status.success()); assert!(std::path::Path::new(&exe).exists()); } #[test] fn standalone_args() { let dir = TempDir::new().unwrap(); 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("./028_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().unwrap(); 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("./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(); // On Windows, we cannot assert the file path (because '\'). // Instead we just check for relevant output. assert!(stderr.contains("error: Error: boom!\n at boom (file://")); assert!(stderr.contains("standalone_error.ts:2:11")); assert!(stderr.contains("at foo (file://")); assert!(stderr.contains("standalone_error.ts:5:5")); assert!(stderr.contains("standalone_error.ts:7:1")); } #[test] fn standalone_error_module_with_imports() { let dir = TempDir::new().unwrap(); 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("./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()); println!("{:#?}", &output); assert_eq!(output.stdout, b"hello\n"); let stderr = String::from_utf8(output.stderr).unwrap(); // On Windows, we cannot assert the file path (because '\'). // Instead we just check for relevant output. assert!(stderr.contains("error: Error: boom!\n at file://")); assert!(stderr.contains("standalone_error_module_with_imports_2.ts:2:7")); } #[test] fn standalone_load_datauri() { let dir = TempDir::new().unwrap(); 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("./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"); } #[test] fn standalone_compiler_ops() { let dir = TempDir::new().unwrap(); let exe = if cfg!(windows) { dir.path().join("standalone_compiler_ops.exe") } else { dir.path().join("standalone_compiler_ops") }; let output = util::deno_cmd() .current_dir(util::testdata_path()) .arg("compile") .arg("--unstable") .arg("--output") .arg(&exe) .arg("./standalone_compiler_ops.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, Compiler API!\n"); } #[test] fn compile_with_directory_output_flag() { let dir = TempDir::new().unwrap(); let output_path = if cfg!(windows) { dir.path().join(r"args\random\") } else { dir.path().join("args/random/") }; let output = util::deno_cmd() .current_dir(util::testdata_path()) .arg("compile") .arg("--unstable") .arg("--output") .arg(&output_path) .arg("./standalone_compiler_ops.ts") .stdout(std::process::Stdio::piped()) .spawn() .unwrap() .wait_with_output() .unwrap(); assert!(output.status.success()); let exe = if cfg!(windows) { output_path.join("standalone_compiler_ops.exe") } else { output_path.join("standalone_compiler_ops") }; assert!(&exe.exists()); 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, Compiler API!\n"); } #[test] fn compile_with_file_exists_error() { let dir = TempDir::new().unwrap(); 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("./028_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 ` flag to ", "provide an alternative name.\n", ), file_path.display(), ); let stderr = String::from_utf8(output.stderr).unwrap(); assert!(stderr.contains(&expected_stderr)); } #[test] fn compile_with_directory_exists_error() { let dir = TempDir::new().unwrap(); 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("./028_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 ` flag to ", "provide an alternative name." ), exe.display() ); let stderr = String::from_utf8(output.stderr).unwrap(); assert!(stderr.contains(&expected_stderr)); } #[test] fn compile_with_conflict_file_exists_error() { let dir = TempDir::new().unwrap(); 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("./028_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