2023-01-12 20:59:13 -05:00
|
|
|
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
|
2023-02-23 10:58:10 -05:00
|
|
|
use test_util::env_vars_for_npm_tests;
|
2023-06-06 17:07:46 -04:00
|
|
|
use test_util::TestContext;
|
2023-04-11 18:10:51 -04:00
|
|
|
use test_util::TestContextBuilder;
|
2023-02-23 10:58:10 -05:00
|
|
|
|
2023-01-12 20:59:13 -05:00
|
|
|
itest!(_036_import_map_fetch {
|
|
|
|
args:
|
|
|
|
"cache --quiet --reload --import-map=import_maps/import_map.json import_maps/test.ts",
|
|
|
|
output: "cache/036_import_map_fetch.out",
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(_037_fetch_multiple {
|
|
|
|
args: "cache --reload --check=all run/fetch/test.ts run/fetch/other.ts",
|
|
|
|
http_server: true,
|
|
|
|
output: "cache/037_fetch_multiple.out",
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(_095_cache_with_bare_import {
|
|
|
|
args: "cache cache/095_cache_with_bare_import.ts",
|
|
|
|
output: "cache/095_cache_with_bare_import.ts.out",
|
|
|
|
exit_code: 1,
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(cache_extensionless {
|
|
|
|
args: "cache --reload --check=all http://localhost:4545/subdir/no_js_ext",
|
|
|
|
output: "cache/cache_extensionless.out",
|
|
|
|
http_server: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(cache_random_extension {
|
|
|
|
args:
|
|
|
|
"cache --reload --check=all http://localhost:4545/subdir/no_js_ext@1.0.0",
|
|
|
|
output: "cache/cache_random_extension.out",
|
|
|
|
http_server: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(performance_stats {
|
|
|
|
args: "cache --reload --check=all --log-level debug run/002_hello.ts",
|
|
|
|
output: "cache/performance_stats.out",
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(redirect_cache {
|
|
|
|
http_server: true,
|
|
|
|
args:
|
|
|
|
"cache --reload --check=all http://localhost:4548/subdir/redirects/a.ts",
|
|
|
|
output: "cache/redirect_cache.out",
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(ignore_require {
|
|
|
|
args: "cache --reload --no-check cache/ignore_require.js",
|
|
|
|
output_str: Some(""),
|
|
|
|
exit_code: 0,
|
|
|
|
});
|
|
|
|
|
|
|
|
// This test only runs on linux, because it hardcodes the XDG_CACHE_HOME env var
|
|
|
|
// which is only used on linux.
|
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
#[test]
|
|
|
|
fn relative_home_dir() {
|
|
|
|
use test_util as util;
|
|
|
|
use test_util::TempDir;
|
|
|
|
|
2023-06-10 11:09:45 -04:00
|
|
|
let deno_dir = TempDir::new();
|
2023-01-12 20:59:13 -05:00
|
|
|
let mut deno_cmd = util::deno_cmd();
|
|
|
|
let output = deno_cmd
|
|
|
|
.current_dir(util::testdata_path())
|
2023-06-10 11:09:45 -04:00
|
|
|
.env("XDG_CACHE_HOME", deno_dir.path())
|
2023-01-12 20:59:13 -05:00
|
|
|
.env_remove("HOME")
|
|
|
|
.env_remove("DENO_DIR")
|
|
|
|
.arg("cache")
|
|
|
|
.arg("--reload")
|
|
|
|
.arg("--no-check")
|
|
|
|
.arg("run/002_hello.ts")
|
|
|
|
.stdout(std::process::Stdio::piped())
|
|
|
|
.spawn()
|
|
|
|
.unwrap()
|
|
|
|
.wait_with_output()
|
|
|
|
.unwrap();
|
|
|
|
assert!(output.status.success());
|
|
|
|
assert_eq!(output.stdout, b"");
|
|
|
|
}
|
|
|
|
|
|
|
|
itest!(check_local_by_default {
|
|
|
|
args: "cache --quiet cache/check_local_by_default.ts",
|
|
|
|
output: "cache/check_local_by_default.out",
|
|
|
|
http_server: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(check_local_by_default2 {
|
|
|
|
args: "cache --quiet cache/check_local_by_default2.ts",
|
|
|
|
output: "cache/check_local_by_default2.out",
|
|
|
|
http_server: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
itest!(json_import {
|
|
|
|
// should not error
|
|
|
|
args: "cache --quiet cache/json_import/main.ts",
|
|
|
|
});
|
2023-02-23 10:58:10 -05:00
|
|
|
|
|
|
|
itest!(package_json_basic {
|
|
|
|
args: "cache main.ts",
|
|
|
|
output: "package_json/basic/main.cache.out",
|
|
|
|
envs: env_vars_for_npm_tests(),
|
|
|
|
http_server: true,
|
|
|
|
cwd: Some("package_json/basic"),
|
|
|
|
copy_temp_dir: Some("package_json/basic"),
|
|
|
|
exit_code: 0,
|
|
|
|
});
|
2023-04-11 18:10:51 -04:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn cache_matching_package_json_dep_should_not_install_all() {
|
|
|
|
let context = TestContextBuilder::for_npm().use_temp_cwd().build();
|
|
|
|
let temp_dir = context.temp_dir();
|
|
|
|
temp_dir.write(
|
|
|
|
"package.json",
|
|
|
|
r#"{ "dependencies": { "@types/node": "18.8.2", "@denotest/esm-basic": "*" } }"#,
|
|
|
|
);
|
|
|
|
let output = context
|
|
|
|
.new_command()
|
|
|
|
.args("cache npm:@types/node@18.8.2")
|
|
|
|
.run();
|
|
|
|
output.assert_matches_text(concat!(
|
|
|
|
"Download http://localhost:4545/npm/registry/@types/node\n",
|
|
|
|
"Download http://localhost:4545/npm/registry/@types/node/node-18.8.2.tgz\n",
|
|
|
|
"Initialize @types/node@18.8.2\n",
|
|
|
|
));
|
|
|
|
}
|
2023-04-12 01:55:19 -04:00
|
|
|
|
|
|
|
// Regression test for https://github.com/denoland/deno/issues/17299
|
|
|
|
#[test]
|
|
|
|
fn cache_put_overwrite() {
|
|
|
|
let test_context = TestContextBuilder::new().use_temp_cwd().build();
|
|
|
|
let temp_dir = test_context.temp_dir();
|
|
|
|
|
|
|
|
let part_one = r#"
|
|
|
|
const req = new Request('http://localhost/abc');
|
|
|
|
const res1 = new Response('res1');
|
|
|
|
const res2 = new Response('res2');
|
|
|
|
|
|
|
|
const cache = await caches.open('test');
|
|
|
|
|
|
|
|
await cache.put(req, res1);
|
|
|
|
await cache.put(req, res2);
|
|
|
|
|
|
|
|
const res = await cache.match(req).then((res) => res?.text());
|
|
|
|
console.log(res);
|
|
|
|
"#;
|
|
|
|
|
|
|
|
let part_two = r#"
|
|
|
|
const req = new Request("http://localhost/abc");
|
|
|
|
const res1 = new Response("res1");
|
|
|
|
const res2 = new Response("res2");
|
|
|
|
|
|
|
|
const cache = await caches.open("test");
|
|
|
|
|
|
|
|
// Swap the order of put() calls.
|
|
|
|
await cache.put(req, res2);
|
|
|
|
await cache.put(req, res1);
|
|
|
|
|
|
|
|
const res = await cache.match(req).then((res) => res?.text());
|
|
|
|
console.log(res);
|
|
|
|
"#;
|
|
|
|
|
|
|
|
temp_dir.write("cache_put.js", part_one);
|
|
|
|
|
|
|
|
let run_command =
|
|
|
|
test_context.new_command().args_vec(["run", "cache_put.js"]);
|
|
|
|
|
|
|
|
let output = run_command.run();
|
|
|
|
output.assert_matches_text("res2\n");
|
|
|
|
output.assert_exit_code(0);
|
|
|
|
|
|
|
|
// The wait will surface the bug as we check last written time
|
|
|
|
// when we overwrite a response.
|
|
|
|
std::thread::sleep(std::time::Duration::from_secs(1));
|
|
|
|
|
|
|
|
temp_dir.write("cache_put.js", part_two);
|
|
|
|
let output = run_command.run();
|
|
|
|
output.assert_matches_text("res1\n");
|
|
|
|
output.assert_exit_code(0);
|
|
|
|
}
|
2023-06-06 17:07:46 -04:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn loads_type_graph() {
|
|
|
|
let output = TestContext::default()
|
|
|
|
.new_command()
|
|
|
|
.args("cache --reload -L debug run/type_directives_js_main.js")
|
|
|
|
.run();
|
|
|
|
output.assert_matches_text("[WILDCARD] - FileFetcher::fetch() - specifier: file:///[WILDCARD]/subdir/type_reference.d.ts[WILDCARD]");
|
|
|
|
}
|