mirror of
https://github.com/denoland/deno.git
synced 2025-01-09 23:58:23 -05:00
a65ce33fab
This commit adds CJS/ESM interoperability when running in --compat mode. Before executing files, they are analyzed and all CommonJS modules are transformed on the fly to a ES modules. This is done by utilizing analyze_cjs() functionality from deno_ast. After discovering exports and reexports, an ES module is rendered and saved in memory for later use. There's a caveat that all files ending with ".js" extension are considered as CommonJS modules (unless there's a related "package.json" with "type": "module").
157 lines
4.8 KiB
Rust
157 lines
4.8 KiB
Rust
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
|
|
|
use crate::itest;
|
|
use deno_core::url::Url;
|
|
use test_util as util;
|
|
|
|
/// Tests in this file should use `std_file_url` to override `DENO_NODE_COMPAT_URL`
|
|
/// env variable. This speeds up tests significantly as they no longer
|
|
/// download contents of `deno_std` from `https://deno.land` in each test.
|
|
|
|
/// Return a file URL pointing to "std" submodule
|
|
/// in "test_util" directory. It must have a trailing slash.
|
|
fn std_file_url() -> String {
|
|
let u = Url::from_directory_path(util::std_path()).unwrap();
|
|
u.to_string()
|
|
}
|
|
|
|
itest!(globals {
|
|
args: "run --compat --no-check --unstable --allow-read --allow-env compat/globals.ts",
|
|
output: "compat/globals.out",
|
|
envs: vec![("DENO_NODE_COMPAT_URL".to_string(), std_file_url())],
|
|
});
|
|
|
|
itest!(fs_promises {
|
|
args: "run --compat --no-check --unstable -A compat/fs_promises.mjs",
|
|
output: "compat/fs_promises.out",
|
|
envs: vec![("DENO_NODE_COMPAT_URL".to_string(), std_file_url())],
|
|
});
|
|
|
|
itest!(node_prefix_fs_promises {
|
|
args: "run --compat --no-check --unstable -A compat/node_fs_promises.mjs",
|
|
output: "compat/fs_promises.out",
|
|
envs: vec![("DENO_NODE_COMPAT_URL".to_string(), std_file_url())],
|
|
});
|
|
|
|
itest!(compat_with_import_map_and_https_imports {
|
|
args: "run --quiet --no-check --compat --unstable -A --import-map=compat/import_map.json compat/import_map_https_imports.mjs",
|
|
output: "compat/import_map_https_imports.out",
|
|
envs: vec![("DENO_NODE_COMPAT_URL".to_string(), std_file_url())],
|
|
});
|
|
|
|
itest!(compat_dyn_import_rejects_with_node_compatible_error {
|
|
args:
|
|
"run --quiet --no-check --compat --unstable -A compat/dyn_import_reject.js",
|
|
output: "compat/dyn_import_reject.out",
|
|
envs: vec![("DENO_NODE_COMPAT_URL".to_string(), std_file_url())],
|
|
});
|
|
|
|
itest!(import_esm_from_cjs {
|
|
args:
|
|
"run --compat --unstable -A --quiet compat/import_esm_from_cjs/index.js",
|
|
output_str: Some("function\n"),
|
|
});
|
|
|
|
itest!(test_runner_cjs {
|
|
args: "test --compat --unstable -A --quiet compat/test_runner/cjs.js",
|
|
exit_code: 1,
|
|
output: "compat/test_runner/cjs.out",
|
|
});
|
|
|
|
itest!(test_runner_esm {
|
|
args: "test --compat --unstable -A --quiet compat/test_runner/esm.mjs",
|
|
exit_code: 1,
|
|
output: "compat/test_runner/esm.out",
|
|
});
|
|
|
|
// Top level assertion test mostly just make sure that the test runner finishes correctly on compat mode
|
|
// when there is no tests
|
|
itest!(top_level_assertion_cjs {
|
|
args: "test --compat --unstable -A --quiet compat/test_runner/top_level_assertion_cjs.js",
|
|
exit_code: 0,
|
|
output: "compat/test_runner/top_level_assertion_cjs.out",
|
|
});
|
|
|
|
itest!(top_level_assertion_esm {
|
|
args: "test --compat --unstable -A --quiet compat/test_runner/top_level_assertion_esm.mjs",
|
|
exit_code: 0,
|
|
output: "compat/test_runner/top_level_assertion_esm.out",
|
|
});
|
|
|
|
itest!(top_level_fail_cjs {
|
|
args: "test --compat --unstable -A --quiet compat/test_runner/top_level_fail_cjs.js",
|
|
exit_code: 1,
|
|
output: "compat/test_runner/top_level_fail_cjs.out",
|
|
});
|
|
|
|
itest!(top_level_fail_esm {
|
|
args: "test --compat --unstable -A --quiet compat/test_runner/top_level_fail_esm.mjs",
|
|
exit_code: 1,
|
|
output: "compat/test_runner/top_level_fail_esm.out",
|
|
});
|
|
|
|
itest!(compat_worker {
|
|
args: "run --compat --unstable -A --quiet --no-check compat/worker/worker_test.mjs",
|
|
output: "compat/worker/worker_test.out",
|
|
});
|
|
|
|
itest!(cjs_esm_interop {
|
|
args:
|
|
"run --compat --unstable -A --quiet --no-check compat/import_cjs_from_esm/main.mjs",
|
|
output: "compat/import_cjs_from_esm.out",
|
|
});
|
|
|
|
#[test]
|
|
fn globals_in_repl() {
|
|
let (out, _err) = util::run_and_collect_output_with_args(
|
|
true,
|
|
vec!["repl", "--compat", "--unstable", "--no-check", "--quiet"],
|
|
Some(vec!["global == window"]),
|
|
Some(vec![("DENO_NODE_COMPAT_URL".to_string(), std_file_url())]),
|
|
false,
|
|
);
|
|
assert!(out.contains("true"));
|
|
}
|
|
|
|
#[test]
|
|
fn require_in_repl() {
|
|
let (out, _err) = util::run_and_collect_output_with_args(
|
|
true,
|
|
vec!["repl", "--compat", "--unstable", "--quiet"],
|
|
Some(vec![
|
|
"const foo = require('./compat/import_esm_from_cjs/index');",
|
|
]),
|
|
None,
|
|
false,
|
|
);
|
|
assert!(out.contains("function"));
|
|
}
|
|
|
|
#[test]
|
|
fn node_compat_url() {
|
|
let (out, err) = util::run_and_collect_output_with_args(
|
|
false,
|
|
vec!["repl", "--compat", "--unstable", "--no-check", "--quiet"],
|
|
None,
|
|
Some(vec![(
|
|
"DENO_NODE_COMPAT_URL".to_string(),
|
|
"file:///non_existent/".to_string(),
|
|
)]),
|
|
false,
|
|
);
|
|
assert!(out.is_empty());
|
|
assert!(!err.is_empty());
|
|
assert!(err.contains("file:///non_existent/node/global.ts"));
|
|
}
|
|
|
|
#[test]
|
|
fn native_modules_as_global_vars() {
|
|
let (out, _err) = util::run_and_collect_output_with_args(
|
|
true,
|
|
vec!["repl", "--compat", "--unstable", "--quiet"],
|
|
Some(vec!["if(cluster && v8 && sys) { true } else { false }"]),
|
|
None,
|
|
false,
|
|
);
|
|
assert!(out.contains("true"));
|
|
}
|