2021-01-12 02:13:41 +09:00
|
|
|
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
|
2020-01-24 22:15:31 +09:00
|
|
|
import {
|
|
|
|
assert,
|
|
|
|
assertEquals,
|
2020-03-03 18:22:53 +01:00
|
|
|
assertThrows,
|
2020-11-26 17:22:36 +01:00
|
|
|
deferred,
|
2021-06-25 10:44:14 +09:00
|
|
|
delay,
|
2020-09-27 06:22:32 -04:00
|
|
|
unitTest,
|
2020-01-24 22:15:31 +09:00
|
|
|
} from "./test_util.ts";
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(
|
2020-04-28 12:35:23 -04:00
|
|
|
{ ignore: Deno.build.os !== "windows" },
|
2021-08-05 13:08:58 +02:00
|
|
|
function signalsNotImplemented() {
|
2020-01-24 22:15:31 +09:00
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signal(1);
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.alarm(); // for SIGALRM
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.child(); // for SIGCHLD
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.hungup(); // for SIGHUP
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.interrupt(); // for SIGINT
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.io(); // for SIGIO
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.pipe(); // for SIGPIPE
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.quit(); // for SIGQUIT
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.terminate(); // for SIGTERM
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.userDefined1(); // for SIGUSR1
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.userDefined2(); // for SIGURS2
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.signals.windowChange(); // for SIGWINCH
|
|
|
|
},
|
|
|
|
Error,
|
2020-07-14 15:24:17 -04:00
|
|
|
"not implemented",
|
2020-01-24 22:15:31 +09:00
|
|
|
);
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
unitTest(
|
2020-04-28 12:35:23 -04:00
|
|
|
{ ignore: Deno.build.os === "windows", perms: { run: true, net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function signalStreamTest() {
|
2020-11-26 17:22:36 +01:00
|
|
|
const resolvable = deferred();
|
2020-01-24 22:15:31 +09:00
|
|
|
// This prevents the program from exiting.
|
|
|
|
const t = setInterval(() => {}, 1000);
|
|
|
|
|
|
|
|
let c = 0;
|
|
|
|
const sig = Deno.signal(Deno.Signal.SIGUSR1);
|
|
|
|
setTimeout(async () => {
|
2021-06-25 10:44:14 +09:00
|
|
|
await delay(20);
|
2020-01-24 22:15:31 +09:00
|
|
|
for (const _ of Array(3)) {
|
|
|
|
// Sends SIGUSR1 3 times.
|
|
|
|
Deno.kill(Deno.pid, Deno.Signal.SIGUSR1);
|
2021-06-25 10:44:14 +09:00
|
|
|
await delay(20);
|
2020-01-24 22:15:31 +09:00
|
|
|
}
|
|
|
|
sig.dispose();
|
2020-03-03 18:22:53 +01:00
|
|
|
resolvable.resolve();
|
2020-01-24 22:15:31 +09:00
|
|
|
});
|
|
|
|
|
|
|
|
for await (const _ of sig) {
|
|
|
|
c += 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
assertEquals(c, 3);
|
|
|
|
|
2020-03-03 18:22:53 +01:00
|
|
|
clearInterval(t);
|
|
|
|
await resolvable;
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
2020-01-24 22:15:31 +09:00
|
|
|
|
2021-06-25 13:15:35 +09:00
|
|
|
// This tests that pending op_signal_poll doesn't block the runtime from exiting the process.
|
|
|
|
unitTest(
|
|
|
|
{ ignore: Deno.build.os === "windows", perms: { run: true, read: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function signalStreamExitTest() {
|
2021-06-25 13:15:35 +09:00
|
|
|
const p = Deno.run({
|
|
|
|
cmd: [
|
|
|
|
Deno.execPath(),
|
|
|
|
"eval",
|
|
|
|
"--unstable",
|
|
|
|
"(async () => { for await (const _ of Deno.signals.io()) {} })()",
|
|
|
|
],
|
|
|
|
});
|
|
|
|
const res = await p.status();
|
|
|
|
assertEquals(res.code, 0);
|
|
|
|
p.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(
|
2020-04-28 12:35:23 -04:00
|
|
|
{ ignore: Deno.build.os === "windows", perms: { run: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function signalPromiseTest() {
|
2020-11-26 17:22:36 +01:00
|
|
|
const resolvable = deferred();
|
2020-03-03 18:22:53 +01:00
|
|
|
// This prevents the program from exiting.
|
|
|
|
const t = setInterval(() => {}, 1000);
|
2020-01-24 22:15:31 +09:00
|
|
|
|
2020-03-03 18:22:53 +01:00
|
|
|
const sig = Deno.signal(Deno.Signal.SIGUSR1);
|
|
|
|
setTimeout(() => {
|
|
|
|
Deno.kill(Deno.pid, Deno.Signal.SIGUSR1);
|
|
|
|
resolvable.resolve();
|
|
|
|
}, 20);
|
|
|
|
await sig;
|
|
|
|
sig.dispose();
|
2020-01-24 22:15:31 +09:00
|
|
|
|
2020-03-03 18:22:53 +01:00
|
|
|
clearInterval(t);
|
|
|
|
await resolvable;
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
2020-01-24 22:15:31 +09:00
|
|
|
|
2021-06-22 15:17:44 +09:00
|
|
|
// https://github.com/denoland/deno/issues/9806
|
|
|
|
unitTest(
|
|
|
|
{ ignore: Deno.build.os === "windows", perms: { run: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function signalPromiseTest2() {
|
2021-06-22 15:17:44 +09:00
|
|
|
const resolvable = deferred();
|
|
|
|
// This prevents the program from exiting.
|
|
|
|
const t = setInterval(() => {}, 1000);
|
|
|
|
|
|
|
|
let called = false;
|
|
|
|
const sig = Deno.signal(Deno.Signal.SIGUSR1);
|
|
|
|
sig.then(() => {
|
|
|
|
called = true;
|
|
|
|
});
|
|
|
|
setTimeout(() => {
|
|
|
|
sig.dispose();
|
|
|
|
setTimeout(() => {
|
|
|
|
resolvable.resolve();
|
|
|
|
}, 10);
|
|
|
|
}, 10);
|
|
|
|
|
|
|
|
clearInterval(t);
|
|
|
|
await resolvable;
|
|
|
|
|
|
|
|
// Promise callback is not called because it didn't get
|
|
|
|
// the corresponding signal.
|
|
|
|
assert(!called);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(
|
2020-04-28 12:35:23 -04:00
|
|
|
{ ignore: Deno.build.os === "windows", perms: { run: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
function signalShorthandsTest() {
|
2020-01-24 22:15:31 +09:00
|
|
|
let s: Deno.SignalStream;
|
|
|
|
s = Deno.signals.alarm(); // for SIGALRM
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.child(); // for SIGCHLD
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.hungup(); // for SIGHUP
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.interrupt(); // for SIGINT
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.io(); // for SIGIO
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.pipe(); // for SIGPIPE
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.quit(); // for SIGQUIT
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.terminate(); // for SIGTERM
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.userDefined1(); // for SIGUSR1
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.userDefined2(); // for SIGURS2
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
|
|
|
s = Deno.signals.windowChange(); // for SIGWINCH
|
|
|
|
assert(s instanceof Deno.SignalStream);
|
|
|
|
s.dispose();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|