summaryrefslogtreecommitdiff
path: root/tests/unit_node/dgram_test.ts
diff options
context:
space:
mode:
authorMatt Mastracci <matthew@mastracci.com>2024-02-10 13:22:13 -0700
committerGitHub <noreply@github.com>2024-02-10 20:22:13 +0000
commitf5e46c9bf2f50d66a953fa133161fc829cecff06 (patch)
tree8faf2f5831c1c7b11d842cd9908d141082c869a5 /tests/unit_node/dgram_test.ts
parentd2477f780630a812bfd65e3987b70c0d309385bb (diff)
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.
Diffstat (limited to 'tests/unit_node/dgram_test.ts')
-rw-r--r--tests/unit_node/dgram_test.ts59
1 files changed, 59 insertions, 0 deletions
diff --git a/tests/unit_node/dgram_test.ts b/tests/unit_node/dgram_test.ts
new file mode 100644
index 000000000..4c6e49577
--- /dev/null
+++ b/tests/unit_node/dgram_test.ts
@@ -0,0 +1,59 @@
+// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
+
+import { assertEquals } from "@test_util/std/assert/mod.ts";
+import { execCode } from "../unit/test_util.ts";
+import { createSocket } from "node:dgram";
+
+const listenPort = 4503;
+const listenPort2 = 4504;
+
+Deno.test("[node/dgram] udp ref and unref", {
+ permissions: { read: true, run: true, net: true },
+}, async () => {
+ const { promise, resolve } = Promise.withResolvers<void>();
+
+ const udpSocket = createSocket("udp4");
+ udpSocket.bind(listenPort);
+
+ udpSocket.unref();
+ udpSocket.ref();
+
+ let data;
+ udpSocket.on("message", (buffer, _rinfo) => {
+ data = Uint8Array.from(buffer);
+ udpSocket.close();
+ });
+ udpSocket.on("close", () => {
+ resolve();
+ });
+
+ const conn = await Deno.listenDatagram({
+ port: listenPort2,
+ transport: "udp",
+ });
+ await conn.send(new Uint8Array([0, 1, 2, 3]), {
+ transport: "udp",
+ port: listenPort,
+ hostname: "127.0.0.1",
+ });
+
+ await promise;
+ conn.close();
+ assertEquals(data, new Uint8Array([0, 1, 2, 3]));
+});
+
+Deno.test("[node/dgram] udp unref", {
+ permissions: { read: true, run: true, net: true },
+}, async () => {
+ const [statusCode, _output] = await execCode(`
+ import { createSocket } from "node:dgram";
+ const udpSocket = createSocket('udp4');
+ udpSocket.bind(${listenPort2});
+ // This should let the program to exit without waiting for the
+ // udp socket to close.
+ udpSocket.unref();
+ udpSocket.on('message', (buffer, rinfo) => {
+ });
+ `);
+ assertEquals(statusCode, 0);
+});