2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2020-03-10 16:38:02 +01:00
|
|
|
import {
|
|
|
|
assert,
|
|
|
|
assertEquals,
|
2020-09-27 06:22:32 -04:00
|
|
|
assertNotEquals,
|
2021-09-22 21:21:11 +08:00
|
|
|
assertRejects,
|
2020-06-25 06:57:08 +08:00
|
|
|
assertThrows,
|
2021-06-25 10:44:14 +09:00
|
|
|
delay,
|
2022-03-23 12:04:20 +09:00
|
|
|
execCode,
|
2022-12-02 12:41:52 -05:00
|
|
|
execCode2,
|
2023-10-04 11:37:39 +09:00
|
|
|
tmpUnixSocketPath,
|
2020-03-10 16:38:02 +01:00
|
|
|
} from "./test_util.ts";
|
2018-10-03 23:58:29 -04:00
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
// Since these tests may run in parallel, ensure this port is unique to this file
|
|
|
|
const listenPort = 4503;
|
|
|
|
const listenPort2 = 4504;
|
|
|
|
|
2021-08-16 16:15:00 +02:00
|
|
|
let isCI: boolean;
|
|
|
|
try {
|
|
|
|
isCI = Deno.env.get("CI") !== undefined;
|
|
|
|
} catch {
|
|
|
|
isCI = true;
|
|
|
|
}
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test({ permissions: { net: true } }, function netTcpListenClose() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ hostname: "127.0.0.1", port: listenPort });
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(listener.addr.transport === "tcp");
|
2020-01-18 21:49:55 +01:00
|
|
|
assertEquals(listener.addr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(listener.addr.port, listenPort);
|
2020-06-09 00:24:51 +08:00
|
|
|
assertNotEquals(listener.rid, 0);
|
2018-10-03 23:58:29 -04:00
|
|
|
listener.close();
|
|
|
|
});
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2020-03-04 17:31:14 +01:00
|
|
|
{
|
2021-09-23 07:50:50 +08:00
|
|
|
permissions: { net: true },
|
2020-03-04 17:31:14 +01:00
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
function netUdpListenClose() {
|
2020-04-28 21:46:39 +02:00
|
|
|
const socket = Deno.listenDatagram({
|
2020-03-04 17:31:14 +01:00
|
|
|
hostname: "127.0.0.1",
|
2023-05-22 13:35:59 -06:00
|
|
|
port: listenPort,
|
2020-03-29 04:03:49 +11:00
|
|
|
transport: "udp",
|
2020-03-04 17:31:14 +01:00
|
|
|
});
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(socket.addr.transport === "udp");
|
2020-03-04 17:31:14 +01:00
|
|
|
assertEquals(socket.addr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(socket.addr.port, listenPort);
|
2020-03-04 17:31:14 +01:00
|
|
|
socket.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
2019-01-15 17:36:51 -08:00
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
function netUnixListenClose() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-03-23 22:02:51 +00:00
|
|
|
const socket = Deno.listen({
|
2020-04-28 21:07:59 +04:30
|
|
|
path: filePath,
|
2020-03-29 04:03:49 +11:00
|
|
|
transport: "unix",
|
2020-03-23 22:02:51 +00:00
|
|
|
});
|
|
|
|
assert(socket.addr.transport === "unix");
|
2020-04-28 21:07:59 +04:30
|
|
|
assertEquals(socket.addr.path, filePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
socket.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
function netUnixPacketListenClose() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-04-28 21:46:39 +02:00
|
|
|
const socket = Deno.listenDatagram({
|
2020-04-28 21:07:59 +04:30
|
|
|
path: filePath,
|
2020-03-29 04:03:49 +11:00
|
|
|
transport: "unixpacket",
|
2020-03-23 22:02:51 +00:00
|
|
|
});
|
|
|
|
assert(socket.addr.transport === "unixpacket");
|
2020-04-28 21:07:59 +04:30
|
|
|
assertEquals(socket.addr.path, filePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
socket.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: false },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
function netUnixListenWritePermission() {
|
2020-11-27 15:02:25 -05:00
|
|
|
assertThrows(() => {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-11-27 13:43:39 -05:00
|
|
|
const socket = Deno.listen({
|
|
|
|
path: filePath,
|
|
|
|
transport: "unix",
|
|
|
|
});
|
|
|
|
assert(socket.addr.transport === "unix");
|
|
|
|
assertEquals(socket.addr.path, filePath);
|
|
|
|
socket.close();
|
2020-11-27 15:02:25 -05:00
|
|
|
}, Deno.errors.PermissionDenied);
|
2020-11-27 13:43:39 -05:00
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: false },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
function netUnixPacketListenWritePermission() {
|
2020-11-27 15:02:25 -05:00
|
|
|
assertThrows(() => {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-11-27 13:43:39 -05:00
|
|
|
const socket = Deno.listenDatagram({
|
|
|
|
path: filePath,
|
|
|
|
transport: "unixpacket",
|
|
|
|
});
|
|
|
|
assert(socket.addr.transport === "unixpacket");
|
|
|
|
assertEquals(socket.addr.path, filePath);
|
|
|
|
socket.close();
|
2020-11-27 15:02:25 -05:00
|
|
|
}, Deno.errors.PermissionDenied);
|
2020-11-27 13:43:39 -05:00
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2020-03-04 17:31:14 +01:00
|
|
|
{
|
2021-09-23 07:50:50 +08:00
|
|
|
permissions: { net: true },
|
2020-03-04 17:31:14 +01:00
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netTcpCloseWhileAccept() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2020-03-04 17:31:14 +01:00
|
|
|
const p = listener.accept();
|
|
|
|
listener.close();
|
2021-10-09 22:37:19 +02:00
|
|
|
// TODO(piscisaureus): the error type should be `Interrupted` here, which
|
|
|
|
// gets thrown, but then ext/net catches it and rethrows `BadResource`.
|
2021-09-22 21:21:11 +08:00
|
|
|
await assertRejects(
|
2021-10-09 22:37:19 +02:00
|
|
|
() => p,
|
2020-06-25 06:57:08 +08:00
|
|
|
Deno.errors.BadResource,
|
2020-07-14 15:24:17 -04:00
|
|
|
"Listener has been closed",
|
2020-06-25 06:57:08 +08:00
|
|
|
);
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixCloseWhileAccept() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-03-23 22:02:51 +00:00
|
|
|
const listener = Deno.listen({
|
2020-04-28 21:07:59 +04:30
|
|
|
path: filePath,
|
2020-03-29 04:03:49 +11:00
|
|
|
transport: "unix",
|
2020-03-23 22:02:51 +00:00
|
|
|
});
|
|
|
|
const p = listener.accept();
|
|
|
|
listener.close();
|
2021-09-22 21:21:11 +08:00
|
|
|
await assertRejects(
|
2021-10-09 22:37:19 +02:00
|
|
|
() => p,
|
2021-12-14 23:27:04 +01:00
|
|
|
Deno.errors.BadResource,
|
|
|
|
"Listener has been closed",
|
2020-06-25 06:57:08 +08:00
|
|
|
);
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netTcpConcurrentAccept() {
|
2022-02-16 16:51:32 +01:00
|
|
|
const listener = Deno.listen({ port: 4510 });
|
2020-03-04 17:31:14 +01:00
|
|
|
let acceptErrCount = 0;
|
2021-08-05 13:08:58 +02:00
|
|
|
const checkErr = (e: Error) => {
|
2020-03-04 17:31:14 +01:00
|
|
|
if (e.message === "Listener has been closed") {
|
|
|
|
assertEquals(acceptErrCount, 1);
|
|
|
|
} else if (e.message === "Another accept task is ongoing") {
|
|
|
|
acceptErrCount++;
|
|
|
|
} else {
|
|
|
|
throw new Error("Unexpected error message");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
const p = listener.accept().catch(checkErr);
|
|
|
|
const p1 = listener.accept().catch(checkErr);
|
|
|
|
await Promise.race([p, p1]);
|
|
|
|
listener.close();
|
|
|
|
await Promise.all([p, p1]);
|
|
|
|
assertEquals(acceptErrCount, 1);
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
2019-01-15 17:36:51 -08:00
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-10-09 22:37:19 +02:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixConcurrentAccept() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-04-28 21:07:59 +04:30
|
|
|
const listener = Deno.listen({ transport: "unix", path: filePath });
|
2020-03-23 22:02:51 +00:00
|
|
|
let acceptErrCount = 0;
|
2021-08-05 13:08:58 +02:00
|
|
|
const checkErr = (e: Error) => {
|
2021-12-14 23:27:04 +01:00
|
|
|
if (e.message === "Listener has been closed") {
|
2020-03-23 22:02:51 +00:00
|
|
|
assertEquals(acceptErrCount, 1);
|
2021-10-09 22:37:19 +02:00
|
|
|
} else if (e instanceof Deno.errors.Busy) { // "Listener already in use"
|
2020-03-23 22:02:51 +00:00
|
|
|
acceptErrCount++;
|
|
|
|
} else {
|
2021-10-09 22:37:19 +02:00
|
|
|
throw e;
|
2020-03-23 22:02:51 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
const p = listener.accept().catch(checkErr);
|
|
|
|
const p1 = listener.accept().catch(checkErr);
|
|
|
|
await Promise.race([p, p1]);
|
|
|
|
listener.close();
|
2021-10-09 22:37:19 +02:00
|
|
|
await Promise.all([p, p1]);
|
2020-03-23 22:02:51 +00:00
|
|
|
assertEquals(acceptErrCount, 1);
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test({ permissions: { net: true } }, async function netTcpDialListen() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2019-04-21 16:40:10 -04:00
|
|
|
listener.accept().then(
|
2021-08-05 13:08:58 +02:00
|
|
|
async (conn) => {
|
2019-08-27 17:35:32 +02:00
|
|
|
assert(conn.remoteAddr != null);
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(conn.localAddr.transport === "tcp");
|
2020-01-18 21:49:55 +01:00
|
|
|
assertEquals(conn.localAddr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(conn.localAddr.port, listenPort);
|
2019-04-21 16:40:10 -04:00
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
conn.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2019-04-21 16:40:10 -04:00
|
|
|
);
|
2020-03-24 17:24:58 +01:00
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ hostname: "127.0.0.1", port: listenPort });
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(conn.remoteAddr.transport === "tcp");
|
2020-01-18 21:49:55 +01:00
|
|
|
assertEquals(conn.remoteAddr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(conn.remoteAddr.port, listenPort);
|
2019-08-27 17:35:32 +02:00
|
|
|
assert(conn.localAddr != null);
|
2018-10-03 23:58:29 -04:00
|
|
|
const buf = new Uint8Array(1024);
|
|
|
|
const readResult = await conn.read(buf);
|
2019-07-06 23:16:03 +09:00
|
|
|
assertEquals(3, readResult);
|
2019-05-01 16:58:09 -04:00
|
|
|
assertEquals(1, buf[0]);
|
|
|
|
assertEquals(2, buf[1]);
|
|
|
|
assertEquals(3, buf[2]);
|
|
|
|
assert(conn.rid > 0);
|
|
|
|
|
2020-04-28 17:40:43 +01:00
|
|
|
assert(readResult !== null);
|
2019-05-01 16:58:09 -04:00
|
|
|
|
|
|
|
const readResult2 = await conn.read(buf);
|
2020-04-28 17:40:43 +01:00
|
|
|
assertEquals(readResult2, null);
|
2019-05-01 16:58:09 -04:00
|
|
|
|
|
|
|
listener.close();
|
|
|
|
conn.close();
|
|
|
|
});
|
|
|
|
|
2022-01-31 22:36:54 +07:00
|
|
|
Deno.test({ permissions: { net: true } }, async function netTcpSetNoDelay() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2022-01-31 22:36:54 +07:00
|
|
|
listener.accept().then(
|
|
|
|
async (conn) => {
|
|
|
|
assert(conn.remoteAddr != null);
|
|
|
|
assert(conn.localAddr.transport === "tcp");
|
|
|
|
assertEquals(conn.localAddr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(conn.localAddr.port, listenPort);
|
2022-01-31 22:36:54 +07:00
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
conn.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ hostname: "127.0.0.1", port: listenPort });
|
2022-01-31 22:36:54 +07:00
|
|
|
conn.setNoDelay(true);
|
|
|
|
assert(conn.remoteAddr.transport === "tcp");
|
|
|
|
assertEquals(conn.remoteAddr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(conn.remoteAddr.port, listenPort);
|
2022-01-31 22:36:54 +07:00
|
|
|
assert(conn.localAddr != null);
|
|
|
|
const buf = new Uint8Array(1024);
|
|
|
|
const readResult = await conn.read(buf);
|
|
|
|
assertEquals(3, readResult);
|
|
|
|
assertEquals(1, buf[0]);
|
|
|
|
assertEquals(2, buf[1]);
|
|
|
|
assertEquals(3, buf[2]);
|
|
|
|
assert(conn.rid > 0);
|
|
|
|
|
|
|
|
assert(readResult !== null);
|
|
|
|
|
|
|
|
const readResult2 = await conn.read(buf);
|
|
|
|
assertEquals(readResult2, null);
|
|
|
|
|
|
|
|
listener.close();
|
|
|
|
conn.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
Deno.test({ permissions: { net: true } }, async function netTcpSetKeepAlive() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2022-01-31 22:36:54 +07:00
|
|
|
listener.accept().then(
|
|
|
|
async (conn) => {
|
|
|
|
assert(conn.remoteAddr != null);
|
|
|
|
assert(conn.localAddr.transport === "tcp");
|
|
|
|
assertEquals(conn.localAddr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(conn.localAddr.port, listenPort);
|
2022-01-31 22:36:54 +07:00
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
conn.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ hostname: "127.0.0.1", port: listenPort });
|
2022-01-31 22:36:54 +07:00
|
|
|
conn.setKeepAlive(true);
|
|
|
|
assert(conn.remoteAddr.transport === "tcp");
|
|
|
|
assertEquals(conn.remoteAddr.hostname, "127.0.0.1");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(conn.remoteAddr.port, listenPort);
|
2022-01-31 22:36:54 +07:00
|
|
|
assert(conn.localAddr != null);
|
|
|
|
const buf = new Uint8Array(1024);
|
|
|
|
const readResult = await conn.read(buf);
|
|
|
|
assertEquals(3, readResult);
|
|
|
|
assertEquals(1, buf[0]);
|
|
|
|
assertEquals(2, buf[1]);
|
|
|
|
assertEquals(3, buf[2]);
|
|
|
|
assert(conn.rid > 0);
|
|
|
|
|
|
|
|
assert(readResult !== null);
|
|
|
|
|
|
|
|
const readResult2 = await conn.read(buf);
|
|
|
|
assertEquals(readResult2, null);
|
|
|
|
|
|
|
|
listener.close();
|
|
|
|
conn.close();
|
|
|
|
});
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixDialListen() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-04-28 21:07:59 +04:30
|
|
|
const listener = Deno.listen({ path: filePath, transport: "unix" });
|
2020-03-23 22:02:51 +00:00
|
|
|
listener.accept().then(
|
2021-08-05 13:08:58 +02:00
|
|
|
async (conn) => {
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(conn.remoteAddr != null);
|
|
|
|
assert(conn.localAddr.transport === "unix");
|
2020-04-28 21:07:59 +04:30
|
|
|
assertEquals(conn.localAddr.path, filePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
conn.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
2020-04-28 21:07:59 +04:30
|
|
|
const conn = await Deno.connect({ path: filePath, transport: "unix" });
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(conn.remoteAddr.transport === "unix");
|
2020-04-28 21:07:59 +04:30
|
|
|
assertEquals(conn.remoteAddr.path, filePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(conn.remoteAddr != null);
|
|
|
|
const buf = new Uint8Array(1024);
|
|
|
|
const readResult = await conn.read(buf);
|
|
|
|
assertEquals(3, readResult);
|
|
|
|
assertEquals(1, buf[0]);
|
|
|
|
assertEquals(2, buf[1]);
|
|
|
|
assertEquals(3, buf[2]);
|
|
|
|
assert(conn.rid > 0);
|
|
|
|
|
2020-04-28 17:40:43 +01:00
|
|
|
assert(readResult !== null);
|
2020-03-23 22:02:51 +00:00
|
|
|
|
|
|
|
const readResult2 = await conn.read(buf);
|
2020-04-28 17:40:43 +01:00
|
|
|
assertEquals(readResult2, null);
|
2020-03-23 22:02:51 +00:00
|
|
|
|
|
|
|
listener.close();
|
|
|
|
conn.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUdpSendReceive() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const alice = Deno.listenDatagram({ port: listenPort, transport: "udp" });
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(alice.addr.transport === "udp");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(alice.addr.port, listenPort);
|
2020-03-23 22:02:51 +00:00
|
|
|
assertEquals(alice.addr.hostname, "127.0.0.1");
|
2020-02-21 17:26:54 +01:00
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const bob = Deno.listenDatagram({ port: listenPort2, transport: "udp" });
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(bob.addr.transport === "udp");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(bob.addr.port, listenPort2);
|
2020-03-23 22:02:51 +00:00
|
|
|
assertEquals(bob.addr.hostname, "127.0.0.1");
|
2020-02-21 17:26:54 +01:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
const sent = new Uint8Array([1, 2, 3]);
|
2020-06-13 22:14:31 +08:00
|
|
|
const byteLength = await alice.send(sent, bob.addr);
|
|
|
|
|
|
|
|
assertEquals(byteLength, 3);
|
2020-02-21 17:26:54 +01:00
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
const [recvd, remote] = await bob.receive();
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(remote.transport === "udp");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(remote.port, listenPort);
|
2020-03-04 17:31:14 +01:00
|
|
|
assertEquals(recvd.length, 3);
|
|
|
|
assertEquals(1, recvd[0]);
|
|
|
|
assertEquals(2, recvd[1]);
|
|
|
|
assertEquals(3, recvd[2]);
|
|
|
|
alice.close();
|
|
|
|
bob.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-04 17:31:14 +01:00
|
|
|
);
|
2019-11-09 19:40:22 +00:00
|
|
|
|
2021-11-29 04:14:46 -06:00
|
|
|
Deno.test(
|
2022-03-20 22:46:39 +01:00
|
|
|
{ permissions: { net: true }, ignore: true },
|
2021-11-29 04:14:46 -06:00
|
|
|
async function netUdpSendReceiveBroadcast() {
|
|
|
|
// Must bind sender to an address that can send to the broadcast address on MacOS.
|
|
|
|
// Macos will give us error 49 when sending the broadcast packet if we omit hostname here.
|
|
|
|
const alice = Deno.listenDatagram({
|
2023-05-22 13:35:59 -06:00
|
|
|
port: listenPort,
|
2021-11-29 04:14:46 -06:00
|
|
|
transport: "udp",
|
|
|
|
hostname: "0.0.0.0",
|
|
|
|
});
|
|
|
|
|
|
|
|
const bob = Deno.listenDatagram({
|
2023-05-22 13:35:59 -06:00
|
|
|
port: listenPort,
|
2021-11-29 04:14:46 -06:00
|
|
|
transport: "udp",
|
|
|
|
hostname: "0.0.0.0",
|
|
|
|
});
|
|
|
|
assert(bob.addr.transport === "udp");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(bob.addr.port, listenPort);
|
2021-11-29 04:14:46 -06:00
|
|
|
assertEquals(bob.addr.hostname, "0.0.0.0");
|
|
|
|
|
|
|
|
const broadcastAddr = { ...bob.addr, hostname: "255.255.255.255" };
|
|
|
|
|
|
|
|
const sent = new Uint8Array([1, 2, 3]);
|
|
|
|
const byteLength = await alice.send(sent, broadcastAddr);
|
|
|
|
|
|
|
|
assertEquals(byteLength, 3);
|
|
|
|
const [recvd, remote] = await bob.receive();
|
|
|
|
assert(remote.transport === "udp");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(remote.port, listenPort);
|
2021-11-29 04:14:46 -06:00
|
|
|
assertEquals(recvd.length, 3);
|
|
|
|
assertEquals(1, recvd[0]);
|
|
|
|
assertEquals(2, recvd[1]);
|
|
|
|
assertEquals(3, recvd[2]);
|
|
|
|
alice.close();
|
|
|
|
bob.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2023-03-20 21:27:00 +00:00
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true }, ignore: true },
|
|
|
|
async function netUdpMulticastV4() {
|
|
|
|
const listener = Deno.listenDatagram({
|
|
|
|
hostname: "0.0.0.0",
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const membership = await listener.joinMulticastV4(
|
|
|
|
"224.0.0.251",
|
|
|
|
"127.0.0.1",
|
|
|
|
);
|
|
|
|
|
|
|
|
membership.setLoopback(true);
|
|
|
|
membership.setLoopback(false);
|
|
|
|
membership.setTTL(50);
|
|
|
|
membership.leave();
|
|
|
|
listener.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true }, ignore: true },
|
|
|
|
async function netUdpMulticastV6() {
|
|
|
|
const listener = Deno.listenDatagram({
|
|
|
|
hostname: "::",
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const membership = await listener.joinMulticastV6(
|
|
|
|
"ff02::fb",
|
|
|
|
1,
|
|
|
|
);
|
|
|
|
|
|
|
|
membership.setLoopback(true);
|
|
|
|
membership.setLoopback(false);
|
|
|
|
membership.leave();
|
|
|
|
listener.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true }, ignore: true },
|
|
|
|
async function netUdpSendReceiveMulticastv4() {
|
|
|
|
const alice = Deno.listenDatagram({
|
|
|
|
hostname: "0.0.0.0",
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: true,
|
|
|
|
loopback: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const bob = Deno.listenDatagram({
|
|
|
|
hostname: "0.0.0.0",
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const aliceMembership = await alice.joinMulticastV4(
|
|
|
|
"224.0.0.1",
|
|
|
|
"0.0.0.0",
|
|
|
|
);
|
|
|
|
|
|
|
|
const bobMembership = await bob.joinMulticastV4("224.0.0.1", "0.0.0.0");
|
|
|
|
|
|
|
|
const sent = new Uint8Array([1, 2, 3]);
|
|
|
|
|
|
|
|
await alice.send(sent, {
|
|
|
|
hostname: "224.0.0.1",
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
});
|
|
|
|
|
|
|
|
const [recvd, remote] = await bob.receive();
|
|
|
|
|
|
|
|
assert(remote.transport === "udp");
|
|
|
|
assertEquals(remote.port, 5353);
|
|
|
|
assertEquals(recvd.length, 3);
|
|
|
|
assertEquals(1, recvd[0]);
|
|
|
|
assertEquals(2, recvd[1]);
|
|
|
|
assertEquals(3, recvd[2]);
|
|
|
|
|
|
|
|
aliceMembership.leave();
|
|
|
|
bobMembership.leave();
|
|
|
|
|
|
|
|
alice.close();
|
|
|
|
bob.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true }, ignore: true },
|
|
|
|
async function netUdpMulticastLoopbackOption() {
|
|
|
|
// Must bind sender to an address that can send to the broadcast address on MacOS.
|
|
|
|
// Macos will give us error 49 when sending the broadcast packet if we omit hostname here.
|
|
|
|
const listener = Deno.listenDatagram({
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
hostname: "0.0.0.0",
|
|
|
|
loopback: true,
|
|
|
|
reuseAddress: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const membership = await listener.joinMulticastV4(
|
|
|
|
"224.0.0.1",
|
|
|
|
"0.0.0.0",
|
|
|
|
);
|
|
|
|
|
|
|
|
// await membership.setLoopback(true);
|
|
|
|
|
|
|
|
const sent = new Uint8Array([1, 2, 3]);
|
|
|
|
const byteLength = await listener.send(sent, {
|
|
|
|
hostname: "224.0.0.1",
|
|
|
|
port: 5353,
|
|
|
|
transport: "udp",
|
|
|
|
});
|
|
|
|
|
|
|
|
assertEquals(byteLength, 3);
|
|
|
|
const [recvd, remote] = await listener.receive();
|
|
|
|
assert(remote.transport === "udp");
|
|
|
|
assertEquals(remote.port, 5353);
|
|
|
|
assertEquals(recvd.length, 3);
|
|
|
|
assertEquals(1, recvd[0]);
|
|
|
|
assertEquals(2, recvd[1]);
|
|
|
|
assertEquals(3, recvd[2]);
|
|
|
|
membership.leave();
|
|
|
|
listener.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUdpConcurrentSendReceive() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const socket = Deno.listenDatagram({ port: listenPort, transport: "udp" });
|
2020-12-16 17:14:12 +01:00
|
|
|
assert(socket.addr.transport === "udp");
|
2023-05-22 13:35:59 -06:00
|
|
|
assertEquals(socket.addr.port, listenPort);
|
2020-12-16 17:14:12 +01:00
|
|
|
assertEquals(socket.addr.hostname, "127.0.0.1");
|
|
|
|
|
|
|
|
const recvPromise = socket.receive();
|
|
|
|
|
|
|
|
const sendBuf = new Uint8Array([1, 2, 3]);
|
|
|
|
const sendLen = await socket.send(sendBuf, socket.addr);
|
|
|
|
assertEquals(sendLen, 3);
|
|
|
|
|
2021-04-09 23:35:29 +02:00
|
|
|
const [recvBuf, _recvAddr] = await recvPromise;
|
2020-12-16 17:14:12 +01:00
|
|
|
assertEquals(recvBuf.length, 3);
|
|
|
|
assertEquals(1, recvBuf[0]);
|
|
|
|
assertEquals(2, recvBuf[1]);
|
|
|
|
assertEquals(3, recvBuf[2]);
|
|
|
|
|
|
|
|
socket.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUdpBorrowMutError() {
|
2020-06-10 11:26:28 -04:00
|
|
|
const socket = Deno.listenDatagram({
|
2023-05-22 13:35:59 -06:00
|
|
|
port: listenPort,
|
2020-06-10 11:26:28 -04:00
|
|
|
transport: "udp",
|
|
|
|
});
|
|
|
|
// Panic happened on second send: BorrowMutError
|
|
|
|
const a = socket.send(new Uint8Array(), socket.addr);
|
|
|
|
const b = socket.send(new Uint8Array(), socket.addr);
|
|
|
|
await Promise.all([a, b]);
|
|
|
|
socket.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-06-10 11:26:28 -04:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixPacketSendReceive() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const aliceFilePath = tmpUnixSocketPath();
|
2020-04-28 21:46:39 +02:00
|
|
|
const alice = Deno.listenDatagram({
|
2022-10-24 00:45:45 +02:00
|
|
|
path: aliceFilePath,
|
2020-04-28 21:46:39 +02:00
|
|
|
transport: "unixpacket",
|
|
|
|
});
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(alice.addr.transport === "unixpacket");
|
2022-10-24 00:45:45 +02:00
|
|
|
assertEquals(alice.addr.path, aliceFilePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
|
2022-10-24 00:45:45 +02:00
|
|
|
const bobFilePath = tmpUnixSocketPath();
|
2020-04-28 21:46:39 +02:00
|
|
|
const bob = Deno.listenDatagram({
|
2022-10-24 00:45:45 +02:00
|
|
|
path: bobFilePath,
|
2020-04-28 21:46:39 +02:00
|
|
|
transport: "unixpacket",
|
|
|
|
});
|
2020-03-23 22:02:51 +00:00
|
|
|
assert(bob.addr.transport === "unixpacket");
|
2022-10-24 00:45:45 +02:00
|
|
|
assertEquals(bob.addr.path, bobFilePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
|
|
|
|
const sent = new Uint8Array([1, 2, 3]);
|
2020-06-15 18:20:45 +02:00
|
|
|
const byteLength = await alice.send(sent, bob.addr);
|
|
|
|
assertEquals(byteLength, 3);
|
2020-03-23 22:02:51 +00:00
|
|
|
|
|
|
|
const [recvd, remote] = await bob.receive();
|
|
|
|
assert(remote.transport === "unixpacket");
|
2022-10-24 00:45:45 +02:00
|
|
|
assertEquals(remote.path, aliceFilePath);
|
2020-03-23 22:02:51 +00:00
|
|
|
assertEquals(recvd.length, 3);
|
|
|
|
assertEquals(1, recvd[0]);
|
|
|
|
assertEquals(2, recvd[1]);
|
|
|
|
assertEquals(3, recvd[2]);
|
|
|
|
alice.close();
|
|
|
|
bob.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2022-10-24 00:45:45 +02:00
|
|
|
// TODO(lucacasonato): support concurrent reads and writes on unixpacket sockets
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ ignore: true, permissions: { read: true, write: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixPacketConcurrentSendReceive() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-12-16 17:14:12 +01:00
|
|
|
const socket = Deno.listenDatagram({
|
|
|
|
path: filePath,
|
|
|
|
transport: "unixpacket",
|
|
|
|
});
|
|
|
|
assert(socket.addr.transport === "unixpacket");
|
|
|
|
assertEquals(socket.addr.path, filePath);
|
|
|
|
|
|
|
|
const recvPromise = socket.receive();
|
|
|
|
|
|
|
|
const sendBuf = new Uint8Array([1, 2, 3]);
|
|
|
|
const sendLen = await socket.send(sendBuf, socket.addr);
|
|
|
|
assertEquals(sendLen, 3);
|
|
|
|
|
2021-04-09 23:35:29 +02:00
|
|
|
const [recvBuf, _recvAddr] = await recvPromise;
|
2020-12-16 17:14:12 +01:00
|
|
|
assertEquals(recvBuf.length, 3);
|
|
|
|
assertEquals(1, recvBuf[0]);
|
|
|
|
assertEquals(2, recvBuf[1]);
|
|
|
|
assertEquals(3, recvBuf[2]);
|
|
|
|
|
|
|
|
socket.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netTcpListenIteratorBreakClosesResource() {
|
|
|
|
async function iterate(listener: Deno.Listener) {
|
2020-04-29 01:08:02 +02:00
|
|
|
let i = 0;
|
|
|
|
|
|
|
|
for await (const conn of listener) {
|
|
|
|
conn.close();
|
|
|
|
i++;
|
|
|
|
|
|
|
|
if (i > 1) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const addr = { hostname: "127.0.0.1", port: 8888 };
|
|
|
|
const listener = Deno.listen(addr);
|
2021-08-25 16:04:14 -04:00
|
|
|
const iteratePromise = iterate(listener);
|
2020-04-29 01:08:02 +02:00
|
|
|
|
2021-06-25 10:44:14 +09:00
|
|
|
await delay(100);
|
2020-04-29 01:08:02 +02:00
|
|
|
const conn1 = await Deno.connect(addr);
|
|
|
|
conn1.close();
|
|
|
|
const conn2 = await Deno.connect(addr);
|
|
|
|
conn2.close();
|
|
|
|
|
2021-08-25 16:04:14 -04:00
|
|
|
await iteratePromise;
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-04-29 01:08:02 +02:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netTcpListenCloseWhileIterating() {
|
2021-07-31 21:10:19 -04:00
|
|
|
const listener = Deno.listen({ port: 8001 });
|
2020-02-21 17:26:54 +01:00
|
|
|
const nextWhileClosing = listener[Symbol.asyncIterator]().next();
|
|
|
|
listener.close();
|
|
|
|
assertEquals(await nextWhileClosing, { value: undefined, done: true });
|
|
|
|
|
|
|
|
const nextAfterClosing = listener[Symbol.asyncIterator]().next();
|
|
|
|
assertEquals(await nextAfterClosing, { value: undefined, done: true });
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-02-21 17:26:54 +01:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUdpListenCloseWhileIterating() {
|
2021-01-25 16:02:03 +01:00
|
|
|
const socket = Deno.listenDatagram({ port: 8000, transport: "udp" });
|
2020-02-21 17:26:54 +01:00
|
|
|
const nextWhileClosing = socket[Symbol.asyncIterator]().next();
|
|
|
|
socket.close();
|
|
|
|
assertEquals(await nextWhileClosing, { value: undefined, done: true });
|
|
|
|
|
|
|
|
const nextAfterClosing = socket[Symbol.asyncIterator]().next();
|
|
|
|
assertEquals(await nextAfterClosing, { value: undefined, done: true });
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-02-21 17:26:54 +01:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixListenCloseWhileIterating() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-04-28 21:07:59 +04:30
|
|
|
const socket = Deno.listen({ path: filePath, transport: "unix" });
|
2020-03-23 22:02:51 +00:00
|
|
|
const nextWhileClosing = socket[Symbol.asyncIterator]().next();
|
|
|
|
socket.close();
|
|
|
|
assertEquals(await nextWhileClosing, { value: undefined, done: true });
|
|
|
|
|
|
|
|
const nextAfterClosing = socket[Symbol.asyncIterator]().next();
|
|
|
|
assertEquals(await nextAfterClosing, { value: undefined, done: true });
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-09-23 07:50:50 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netUnixPacketListenCloseWhileIterating() {
|
2022-10-24 00:45:45 +02:00
|
|
|
const filePath = tmpUnixSocketPath();
|
2020-04-28 21:46:39 +02:00
|
|
|
const socket = Deno.listenDatagram({
|
|
|
|
path: filePath,
|
|
|
|
transport: "unixpacket",
|
|
|
|
});
|
2020-03-23 22:02:51 +00:00
|
|
|
const nextWhileClosing = socket[Symbol.asyncIterator]().next();
|
|
|
|
socket.close();
|
|
|
|
assertEquals(await nextWhileClosing, { value: undefined, done: true });
|
|
|
|
|
|
|
|
const nextAfterClosing = socket[Symbol.asyncIterator]().next();
|
|
|
|
assertEquals(await nextAfterClosing, { value: undefined, done: true });
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-23 22:02:51 +00:00
|
|
|
);
|
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-10-09 22:37:19 +02:00
|
|
|
{ permissions: { net: true } },
|
2021-08-05 13:08:58 +02:00
|
|
|
async function netListenAsyncIterator() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const addr = { hostname: "127.0.0.1", port: listenPort };
|
2020-03-10 16:38:02 +01:00
|
|
|
const listener = Deno.listen(addr);
|
2021-08-05 13:08:58 +02:00
|
|
|
const runAsyncIterator = async () => {
|
2020-03-10 16:38:02 +01:00
|
|
|
for await (const conn of listener) {
|
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
conn.close();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
runAsyncIterator();
|
|
|
|
const conn = await Deno.connect(addr);
|
|
|
|
const buf = new Uint8Array(1024);
|
|
|
|
const readResult = await conn.read(buf);
|
|
|
|
assertEquals(3, readResult);
|
|
|
|
assertEquals(1, buf[0]);
|
|
|
|
assertEquals(2, buf[1]);
|
|
|
|
assertEquals(3, buf[2]);
|
|
|
|
assert(conn.rid > 0);
|
2018-10-03 23:58:29 -04:00
|
|
|
|
2020-04-28 17:40:43 +01:00
|
|
|
assert(readResult !== null);
|
2018-10-03 23:58:29 -04:00
|
|
|
|
2020-03-10 16:38:02 +01:00
|
|
|
const readResult2 = await conn.read(buf);
|
2020-04-28 17:40:43 +01:00
|
|
|
assertEquals(readResult2, null);
|
2018-10-03 23:58:29 -04:00
|
|
|
|
2020-03-10 16:38:02 +01:00
|
|
|
listener.close();
|
|
|
|
conn.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-10 16:38:02 +01:00
|
|
|
);
|
2018-10-05 09:16:24 -07:00
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2020-03-10 16:38:02 +01:00
|
|
|
{
|
2021-09-23 07:50:50 +08:00
|
|
|
permissions: { net: true },
|
2020-03-10 16:38:02 +01:00
|
|
|
},
|
|
|
|
async function netCloseWriteSuccess() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const addr = { hostname: "127.0.0.1", port: listenPort };
|
2020-03-10 16:38:02 +01:00
|
|
|
const listener = Deno.listen(addr);
|
2023-11-11 03:29:09 +06:00
|
|
|
const { promise: closePromise, resolve } = Promise.withResolvers<void>();
|
2020-03-29 04:03:49 +11:00
|
|
|
listener.accept().then(async (conn) => {
|
2020-03-10 16:38:02 +01:00
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
2023-11-11 03:29:09 +06:00
|
|
|
await closePromise;
|
2020-03-10 16:38:02 +01:00
|
|
|
conn.close();
|
|
|
|
});
|
|
|
|
const conn = await Deno.connect(addr);
|
|
|
|
conn.closeWrite(); // closing write
|
|
|
|
const buf = new Uint8Array(1024);
|
|
|
|
// Check read not impacted
|
|
|
|
const readResult = await conn.read(buf);
|
|
|
|
assertEquals(3, readResult);
|
|
|
|
assertEquals(1, buf[0]);
|
|
|
|
assertEquals(2, buf[1]);
|
|
|
|
assertEquals(3, buf[2]);
|
2021-01-19 20:11:08 -08:00
|
|
|
// Verify that the write end of the socket is closed.
|
|
|
|
// TODO(piscisaureus): assert that thrown error is of a specific type.
|
2021-09-22 21:21:11 +08:00
|
|
|
await assertRejects(async () => {
|
2020-03-10 16:38:02 +01:00
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
});
|
2023-11-11 03:29:09 +06:00
|
|
|
resolve();
|
2020-03-10 16:38:02 +01:00
|
|
|
listener.close();
|
2019-04-28 14:15:15 -07:00
|
|
|
conn.close();
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-10 16:38:02 +01:00
|
|
|
);
|
2020-03-11 22:19:24 +00:00
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2020-03-11 22:19:24 +00:00
|
|
|
{
|
2021-08-16 16:15:00 +02:00
|
|
|
// https://github.com/denoland/deno/issues/11580
|
|
|
|
ignore: Deno.build.os === "darwin" && isCI,
|
2021-09-23 07:50:50 +08:00
|
|
|
permissions: { net: true },
|
2020-03-11 22:19:24 +00:00
|
|
|
},
|
|
|
|
async function netHangsOnClose() {
|
|
|
|
let acceptedConn: Deno.Conn;
|
|
|
|
|
2021-08-05 13:08:58 +02:00
|
|
|
async function iteratorReq(listener: Deno.Listener) {
|
2020-03-11 22:19:24 +00:00
|
|
|
const p = new Uint8Array(10);
|
|
|
|
const conn = await listener.accept();
|
|
|
|
acceptedConn = conn;
|
|
|
|
|
|
|
|
try {
|
|
|
|
while (true) {
|
|
|
|
const nread = await conn.read(p);
|
2020-04-28 17:40:43 +01:00
|
|
|
if (nread === null) {
|
2020-03-11 22:19:24 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
await conn.write(new Uint8Array([1, 2, 3]));
|
|
|
|
}
|
|
|
|
} catch (err) {
|
2021-10-09 22:37:19 +02:00
|
|
|
assert(err);
|
|
|
|
assert(err instanceof Deno.errors.Interrupted);
|
2020-03-11 22:19:24 +00:00
|
|
|
}
|
|
|
|
}
|
2020-03-24 17:24:58 +01:00
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const addr = { hostname: "127.0.0.1", port: listenPort };
|
2020-03-11 22:19:24 +00:00
|
|
|
const listener = Deno.listen(addr);
|
2021-08-04 19:45:10 -04:00
|
|
|
const listenerPromise = iteratorReq(listener);
|
|
|
|
const connectionPromise = (async () => {
|
|
|
|
const conn = await Deno.connect(addr);
|
|
|
|
await conn.write(new Uint8Array([1, 2, 3, 4]));
|
|
|
|
const buf = new Uint8Array(10);
|
|
|
|
await conn.read(buf);
|
|
|
|
conn!.close();
|
|
|
|
acceptedConn!.close();
|
|
|
|
listener.close();
|
|
|
|
})();
|
|
|
|
|
|
|
|
await Promise.all([
|
|
|
|
listenerPromise,
|
|
|
|
connectionPromise,
|
|
|
|
]);
|
2020-07-14 15:24:17 -04:00
|
|
|
},
|
2020-03-11 22:19:24 +00:00
|
|
|
);
|
2020-09-27 16:44:53 +02:00
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2020-09-27 16:44:53 +02:00
|
|
|
{
|
2021-09-23 07:50:50 +08:00
|
|
|
permissions: { net: true },
|
2020-09-27 16:44:53 +02:00
|
|
|
},
|
|
|
|
function netExplicitUndefinedHostname() {
|
|
|
|
const listener = Deno.listen({ hostname: undefined, port: 8080 });
|
|
|
|
assertEquals((listener.addr as Deno.NetAddr).hostname, "0.0.0.0");
|
|
|
|
listener.close();
|
|
|
|
},
|
|
|
|
);
|
2021-10-03 01:09:59 +08:00
|
|
|
|
2021-11-23 17:45:18 +01:00
|
|
|
Deno.test(
|
2021-10-03 01:09:59 +08:00
|
|
|
{
|
|
|
|
ignore: Deno.build.os !== "linux",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
},
|
|
|
|
function netUnixAbstractPathShouldNotPanic() {
|
|
|
|
const listener = Deno.listen({
|
|
|
|
path: "\0aaa",
|
|
|
|
transport: "unix",
|
|
|
|
});
|
|
|
|
assert("not panic");
|
|
|
|
listener.close();
|
|
|
|
},
|
|
|
|
);
|
2022-02-15 13:35:22 +01:00
|
|
|
|
|
|
|
Deno.test({ permissions: { net: true } }, async function whatwgStreams() {
|
2023-09-16 07:48:31 +02:00
|
|
|
const server = (async () => {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ hostname: "127.0.0.1", port: listenPort });
|
2022-02-15 13:35:22 +01:00
|
|
|
const conn = await listener.accept();
|
|
|
|
await conn.readable.pipeTo(conn.writable);
|
|
|
|
listener.close();
|
|
|
|
})();
|
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ hostname: "127.0.0.1", port: listenPort });
|
2022-02-15 13:35:22 +01:00
|
|
|
const reader = conn.readable.getReader();
|
|
|
|
const writer = conn.writable.getWriter();
|
|
|
|
const encoder = new TextEncoder();
|
|
|
|
const decoder = new TextDecoder();
|
|
|
|
const data = encoder.encode("Hello World");
|
|
|
|
|
|
|
|
await writer.write(data);
|
|
|
|
const { value, done } = await reader.read();
|
|
|
|
assert(!done);
|
|
|
|
assertEquals(decoder.decode(value), "Hello World");
|
|
|
|
await reader.cancel();
|
2023-09-16 07:48:31 +02:00
|
|
|
await server;
|
2022-02-15 13:35:22 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { read: true } },
|
|
|
|
async function readableStreamTextEncoderPipe() {
|
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 13:22:13 -07:00
|
|
|
const filename = "tests/testdata/assets/hello.txt";
|
2022-02-15 13:35:22 +01:00
|
|
|
const file = await Deno.open(filename);
|
|
|
|
const readable = file.readable.pipeThrough(new TextDecoderStream());
|
|
|
|
const chunks = [];
|
|
|
|
for await (const chunk of readable) {
|
|
|
|
chunks.push(chunk);
|
|
|
|
}
|
|
|
|
assertEquals(chunks.length, 1);
|
|
|
|
assertEquals(chunks[0].length, 12);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { read: true, write: true } },
|
|
|
|
async function writableStream() {
|
|
|
|
const path = await Deno.makeTempFile();
|
|
|
|
const file = await Deno.open(path, { write: true });
|
|
|
|
assert(file.writable instanceof WritableStream);
|
|
|
|
const readable = new ReadableStream({
|
|
|
|
start(controller) {
|
|
|
|
controller.enqueue(new TextEncoder().encode("hello "));
|
|
|
|
controller.enqueue(new TextEncoder().encode("world!"));
|
|
|
|
controller.close();
|
|
|
|
},
|
|
|
|
});
|
|
|
|
await readable.pipeTo(file.writable);
|
|
|
|
const res = await Deno.readTextFile(path);
|
|
|
|
assertEquals(res, "hello world!");
|
|
|
|
},
|
|
|
|
);
|
2022-03-23 12:04:20 +09:00
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { read: true, run: true } },
|
|
|
|
async function netListenUnref() {
|
|
|
|
const [statusCode, _output] = await execCode(`
|
|
|
|
async function main() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: ${listenPort} });
|
2022-03-23 12:04:20 +09:00
|
|
|
listener.unref();
|
|
|
|
await listener.accept(); // This doesn't block the program from exiting
|
|
|
|
}
|
|
|
|
main();
|
|
|
|
`);
|
|
|
|
assertEquals(statusCode, 0);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { read: true, run: true } },
|
2023-09-16 07:48:31 +02:00
|
|
|
async function netListenUnref2() {
|
2022-03-23 12:04:20 +09:00
|
|
|
const [statusCode, _output] = await execCode(`
|
|
|
|
async function main() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: ${listenPort} });
|
2022-03-23 12:04:20 +09:00
|
|
|
await listener.accept();
|
|
|
|
listener.unref();
|
|
|
|
await listener.accept(); // The program exits here
|
|
|
|
throw new Error(); // The program doesn't reach here
|
|
|
|
}
|
|
|
|
main();
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ port: ${listenPort} });
|
2022-03-23 12:04:20 +09:00
|
|
|
conn.close();
|
|
|
|
`);
|
|
|
|
assertEquals(statusCode, 0);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { read: true, run: true, net: true } },
|
|
|
|
async function netListenUnrefAndRef() {
|
2022-12-02 12:41:52 -05:00
|
|
|
const p = execCode2(`
|
2022-03-23 12:04:20 +09:00
|
|
|
async function main() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: ${listenPort} });
|
2022-03-23 12:04:20 +09:00
|
|
|
listener.unref();
|
|
|
|
listener.ref(); // This restores 'ref' state of listener
|
2022-12-02 12:41:52 -05:00
|
|
|
console.log("started");
|
2022-03-23 12:04:20 +09:00
|
|
|
await listener.accept();
|
|
|
|
console.log("accepted")
|
|
|
|
}
|
|
|
|
main();
|
|
|
|
`);
|
2022-12-02 12:41:52 -05:00
|
|
|
await p.waitStdoutText("started");
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ port: listenPort });
|
2022-12-02 12:41:52 -05:00
|
|
|
conn.close();
|
|
|
|
const [statusCode, output] = await p.finished();
|
2022-03-23 12:04:20 +09:00
|
|
|
assertEquals(statusCode, 0);
|
2022-12-02 12:41:52 -05:00
|
|
|
assertEquals(output.trim(), "started\naccepted");
|
2022-03-23 12:04:20 +09:00
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true } },
|
|
|
|
async function netListenUnrefConcurrentAccept() {
|
|
|
|
const timer = setTimeout(() => {}, 1000);
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2022-03-23 12:04:20 +09:00
|
|
|
listener.accept().catch(() => {});
|
|
|
|
listener.unref();
|
|
|
|
// Unref'd listener still causes Busy error
|
|
|
|
// on concurrent accept calls.
|
|
|
|
await assertRejects(async () => {
|
|
|
|
await listener.accept(); // The program exits here
|
|
|
|
}, Deno.errors.Busy);
|
|
|
|
listener.close();
|
|
|
|
clearTimeout(timer);
|
|
|
|
},
|
|
|
|
);
|
2022-10-24 00:45:45 +02:00
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
ignore: Deno.build.os === "windows",
|
|
|
|
permissions: { read: true, write: true },
|
|
|
|
}, function netUnixListenAddrAlreadyInUse() {
|
|
|
|
const filePath = tmpUnixSocketPath();
|
|
|
|
const listener = Deno.listen({ path: filePath, transport: "unix" });
|
|
|
|
assertThrows(
|
|
|
|
() => {
|
|
|
|
Deno.listen({ path: filePath, transport: "unix" });
|
|
|
|
},
|
|
|
|
Deno.errors.AddrInUse,
|
|
|
|
);
|
|
|
|
listener.close();
|
|
|
|
});
|
2022-10-24 11:05:07 +02:00
|
|
|
|
2022-12-28 10:29:48 +01:00
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true, read: true, run: true } },
|
|
|
|
async function netConnUnref() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2022-12-28 10:29:48 +01:00
|
|
|
const intervalId = setInterval(() => {}); // This keeps event loop alive.
|
|
|
|
|
|
|
|
const program = execCode(`
|
|
|
|
async function main() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ port: ${listenPort} });
|
2022-12-28 10:29:48 +01:00
|
|
|
conn.unref();
|
|
|
|
await conn.read(new Uint8Array(10)); // The program exits here
|
2023-01-02 16:00:42 -05:00
|
|
|
throw new Error(); // The program doesn't reach here
|
2022-12-28 10:29:48 +01:00
|
|
|
}
|
|
|
|
main();
|
|
|
|
`);
|
|
|
|
const conn = await listener.accept();
|
|
|
|
const [statusCode, _output] = await program;
|
|
|
|
conn.close();
|
|
|
|
listener.close();
|
|
|
|
clearInterval(intervalId);
|
|
|
|
assertEquals(statusCode, 0);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true, read: true, run: true } },
|
|
|
|
async function netConnUnrefReadable() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const listener = Deno.listen({ port: listenPort });
|
2022-12-28 10:29:48 +01:00
|
|
|
const intervalId = setInterval(() => {}); // This keeps event loop alive.
|
|
|
|
|
|
|
|
const program = execCode(`
|
|
|
|
async function main() {
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn = await Deno.connect({ port: ${listenPort} });
|
2022-12-28 10:29:48 +01:00
|
|
|
conn.unref();
|
|
|
|
const reader = conn.readable.getReader();
|
|
|
|
await reader.read(); // The program exits here
|
2023-01-02 16:00:42 -05:00
|
|
|
throw new Error(); // The program doesn't reach here
|
2022-12-28 10:29:48 +01:00
|
|
|
}
|
|
|
|
main();
|
|
|
|
`);
|
|
|
|
const conn = await listener.accept();
|
|
|
|
const [statusCode, _output] = await program;
|
|
|
|
conn.close();
|
|
|
|
listener.close();
|
|
|
|
clearInterval(intervalId);
|
|
|
|
assertEquals(statusCode, 0);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2022-10-24 11:05:07 +02:00
|
|
|
Deno.test({ permissions: { net: true } }, async function netTcpReuseAddr() {
|
|
|
|
const listener1 = Deno.listen({
|
|
|
|
hostname: "127.0.0.1",
|
2023-05-22 13:35:59 -06:00
|
|
|
port: listenPort,
|
2022-10-24 11:05:07 +02:00
|
|
|
});
|
|
|
|
listener1.accept().then(
|
|
|
|
(conn) => {
|
|
|
|
conn.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn1 = await Deno.connect({ hostname: "127.0.0.1", port: listenPort });
|
2022-10-24 11:05:07 +02:00
|
|
|
const buf1 = new Uint8Array(1024);
|
|
|
|
await conn1.read(buf1);
|
|
|
|
listener1.close();
|
|
|
|
conn1.close();
|
|
|
|
|
|
|
|
const listener2 = Deno.listen({
|
|
|
|
hostname: "127.0.0.1",
|
2023-05-22 13:35:59 -06:00
|
|
|
port: listenPort,
|
2022-10-24 11:05:07 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
listener2.accept().then(
|
|
|
|
(conn) => {
|
|
|
|
conn.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2023-05-22 13:35:59 -06:00
|
|
|
const conn2 = await Deno.connect({ hostname: "127.0.0.1", port: listenPort });
|
2022-10-24 11:05:07 +02:00
|
|
|
const buf2 = new Uint8Array(1024);
|
|
|
|
await conn2.read(buf2);
|
|
|
|
|
|
|
|
listener2.close();
|
|
|
|
conn2.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true } },
|
|
|
|
async function netUdpReuseAddr() {
|
|
|
|
const sender = Deno.listenDatagram({
|
|
|
|
port: 4002,
|
|
|
|
transport: "udp",
|
|
|
|
});
|
|
|
|
const listener1 = Deno.listenDatagram({
|
|
|
|
port: 4000,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: true,
|
|
|
|
});
|
|
|
|
const listener2 = Deno.listenDatagram({
|
|
|
|
port: 4000,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: true,
|
|
|
|
});
|
|
|
|
|
|
|
|
const sent = new Uint8Array([1, 2, 3]);
|
|
|
|
await sender.send(sent, listener1.addr);
|
|
|
|
await Promise.any([listener1.receive(), listener2.receive()]).then(
|
|
|
|
([recvd, remote]) => {
|
|
|
|
assert(remote.transport === "udp");
|
|
|
|
assertEquals(recvd.length, 3);
|
|
|
|
assertEquals(1, recvd[0]);
|
|
|
|
assertEquals(2, recvd[1]);
|
|
|
|
assertEquals(3, recvd[2]);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
sender.close();
|
|
|
|
listener1.close();
|
|
|
|
listener2.close();
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true } },
|
|
|
|
function netUdpNoReuseAddr() {
|
|
|
|
let listener1;
|
|
|
|
try {
|
|
|
|
listener1 = Deno.listenDatagram({
|
|
|
|
port: 4001,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: false,
|
|
|
|
});
|
|
|
|
} catch (err) {
|
|
|
|
assert(err);
|
|
|
|
assert(err instanceof Deno.errors.AddrInUse); // AddrInUse from previous test
|
|
|
|
}
|
|
|
|
|
|
|
|
assertThrows(() => {
|
|
|
|
Deno.listenDatagram({
|
|
|
|
port: 4001,
|
|
|
|
transport: "udp",
|
|
|
|
reuseAddress: false,
|
|
|
|
});
|
|
|
|
}, Deno.errors.AddrInUse);
|
|
|
|
if (typeof listener1 !== "undefined") {
|
|
|
|
listener1.close();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
);
|
2022-10-26 21:04:27 +02:00
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
ignore: Deno.build.os !== "linux",
|
|
|
|
permissions: { net: true },
|
|
|
|
}, async function netTcpListenReusePort() {
|
|
|
|
const port = 4003;
|
|
|
|
const listener1 = Deno.listen({ port, reusePort: true });
|
|
|
|
const listener2 = Deno.listen({ port, reusePort: true });
|
|
|
|
let p1;
|
|
|
|
let p2;
|
|
|
|
let listener1Recv = false;
|
|
|
|
let listener2Recv = false;
|
|
|
|
while (!listener1Recv || !listener2Recv) {
|
|
|
|
if (!p1) {
|
|
|
|
p1 = listener1.accept().then((conn) => {
|
|
|
|
conn.close();
|
|
|
|
listener1Recv = true;
|
|
|
|
p1 = undefined;
|
2024-04-08 16:18:14 -06:00
|
|
|
listener1.close();
|
2022-10-26 21:04:27 +02:00
|
|
|
}).catch(() => {});
|
|
|
|
}
|
|
|
|
if (!p2) {
|
|
|
|
p2 = listener2.accept().then((conn) => {
|
|
|
|
conn.close();
|
|
|
|
listener2Recv = true;
|
|
|
|
p2 = undefined;
|
2024-04-08 16:18:14 -06:00
|
|
|
listener2.close();
|
2022-10-26 21:04:27 +02:00
|
|
|
}).catch(() => {});
|
|
|
|
}
|
|
|
|
const conn = await Deno.connect({ port });
|
|
|
|
conn.close();
|
|
|
|
await Promise.race([p1, p2]);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
ignore: Deno.build.os === "linux",
|
|
|
|
permissions: { net: true },
|
|
|
|
}, function netTcpListenReusePortDoesNothing() {
|
|
|
|
const listener1 = Deno.listen({ port: 4003, reusePort: true });
|
|
|
|
assertThrows(() => {
|
|
|
|
Deno.listen({ port: 4003, reusePort: true });
|
|
|
|
}, Deno.errors.AddrInUse);
|
|
|
|
listener1.close();
|
|
|
|
});
|
2023-07-25 15:26:18 +09:00
|
|
|
|
|
|
|
Deno.test({
|
|
|
|
permissions: { net: true },
|
|
|
|
}, function netTcpListenDoesNotThrowOnStringPort() {
|
|
|
|
// @ts-ignore String port is not allowed by typing, but it shouldn't throw
|
|
|
|
// for backwards compatibility.
|
|
|
|
const listener = Deno.listen({ hostname: "localhost", port: "0" });
|
|
|
|
listener.close();
|
|
|
|
});
|
2023-11-01 20:26:12 +01:00
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true } },
|
|
|
|
async function listenerExplicitResourceManagement() {
|
|
|
|
let done: Promise<Deno.errors.BadResource>;
|
|
|
|
|
|
|
|
{
|
|
|
|
using listener = Deno.listen({ port: listenPort });
|
|
|
|
|
|
|
|
done = assertRejects(
|
|
|
|
() => listener.accept(),
|
|
|
|
Deno.errors.BadResource,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
await done;
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
|
|
|
Deno.test(
|
|
|
|
{ permissions: { net: true } },
|
|
|
|
async function listenerExplicitResourceManagementManualClose() {
|
|
|
|
using listener = Deno.listen({ port: listenPort });
|
|
|
|
listener.close();
|
|
|
|
await assertRejects( // definitely closed
|
|
|
|
() => listener.accept(),
|
|
|
|
Deno.errors.BadResource,
|
|
|
|
);
|
|
|
|
// calling [Symbol.dispose] after manual close is a no-op
|
|
|
|
},
|
|
|
|
);
|