|
20 | 20 | // USE OR OTHER DEALINGS IN THE SOFTWARE. |
21 | 21 |
|
22 | 22 | 'use strict'; |
23 | | -require('../common'); |
| 23 | +const common = require('../common'); |
24 | 24 | const assert = require('assert'); |
25 | 25 | const http = require('http'); |
26 | 26 |
|
27 | | -let outstanding_reqs = 0; |
28 | 27 | const test_req_body = 'some stuff...\n'; |
29 | 28 | const test_res_body = 'other stuff!\n'; |
30 | 29 | let sent_continue = false; |
31 | 30 | let got_continue = false; |
32 | 31 |
|
33 | | -function handler(req, res) { |
34 | | - assert.strictEqual(sent_continue, true, |
35 | | - 'Full response sent before 100 Continue'); |
| 32 | +const handler = common.mustCall((req, res) => { |
| 33 | + assert.ok(sent_continue, 'Full response sent before 100 Continue'); |
36 | 34 | console.error('Server sending full response...'); |
37 | 35 | res.writeHead(200, { |
38 | 36 | 'Content-Type': 'text/plain', |
39 | 37 | 'ABCD': '1' |
40 | 38 | }); |
41 | 39 | res.end(test_res_body); |
42 | | -} |
| 40 | +}); |
43 | 41 |
|
44 | | -const server = http.createServer(handler); |
45 | | -server.on('checkContinue', function(req, res) { |
| 42 | +const server = http.createServer(); |
| 43 | +server.on('checkContinue', common.mustCall((req, res) => { |
46 | 44 | console.error('Server got Expect: 100-continue...'); |
47 | 45 | res.writeContinue(); |
48 | 46 | sent_continue = true; |
49 | 47 | setTimeout(function() { |
50 | 48 | handler(req, res); |
51 | 49 | }, 100); |
52 | | -}); |
| 50 | +})); |
53 | 51 | server.listen(0); |
54 | 52 |
|
55 | 53 |
|
56 | | -server.on('listening', function() { |
| 54 | +server.on('listening', common.mustCall(() => { |
57 | 55 | const req = http.request({ |
58 | | - port: this.address().port, |
| 56 | + port: server.address().port, |
59 | 57 | method: 'POST', |
60 | 58 | path: '/world', |
61 | 59 | headers: { 'Expect': '100-continue' } |
62 | 60 | }); |
63 | 61 | console.error('Client sending request...'); |
64 | | - outstanding_reqs++; |
65 | 62 | let body = ''; |
66 | | - req.on('continue', function() { |
| 63 | + req.on('continue', common.mustCall(() => { |
67 | 64 | console.error('Client got 100 Continue...'); |
68 | 65 | got_continue = true; |
69 | 66 | req.end(test_req_body); |
70 | | - }); |
71 | | - req.on('response', function(res) { |
72 | | - assert.strictEqual(got_continue, true, |
73 | | - 'Full response received before 100 Continue'); |
| 67 | + })); |
| 68 | + req.on('response', common.mustCall((res) => { |
| 69 | + assert.ok(got_continue, 'Full response received before 100 Continue'); |
74 | 70 | assert.strictEqual(200, res.statusCode, |
75 | 71 | `Final status code was ${res.statusCode}, not 200.`); |
76 | 72 | res.setEncoding('utf8'); |
77 | 73 | res.on('data', function(chunk) { body += chunk; }); |
78 | | - res.on('end', function() { |
| 74 | + res.on('end', common.mustCall(() => { |
79 | 75 | console.error('Got full response.'); |
80 | | - assert.strictEqual(body, test_res_body, 'Response body doesn\'t match.'); |
| 76 | + assert.strictEqual(body, test_res_body); |
81 | 77 | assert.ok('abcd' in res.headers, 'Response headers missing.'); |
82 | | - outstanding_reqs--; |
83 | | - if (outstanding_reqs === 0) { |
84 | | - server.close(); |
85 | | - process.exit(); |
86 | | - } |
87 | | - }); |
88 | | - }); |
89 | | -}); |
| 78 | + server.close(); |
| 79 | + process.exit(); |
| 80 | + })); |
| 81 | + })); |
| 82 | +})); |
0 commit comments