forked from nodejs/node
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtest-http-no-read-no-dump.js
More file actions
62 lines (52 loc) · 1.26 KB
/
test-http-no-read-no-dump.js
File metadata and controls
62 lines (52 loc) · 1.26 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
'use strict';
const common = require('../common');
const http = require('http');
const assert = require('assert');
let onPause = null;
const server = http.createServer((req, res) => {
if (req.method === 'GET')
return res.end();
res.writeHead(200);
res.flushHeaders();
let closed = false;
req.on('close', common.mustCall(() => {
closed = true;
}));
req.on('end', common.mustCall(() => {
assert.strictEqual(closed, false);
}));
req.connection.on('pause', () => {
res.end();
onPause();
});
}).listen(0, common.mustCall(() => {
const agent = new http.Agent({
maxSockets: 1,
keepAlive: true
});
const port = server.address().port;
const post = http.request({
agent,
method: 'POST',
port,
}, common.mustCall((res) => {
res.resume();
post.write(Buffer.alloc(16 * 1024).fill('X'));
onPause = () => {
post.end('something');
};
}));
/* What happens here is that the server `end`s the response before we send
* `something`, and the client thought that this is a green light for sending
* next GET request
*/
post.write('initial');
http.request({
agent,
method: 'GET',
port,
}, common.mustCall((res) => {
server.close();
res.connection.end();
})).end();
}));