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:
parent
082f8128b8
commit
e23fc6d88c
7 changed files with 64 additions and 57 deletions
12
Cargo.lock
generated
12
Cargo.lock
generated
|
@ -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",
|
||||||
|
|
|
@ -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"
|
||||||
|
|
55
cli/build.rs
55
cli/build.rs
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
|
@ -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] },
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -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()),
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue