summaryrefslogtreecommitdiff
path: root/cli/tests/integration
diff options
context:
space:
mode:
authorBartek IwaƄczuk <biwanczuk@gmail.com>2021-11-24 16:55:10 +0100
committerGitHub <noreply@github.com>2021-11-24 16:55:10 +0100
commit1117d2db3965fc44f174be3fd029293b7e2b952e (patch)
tree3a50bffc376d1d86cfa09e726e500560f9f3c67c /cli/tests/integration
parent1a51f2392db731fe0c1aa0ccd00da6769d254e66 (diff)
compat: support compat mode in REPL (#12882)
This commit introduces "ProcState::maybe_resolver" field, which stores a single instance of resolver for the whole lifetime of the process, instead of creating these resolvers for each creation of module graph. As a result, this resolver can be used in fallback case where graph is not constructed (REPL, loading modules using "require") unifying resolution logic.
Diffstat (limited to 'cli/tests/integration')
-rw-r--r--cli/tests/integration/compat_tests.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/cli/tests/integration/compat_tests.rs b/cli/tests/integration/compat_tests.rs
index 70c224e31..fdd9813f0 100644
--- a/cli/tests/integration/compat_tests.rs
+++ b/cli/tests/integration/compat_tests.rs
@@ -46,6 +46,12 @@ itest!(compat_dyn_import_rejects_with_node_compatible_error {
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"),
+});
+
#[test]
fn globals_in_repl() {
let (out, _err) = util::run_and_collect_output_with_args(
@@ -59,6 +65,20 @@ fn globals_in_repl() {
}
#[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,