diff options
| author | Kevin (Kun) "Kassimo" Qian <kevinkassimo@gmail.com> | 2019-04-13 12:23:56 -0700 |
|---|---|---|
| committer | Ryan Dahl <ry@tinyclouds.org> | 2019-04-13 15:23:56 -0400 |
| commit | 236cedc7cba21132a2280c86ae4cf44c057ab5d8 (patch) | |
| tree | bbaede3c311c377d9b4a22dc365875f7f642185f /http/racing_server.ts | |
| parent | 733fbfd555a2db3365ac8ce19bc11e4a97fcfd47 (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.ts | 53 |
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"); |
