1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-03 04:48:52 -05:00

chore(core): Ensure that net test ports aren't used elsewhere (#19243)

Fixes occasional test flake due to overlapping ports
This commit is contained in:
Matt Mastracci 2023-05-24 12:36:41 -06:00 committed by GitHub
parent 1174715f99
commit 0fbfdaf901
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 43 additions and 43 deletions

View file

@ -943,7 +943,7 @@ Deno.test(
file.close(); file.close();
let httpConn: Deno.HttpConn; let httpConn: Deno.HttpConn;
const listener = Deno.listen({ port: 4503 }); const listener = Deno.listen({ port: 4501 });
const promise = (async () => { const promise = (async () => {
const conn = await listener.accept(); const conn = await listener.accept();
httpConn = Deno.serveHttp(conn); httpConn = Deno.serveHttp(conn);
@ -952,7 +952,7 @@ Deno.test(
const f = await Deno.open(tmpFile, { read: true }); const f = await Deno.open(tmpFile, { read: true });
await respondWith(new Response(f.readable, { status: 200 })); await respondWith(new Response(f.readable, { status: 200 }));
})(); })();
const resp = await fetch("http://127.0.0.1:4503/"); const resp = await fetch("http://127.0.0.1:4501/");
const body = await resp.arrayBuffer(); const body = await resp.arrayBuffer();
assertEquals(body.byteLength, 70 * 1024); assertEquals(body.byteLength, 70 * 1024);
await promise; await promise;

View file

@ -788,14 +788,14 @@ Deno.test(
const server = Deno.serve({ const server = Deno.serve({
handler: () => new Response("韓國".repeat(10)), handler: () => new Response("韓國".repeat(10)),
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -1565,14 +1565,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = `GET /echo HTTP/1.1\r\nHost: deno.land\r\n\r\n`; const body = `GET /echo HTTP/1.1\r\nHost: deno.land\r\n\r\n`;
const writeResult = await conn.write(encoder.encode(body)); const writeResult = await conn.write(encoder.encode(body));
@ -1599,14 +1599,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = `GET / HTTP/1.1\r\nserver: hello\tworld\r\n\r\n`; const body = `GET / HTTP/1.1\r\nserver: hello\tworld\r\n\r\n`;
const writeResult = await conn.write(encoder.encode(body)); const writeResult = await conn.write(encoder.encode(body));
@ -1633,14 +1633,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
// Connection: close = don't try to parse the body as a new request // Connection: close = don't try to parse the body as a new request
const body = const body =
@ -1669,14 +1669,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = const body =
`POST / HTTP/1.1\r\nHost: example.domain\r\nContent-Length: 19\r\n\r\nI'm a good request.`; `POST / HTTP/1.1\r\nHost: example.domain\r\nContent-Length: 19\r\n\r\nI'm a good request.`;
@ -1715,14 +1715,14 @@ function createServerLengthTest(name: string, testCase: TestCase) {
promise.resolve(); promise.resolve();
return new Response(testCase.body, testCase.headers ?? {}); return new Response(testCase.body, testCase.headers ?? {});
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = const body =
`GET / HTTP/1.1\r\nHost: example.domain\r\nConnection: close\r\n\r\n`; `GET / HTTP/1.1\r\nHost: example.domain\r\nConnection: close\r\n\r\n`;
@ -1849,14 +1849,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = const body =
@ -1881,14 +1881,14 @@ Deno.test(
handler: () => { handler: () => {
throw new Error("unreachable"); throw new Error("unreachable");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -1924,14 +1924,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = const body =
@ -1960,14 +1960,14 @@ Deno.test(
assertEquals(await r.text(), "12345"); assertEquals(await r.text(), "12345");
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = const body =
@ -1995,14 +1995,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("NaN".repeat(100)); return new Response("NaN".repeat(100));
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -2138,14 +2138,14 @@ for (const testCase of compressionTestCases) {
headers: headers as HeadersInit, headers: headers as HeadersInit,
}); });
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
try { try {
await listeningPromise; await listeningPromise;
const resp = await fetch("http://127.0.0.1:4503/", { const resp = await fetch(`http://127.0.0.1:${servePort}/`, {
headers: testCase.in as HeadersInit, headers: testCase.in as HeadersInit,
}); });
await promise; await promise;
@ -2192,7 +2192,7 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
@ -2200,7 +2200,7 @@ Deno.test(
await listeningPromise; await listeningPromise;
const f = await makeTempFile(70 * 1024); const f = await makeTempFile(70 * 1024);
const response = await fetch(`http://localhost:4503/`, { const response = await fetch(`http://localhost:${servePort}/`, {
method: "POST", method: "POST",
body: f.readable, body: f.readable,
}); });
@ -2263,14 +2263,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response("ok"); return new Response("ok");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const body = const body =
@ -2296,7 +2296,7 @@ Deno.test(
handler: () => { handler: () => {
throw new Error("oops"); throw new Error("oops");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
@ -2314,7 +2314,7 @@ Deno.test(
await listeningPromise; await listeningPromise;
for (const teHeader of variations) { for (const teHeader of variations) {
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const body = const body =
`POST / HTTP/1.1\r\nHost: example.domain\r\n${teHeader}\r\n\r\n0\r\n\r\n`; `POST / HTTP/1.1\r\nHost: example.domain\r\n${teHeader}\r\n\r\n0\r\n\r\n`;
const writeResult = await conn.write(encoder.encode(body)); const writeResult = await conn.write(encoder.encode(body));
@ -2374,14 +2374,14 @@ Deno.test(
promise.resolve(); promise.resolve();
return new Response(null, { status: 304 }); return new Response(null, { status: 304 });
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -2420,14 +2420,14 @@ Deno.test(
assertEquals(await req.text(), "hello"); assertEquals(await req.text(), "hello");
return new Response(null, { status: 304 }); return new Response(null, { status: 304 });
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -2481,14 +2481,14 @@ Deno.test(
assertEquals(await req.text(), ""); assertEquals(await req.text(), "");
return new Response(null, { status: 304 }); return new Response(null, { status: 304 });
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -2533,14 +2533,14 @@ for (const [name, req] of badRequests) {
handler: () => { handler: () => {
throw new Error("oops"); throw new Error("oops");
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
await listeningPromise; await listeningPromise;
const conn = await Deno.connect({ port: 4503 }); const conn = await Deno.connect({ port: servePort });
const encoder = new TextEncoder(); const encoder = new TextEncoder();
const decoder = new TextDecoder(); const decoder = new TextDecoder();
@ -2603,13 +2603,13 @@ Deno.test(
return new Response(`hello ${reqCount}`); return new Response(`hello ${reqCount}`);
}, },
port: 4503, port: servePort,
signal: ac.signal, signal: ac.signal,
onListen: onListen(listeningPromise), onListen: onListen(listeningPromise),
onError: createOnErrorCb(ac), onError: createOnErrorCb(ac),
}); });
const sseRequest = await fetch(`http://localhost:4503/`); const sseRequest = await fetch(`http://localhost:${servePort}/`);
const decoder = new TextDecoder(); const decoder = new TextDecoder();
const stream = sseRequest.body!.getReader(); const stream = sseRequest.body!.getReader();
@ -2619,7 +2619,7 @@ Deno.test(
assertEquals(decoder.decode(value), "data: hello\r\n\r\n"); assertEquals(decoder.decode(value), "data: hello\r\n\r\n");
} }
const helloRequest = await fetch(`http://localhost:4503/`); const helloRequest = await fetch(`http://localhost:${servePort}/`);
assertEquals(helloRequest.status, 200); assertEquals(helloRequest.status, 200);
assertEquals(await helloRequest.text(), "hello 1"); assertEquals(await helloRequest.text(), "hello 1");