1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-12 09:03:42 -05:00

chore: deno_core bump (#22407)

- Adding `None` flag for warmup script.
 - Modify opcall trace interface to match new Rust implementation
This commit is contained in:
Matt Mastracci 2024-02-13 19:44:37 -07:00 committed by GitHub
parent 082f8128b8
commit e23fc6d88c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
7 changed files with 64 additions and 57 deletions

12
Cargo.lock generated
View file

@ -1226,9 +1226,9 @@ dependencies = [
[[package]] [[package]]
name = "deno_core" name = "deno_core"
version = "0.261.0" version = "0.262.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "7743b191a1004e4989caf50c4ace8e3208732456118e79d433e2aff246772066" checksum = "bb0c12fbe4f2c497ff53de92dd698a27d93f8e9c2519ea5684f608cb9f4ef44b"
dependencies = [ dependencies = [
"anyhow", "anyhow",
"bit-set", "bit-set",
@ -1676,9 +1676,9 @@ dependencies = [
[[package]] [[package]]
name = "deno_ops" name = "deno_ops"
version = "0.137.0" version = "0.138.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "7ee5973f100f3ff9dea83a5b6261276d233c51ebc7f4c4fcdebd4c0d476b4fe5" checksum = "04698b09128a026abe3d8a82fdb231baf1a35f07443844728fe1441b2c2340f1"
dependencies = [ dependencies = [
"proc-macro-rules", "proc-macro-rules",
"proc-macro2", "proc-macro2",
@ -5450,9 +5450,9 @@ dependencies = [
[[package]] [[package]]
name = "serde_v8" name = "serde_v8"
version = "0.170.0" version = "0.171.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "43cce12a1cbf76530919847280a975a7831dab85a73d513161a5e6153a8e75d6" checksum = "88a2746b1f9e4015ee5f325bb87ab0f1891b76c38dfb1675bc83857eaf6451d0"
dependencies = [ dependencies = [
"bytes", "bytes",
"derive_more", "derive_more",

View file

@ -43,7 +43,7 @@ repository = "https://github.com/denoland/deno"
[workspace.dependencies] [workspace.dependencies]
deno_ast = { version = "0.33.2", features = ["transpiling"] } deno_ast = { version = "0.33.2", features = ["transpiling"] }
deno_core = { version = "0.261.0" } deno_core = { version = "0.262.0" }
deno_bench_util = { version = "0.131.0", path = "./bench_util" } deno_bench_util = { version = "0.131.0", path = "./bench_util" }
deno_lockfile = "0.18.2" deno_lockfile = "0.18.2"

View file

@ -266,33 +266,36 @@ mod ts {
) )
.unwrap(); .unwrap();
let output = create_snapshot(CreateSnapshotOptions { let output = create_snapshot(
cargo_manifest_dir: env!("CARGO_MANIFEST_DIR"), CreateSnapshotOptions {
snapshot_path, cargo_manifest_dir: env!("CARGO_MANIFEST_DIR"),
startup_snapshot: None, snapshot_path,
extensions: vec![deno_tsc::init_ops_and_esm( startup_snapshot: None,
op_crate_libs, extensions: vec![deno_tsc::init_ops_and_esm(
build_libs, op_crate_libs,
path_dts, build_libs,
)], path_dts,
// NOTE(bartlomieju): Compressing the TSC snapshot in debug build took )],
// ~45s on M1 MacBook Pro; without compression it took ~1s. // NOTE(bartlomieju): Compressing the TSC snapshot in debug build took
// Thus we're not not using compressed snapshot, trading off // ~45s on M1 MacBook Pro; without compression it took ~1s.
// a lot of build time for some startup time in debug build. // Thus we're not not using compressed snapshot, trading off
#[cfg(debug_assertions)] // a lot of build time for some startup time in debug build.
compression_cb: None, #[cfg(debug_assertions)]
compression_cb: None,
#[cfg(not(debug_assertions))] #[cfg(not(debug_assertions))]
compression_cb: Some(Box::new(|vec, snapshot_slice| { compression_cb: Some(Box::new(|vec, snapshot_slice| {
eprintln!("Compressing TSC snapshot..."); eprintln!("Compressing TSC snapshot...");
vec.extend_from_slice( vec.extend_from_slice(
&zstd::bulk::compress(snapshot_slice, 22) &zstd::bulk::compress(snapshot_slice, 22)
.expect("snapshot compression failed"), .expect("snapshot compression failed"),
); );
})), })),
with_runtime_cb: None, with_runtime_cb: None,
skip_op_registration: false, skip_op_registration: false,
}); },
None,
);
for path in output.files_loaded_during_snapshot { for path in output.files_loaded_during_snapshot {
println!("cargo:rerun-if-changed={}", path.display()); println!("cargo:rerun-if-changed={}", path.display());
} }

View file

@ -156,6 +156,7 @@ function populateOpNames() {
function assertOps(fn) { function assertOps(fn) {
/** @param desc {TestDescription | TestStepDescription} */ /** @param desc {TestDescription | TestStepDescription} */
return async function asyncOpSanitizer(desc) { return async function asyncOpSanitizer(desc) {
let hasTraces = false;
if (opNames === null) populateOpNames(); if (opNames === null) populateOpNames();
const res = op_test_op_sanitizer_collect( const res = op_test_op_sanitizer_collect(
desc.id, desc.id,
@ -220,8 +221,7 @@ function assertOps(fn) {
message += ` This is often caused by not ${hint}.`; message += ` This is often caused by not ${hint}.`;
} }
const traces = []; const traces = [];
for (const [id, { opName: traceOpName, stack }] of postTraces) { for (const [id, stack] of postTraces) {
if (traceOpName !== opName) continue;
if (MapPrototypeHas(preTraces, id)) continue; if (MapPrototypeHas(preTraces, id)) continue;
ArrayPrototypePush(traces, stack); ArrayPrototypePush(traces, stack);
} }
@ -232,6 +232,7 @@ function assertOps(fn) {
message += " The operations were started here:\n"; message += " The operations were started here:\n";
message += ArrayPrototypeJoin(traces, "\n\n"); message += ArrayPrototypeJoin(traces, "\n\n");
} }
hasTraces |= traces.length > 0;
ArrayPrototypePush(details, message); ArrayPrototypePush(details, message);
} else if (diff < 0) { } else if (diff < 0) {
const [name, hint] = op_test_op_sanitizer_get_async_message(opName); const [name, hint] = op_test_op_sanitizer_get_async_message(opName);
@ -247,8 +248,7 @@ function assertOps(fn) {
message += ` This is often caused by not ${hint}.`; message += ` This is often caused by not ${hint}.`;
} }
const traces = []; const traces = [];
for (const [id, { opName: traceOpName, stack }] of preTraces) { for (const [id, stack] of preTraces) {
if (opName !== traceOpName) continue;
if (MapPrototypeHas(postTraces, id)) continue; if (MapPrototypeHas(postTraces, id)) continue;
ArrayPrototypePush(traces, stack); ArrayPrototypePush(traces, stack);
} }
@ -259,6 +259,7 @@ function assertOps(fn) {
message += " The operations were started here:\n"; message += " The operations were started here:\n";
message += ArrayPrototypeJoin(traces, "\n\n"); message += ArrayPrototypeJoin(traces, "\n\n");
} }
hasTraces |= traces.length > 0;
ArrayPrototypePush(details, message); ArrayPrototypePush(details, message);
} else { } else {
throw new Error("unreachable"); throw new Error("unreachable");
@ -266,7 +267,7 @@ function assertOps(fn) {
} }
return { return {
failed: { leakedOps: [details, core.isOpCallTracingEnabled()] }, failed: { leakedOps: [details, hasTraces] },
}; };
}; };
} }

View file

@ -133,7 +133,7 @@ fn format_sanitizer_accum_item(
) -> (RuntimeActivityType, Cow<'static, str>) { ) -> (RuntimeActivityType, Cow<'static, str>) {
let activity_type = activity.activity(); let activity_type = activity.activity();
match activity { match activity {
RuntimeActivity::AsyncOp(_, name) => (activity_type, name.into()), RuntimeActivity::AsyncOp(_, name, _) => (activity_type, name.into()),
RuntimeActivity::Interval(_) => (activity_type, "".into()), RuntimeActivity::Interval(_) => (activity_type, "".into()),
RuntimeActivity::Resource(_, name) => (activity_type, name.into()), RuntimeActivity::Resource(_, name) => (activity_type, name.into()),
RuntimeActivity::Timer(_) => (activity_type, "".into()), RuntimeActivity::Timer(_) => (activity_type, "".into()),

View file

@ -265,21 +265,24 @@ pub fn create_runtime_snapshot(
} }
} }
let output = create_snapshot(CreateSnapshotOptions { let output = create_snapshot(
cargo_manifest_dir: env!("CARGO_MANIFEST_DIR"), CreateSnapshotOptions {
snapshot_path, cargo_manifest_dir: env!("CARGO_MANIFEST_DIR"),
startup_snapshot: None, snapshot_path,
extensions, startup_snapshot: None,
compression_cb: None, extensions,
with_runtime_cb: Some(Box::new(|rt| { compression_cb: None,
let isolate = rt.v8_isolate(); with_runtime_cb: Some(Box::new(|rt| {
let scope = &mut v8::HandleScope::new(isolate); let isolate = rt.v8_isolate();
let scope = &mut v8::HandleScope::new(isolate);
let ctx = v8::Context::new(scope); let ctx = v8::Context::new(scope);
assert_eq!(scope.add_context(ctx), deno_node::VM_CONTEXT_INDEX); assert_eq!(scope.add_context(ctx), deno_node::VM_CONTEXT_INDEX);
})), })),
skip_op_registration: false, skip_op_registration: false,
}); },
None,
);
for path in output.files_loaded_during_snapshot { for path in output.files_loaded_during_snapshot {
println!("cargo:rerun-if-changed={}", path.display()); println!("cargo:rerun-if-changed={}", path.display());
} }

View file

@ -10,13 +10,13 @@ error: Leaking async ops:
- 2 async operations to sleep for a duration were started in this test, but never completed. This is often caused by not cancelling a `setTimeout` or `setInterval` call. The operations were started here: - 2 async operations to sleep for a duration were started in this test, but never completed. This is often caused by not cancelling a `setTimeout` or `setInterval` call. The operations were started here:
at [WILDCARD] at [WILDCARD]
at setTimeout ([WILDCARD]) at setTimeout ([WILDCARD])
at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:4:3) at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:[WILDCARD])
at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:8:27 at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:8:27
at [WILDCARD] at [WILDCARD]
at [WILDCARD] at [WILDCARD]
at setTimeout ([WILDCARD]) at setTimeout ([WILDCARD])
at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:5:3) at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:[WILDCARD])
at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:8:27 at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:8:27
at [WILDCARD] at [WILDCARD]
@ -25,13 +25,13 @@ error: Leaking async ops:
- 2 async operations to sleep for a duration were started in this test, but never completed. This is often caused by not cancelling a `setTimeout` or `setInterval` call. The operations were started here: - 2 async operations to sleep for a duration were started in this test, but never completed. This is often caused by not cancelling a `setTimeout` or `setInterval` call. The operations were started here:
at [WILDCARD] at [WILDCARD]
at setTimeout ([WILDCARD]) at setTimeout ([WILDCARD])
at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:4:3) at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:[WILDCARD])
at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:10:27 at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:10:27
at [WILDCARD] at [WILDCARD]
at [WILDCARD] at [WILDCARD]
at setTimeout ([WILDCARD]) at setTimeout ([WILDCARD])
at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:5:3) at test ([WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:[WILDCARD])
at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:10:27 at [WILDCARD]/testdata/test/ops_sanitizer_multiple_timeout_tests.ts:10:27
at [WILDCARD] at [WILDCARD]