1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-14 18:08:52 -05:00
denoland-deno/tests/testdata/test/steps/invalid_usage.ts
Matt Mastracci f5e46c9bf2
chore: move cli/tests/ -> tests/ (#22369)
This looks like a massive PR, but it's only a move from cli/tests ->
tests, and updates of relative paths for files.

This is the first step towards aggregate all of the integration test
files under tests/, which will lead to a set of integration tests that
can run without the CLI binary being built.

While we could leave these tests under `cli`, it would require us to
keep a more complex directory structure for the various test runners. In
addition, we have a lot of complexity to ignore various test files in
the `cli` project itself (cargo publish exclusion rules, autotests =
false, etc).

And finally, the `tests/` folder will eventually house the `test_ffi`,
`test_napi` and other testing code, reducing the size of the root repo
directory.

For easier review, the extremely large and noisy "move" is in the first
commit (with no changes -- just a move), while the remainder of the
changes to actual files is in the second commit.
2024-02-10 20:22:13 +00:00

118 lines
3 KiB
TypeScript

Deno.test("capturing", async (t) => {
let capturedContext!: Deno.TestContext;
await t.step("some step", (t) => {
capturedContext = t;
});
// this should error because the scope of the tester has already completed
await capturedContext.step("next step", () => {});
});
Deno.test("top level missing await", (t) => {
t.step("step", () => {
return new Promise(() => {});
});
});
Deno.test({
name: "inner missing await",
fn: async (t) => {
await t.step("step", (t) => {
t.step("inner", () => {
return new Promise((resolve) => setTimeout(resolve, 10));
});
});
await new Promise((resolve) => setTimeout(resolve, 10));
},
sanitizeResources: false,
sanitizeOps: false,
sanitizeExit: false,
});
Deno.test("parallel steps with sanitizers", async (t) => {
// not allowed because steps with sanitizers cannot be run in parallel
const step1Entered = Promise.withResolvers<void>();
const testFinished = Promise.withResolvers<void>();
t.step("step 1", async () => {
step1Entered.resolve();
await testFinished.promise;
});
await step1Entered.promise;
await t.step("step 2", () => {});
});
Deno.test("parallel steps when first has sanitizer", async (t) => {
const step1Entered = Promise.withResolvers<void>();
const step2Finished = Promise.withResolvers<void>();
const step1 = t.step({
name: "step 1",
fn: async () => {
step1Entered.resolve();
await step2Finished.promise;
},
});
await step1Entered.promise;
await t.step({
name: "step 2",
fn: () => {},
sanitizeOps: false,
sanitizeResources: false,
sanitizeExit: false,
});
step2Finished.resolve();
await step1;
});
Deno.test("parallel steps when second has sanitizer", async (t) => {
const step1Entered = Promise.withResolvers<void>();
const step2Finished = Promise.withResolvers<void>();
const step1 = t.step({
name: "step 1",
fn: async () => {
step1Entered.resolve();
await step2Finished.promise;
},
sanitizeOps: false,
sanitizeResources: false,
sanitizeExit: false,
});
await step1Entered.promise;
await t.step({
name: "step 2",
fn: async () => {
await new Promise((resolve) => setTimeout(resolve, 100));
},
});
step2Finished.resolve();
await step1;
});
Deno.test({
name: "parallel steps where only inner tests have sanitizers",
fn: async (t) => {
const step1Entered = Promise.withResolvers<void>();
const step2Finished = Promise.withResolvers<void>();
const step1 = t.step("step 1", async (t) => {
await t.step({
name: "step inner",
fn: async () => {
step1Entered.resolve();
await step2Finished.promise;
},
sanitizeOps: true,
});
});
await step1Entered.promise;
await t.step("step 2", async (t) => {
await t.step({
name: "step inner",
fn: () => {},
sanitizeOps: true,
});
});
step2Finished.resolve();
await step1;
},
sanitizeResources: false,
sanitizeOps: false,
sanitizeExit: false,
});