2019-04-13 12:23:56 -07:00
|
|
|
import { assert, assertEquals } from "../testing/asserts.ts";
|
2020-02-25 12:49:39 +09:00
|
|
|
import { BufReader, BufWriter } from "../io/bufio.ts";
|
2019-04-13 12:23:56 -07:00
|
|
|
import { TextProtoReader } from "../textproto/mod.ts";
|
|
|
|
|
2020-06-09 12:18:18 +01:00
|
|
|
let server: Deno.Process<Deno.RunOptions & { stdout: "piped" }>;
|
2019-04-13 12:23:56 -07:00
|
|
|
async function startServer(): Promise<void> {
|
2020-06-12 20:23:38 +01:00
|
|
|
server = Deno.run({
|
2020-07-26 12:52:08 -07:00
|
|
|
cmd: [Deno.execPath(), "run", "-A", "http/racing_server.ts"],
|
2020-03-29 04:03:49 +11:00
|
|
|
stdout: "piped",
|
2019-04-13 12:23:56 -07:00
|
|
|
});
|
2019-07-28 20:35:47 +09:00
|
|
|
// Once racing server is ready it will write to its stdout.
|
2020-02-07 16:23:38 +09:00
|
|
|
assert(server.stdout != null);
|
|
|
|
const r = new TextProtoReader(new BufReader(server.stdout));
|
2019-05-23 19:04:06 -07:00
|
|
|
const s = await r.readLine();
|
2020-04-28 17:40:43 +01:00
|
|
|
assert(s !== null && s.includes("Racing server listening..."));
|
2019-04-13 12:23:56 -07:00
|
|
|
}
|
|
|
|
function killServer(): void {
|
|
|
|
server.close();
|
2020-06-09 12:18:18 +01:00
|
|
|
server.stdout.close();
|
2019-04-13 12:23:56 -07:00
|
|
|
}
|
|
|
|
|
2020-02-25 12:49:39 +09:00
|
|
|
const input = [
|
|
|
|
"GET / HTTP/1.1\r\n\r\n",
|
|
|
|
"GET / HTTP/1.1\r\n\r\n",
|
|
|
|
"GET / HTTP/1.1\r\n\r\n",
|
|
|
|
"POST / HTTP/1.1\r\ncontent-length: 4\r\n\r\ndeno",
|
|
|
|
"POST / HTTP/1.1\r\ntransfer-encoding: chunked\r\n\r\n4\r\ndeno\r\n0\r\n\r\n",
|
|
|
|
"POST / HTTP/1.1\r\ntransfer-encoding: chunked\r\ntrailer: deno\r\n\r\n4\r\ndeno\r\n0\r\n\r\ndeno: land\r\n\r\n",
|
2020-03-29 04:03:49 +11:00
|
|
|
"GET / HTTP/1.1\r\n\r\n",
|
2020-02-25 12:49:39 +09:00
|
|
|
].join("");
|
2019-04-13 12:23:56 -07:00
|
|
|
const HUGE_BODY_SIZE = 1024 * 1024;
|
2019-10-06 01:02:34 +09:00
|
|
|
const output = `HTTP/1.1 200 OK
|
2020-02-25 12:49:39 +09:00
|
|
|
content-length: 6
|
2019-04-13 12:23:56 -07:00
|
|
|
|
2020-02-25 12:49:39 +09:00
|
|
|
Step1
|
2019-04-13 12:23:56 -07:00
|
|
|
HTTP/1.1 200 OK
|
|
|
|
content-length: ${HUGE_BODY_SIZE}
|
|
|
|
|
|
|
|
${"a".repeat(HUGE_BODY_SIZE)}HTTP/1.1 200 OK
|
|
|
|
content-length: ${HUGE_BODY_SIZE}
|
|
|
|
|
|
|
|
${"b".repeat(HUGE_BODY_SIZE)}HTTP/1.1 200 OK
|
2020-02-25 12:49:39 +09:00
|
|
|
content-length: 6
|
|
|
|
|
|
|
|
Step4
|
|
|
|
HTTP/1.1 200 OK
|
|
|
|
content-length: 6
|
|
|
|
|
|
|
|
Step5
|
|
|
|
HTTP/1.1 200 OK
|
|
|
|
content-length: 6
|
|
|
|
|
|
|
|
Step6
|
|
|
|
HTTP/1.1 200 OK
|
|
|
|
content-length: 6
|
2019-04-13 12:23:56 -07:00
|
|
|
|
2020-02-25 12:49:39 +09:00
|
|
|
Step7
|
2019-04-13 12:23:56 -07:00
|
|
|
`;
|
|
|
|
|
2020-06-12 20:23:38 +01:00
|
|
|
Deno.test("serverPipelineRace", async function (): Promise<void> {
|
2019-04-13 12:23:56 -07:00
|
|
|
await startServer();
|
|
|
|
|
2020-06-12 20:23:38 +01:00
|
|
|
const conn = await Deno.connect({ port: 4501 });
|
2019-04-13 12:23:56 -07:00
|
|
|
const r = new TextProtoReader(new BufReader(conn));
|
2020-02-25 12:49:39 +09:00
|
|
|
const w = new BufWriter(conn);
|
|
|
|
await w.write(new TextEncoder().encode(input));
|
|
|
|
await w.flush();
|
2019-04-13 12:23:56 -07:00
|
|
|
const outLines = output.split("\n");
|
|
|
|
// length - 1 to disregard last empty line
|
|
|
|
for (let i = 0; i < outLines.length - 1; i++) {
|
2019-05-23 19:04:06 -07:00
|
|
|
const s = await r.readLine();
|
2019-04-13 12:23:56 -07:00
|
|
|
assertEquals(s, outLines[i]);
|
|
|
|
}
|
|
|
|
killServer();
|
2020-03-19 00:25:55 +01:00
|
|
|
conn.close();
|
2019-04-13 12:23:56 -07:00
|
|
|
});
|