summaryrefslogtreecommitdiff
path: root/http/racing_server.ts
diff options
context:
space:
mode:
authorKevin (Kun) "Kassimo" Qian <kevinkassimo@gmail.com>2019-04-13 12:23:56 -0700
committerRyan Dahl <ry@tinyclouds.org>2019-04-13 15:23:56 -0400
commit236cedc7cba21132a2280c86ae4cf44c057ab5d8 (patch)
treebbaede3c311c377d9b4a22dc365875f7f642185f /http/racing_server.ts
parent733fbfd555a2db3365ac8ce19bc11e4a97fcfd47 (diff)
Enforce HTTP/1.1 pipeline response order (denoland/deno_std#331)
Original: https://github.com/denoland/deno_std/commit/144ef0e08d589fad2ca19eb4ef1ea20f1749bb5c
Diffstat (limited to 'http/racing_server.ts')
-rw-r--r--http/racing_server.ts53
1 files changed, 53 insertions, 0 deletions
diff --git a/http/racing_server.ts b/http/racing_server.ts
new file mode 100644
index 000000000..c44fc1216
--- /dev/null
+++ b/http/racing_server.ts
@@ -0,0 +1,53 @@
+// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
+import { serve, ServerRequest } from "./server.ts";
+
+const addr = Deno.args[1] || "127.0.0.1:4501";
+const server = serve(addr);
+
+const body = new TextEncoder().encode("Hello 1\n");
+const body4 = new TextEncoder().encode("World 4\n");
+
+function sleep(ms: number): Promise<void> {
+ return new Promise(res => setTimeout(res, ms));
+}
+
+async function delayedRespond(request: ServerRequest): Promise<void> {
+ await sleep(3000);
+ await request.respond({ status: 200, body });
+}
+
+async function largeRespond(request: ServerRequest, c: string): Promise<void> {
+ const b = new Uint8Array(1024 * 1024);
+ b.fill(c.charCodeAt(0));
+ await request.respond({ status: 200, body: b });
+}
+
+async function main(): Promise<void> {
+ let step = 1;
+ for await (const request of server) {
+ switch (step) {
+ case 1:
+ // Try to wait long enough.
+ // For pipelining, this should cause all the following response
+ // to block.
+ delayedRespond(request);
+ break;
+ case 2:
+ // HUGE body.
+ largeRespond(request, "a");
+ break;
+ case 3:
+ // HUGE body.
+ largeRespond(request, "b");
+ break;
+ default:
+ request.respond({ status: 200, body: body4 });
+ break;
+ }
+ step++;
+ }
+}
+
+main();
+
+console.log("Racing server listening...\n");