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:
parent
1174715f99
commit
0fbfdaf901
2 changed files with 43 additions and 43 deletions
|
@ -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;
|
||||||
|
|
|
@ -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");
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue