-
Notifications
You must be signed in to change notification settings - Fork 30.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
http: added connection closing methods
Fixes: #41578 PR-URL: #42812 Reviewed-By: Matteo Collina <[email protected]> Reviewed-By: Luigi Pinca <[email protected]>
- Loading branch information
1 parent
3ab3086
commit 2f192c4
Showing
9 changed files
with
360 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
'use strict'; | ||
const common = require('../common'); | ||
const assert = require('assert'); | ||
|
||
const { createServer } = require('http'); | ||
const { connect } = require('net'); | ||
|
||
let connections = 0; | ||
|
||
const server = createServer(common.mustCall(function(req, res) { | ||
res.writeHead(200, { Connection: 'keep-alive' }); | ||
res.end(); | ||
}), { | ||
headersTimeout: 0, | ||
keepAliveTimeout: 0, | ||
requestTimeout: common.platformTimeout(60000), | ||
}); | ||
|
||
server.on('connection', function() { | ||
connections++; | ||
}); | ||
|
||
server.listen(0, function() { | ||
const port = server.address().port; | ||
|
||
// Create a first request but never finish it | ||
const client1 = connect(port); | ||
|
||
client1.on('close', common.mustCall()); | ||
|
||
client1.on('error', () => {}); | ||
|
||
client1.write('GET / HTTP/1.1'); | ||
|
||
// Create a second request, let it finish but leave the connection opened using HTTP keep-alive | ||
const client2 = connect(port); | ||
let response = ''; | ||
|
||
client2.on('data', common.mustCall((chunk) => { | ||
response += chunk.toString('utf-8'); | ||
|
||
if (response.endsWith('0\r\n\r\n')) { | ||
assert(response.startsWith('HTTP/1.1 200 OK\r\nConnection: keep-alive')); | ||
assert.strictEqual(connections, 2); | ||
|
||
server.closeAllConnections(); | ||
server.close(common.mustCall()); | ||
|
||
// This timer should never go off as the server.close should shut everything down | ||
setTimeout(common.mustNotCall(), common.platformTimeout(1500)).unref(); | ||
} | ||
})); | ||
|
||
client2.on('close', common.mustCall()); | ||
|
||
client2.write('GET / HTTP/1.1\r\n\r\n'); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
'use strict'; | ||
const common = require('../common'); | ||
const assert = require('assert'); | ||
|
||
const { createServer } = require('http'); | ||
const { connect } = require('net'); | ||
|
||
let connections = 0; | ||
|
||
const server = createServer(common.mustCall(function(req, res) { | ||
res.writeHead(200, { Connection: 'keep-alive' }); | ||
res.end(); | ||
}), { | ||
headersTimeout: 0, | ||
keepAliveTimeout: 0, | ||
requestTimeout: common.platformTimeout(60000), | ||
}); | ||
|
||
server.on('connection', function() { | ||
connections++; | ||
}); | ||
|
||
server.listen(0, function() { | ||
const port = server.address().port; | ||
let client1Closed = false; | ||
let client2Closed = false; | ||
|
||
// Create a first request but never finish it | ||
const client1 = connect(port); | ||
|
||
client1.on('close', common.mustCall(() => { | ||
client1Closed = true; | ||
})); | ||
|
||
client1.on('error', () => {}); | ||
|
||
client1.write('GET / HTTP/1.1'); | ||
|
||
// Create a second request, let it finish but leave the connection opened using HTTP keep-alive | ||
const client2 = connect(port); | ||
let response = ''; | ||
|
||
client2.on('data', common.mustCall((chunk) => { | ||
response += chunk.toString('utf-8'); | ||
|
||
if (response.endsWith('0\r\n\r\n')) { | ||
assert(response.startsWith('HTTP/1.1 200 OK\r\nConnection: keep-alive')); | ||
assert.strictEqual(connections, 2); | ||
|
||
server.closeIdleConnections(); | ||
server.close(common.mustCall()); | ||
|
||
// Check that only the idle connection got closed | ||
setTimeout(common.mustCall(() => { | ||
assert(!client1Closed); | ||
assert(client2Closed); | ||
|
||
server.closeAllConnections(); | ||
server.close(common.mustCall()); | ||
}), common.platformTimeout(500)).unref(); | ||
} | ||
})); | ||
|
||
client2.on('close', common.mustCall(() => { | ||
client2Closed = true; | ||
})); | ||
|
||
client2.write('GET / HTTP/1.1\r\n\r\n'); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
'use strict'; | ||
const common = require('../common'); | ||
const assert = require('assert'); | ||
|
||
if (!common.hasCrypto) { | ||
common.skip('missing crypto'); | ||
} | ||
|
||
const { createServer } = require('https'); | ||
const { connect } = require('tls'); | ||
|
||
const fixtures = require('../common/fixtures'); | ||
|
||
const options = { | ||
key: fixtures.readKey('agent1-key.pem'), | ||
cert: fixtures.readKey('agent1-cert.pem') | ||
}; | ||
|
||
let connections = 0; | ||
|
||
const server = createServer(options, common.mustCall(function(req, res) { | ||
res.writeHead(200, { Connection: 'keep-alive' }); | ||
res.end(); | ||
}), { | ||
headersTimeout: 0, | ||
keepAliveTimeout: 0, | ||
requestTimeout: common.platformTimeout(60000), | ||
}); | ||
|
||
server.on('connection', function() { | ||
connections++; | ||
}); | ||
|
||
server.listen(0, function() { | ||
const port = server.address().port; | ||
|
||
// Create a first request but never finish it | ||
const client1 = connect({ port, rejectUnauthorized: false }); | ||
|
||
client1.on('close', common.mustCall()); | ||
|
||
client1.on('error', () => {}); | ||
|
||
client1.write('GET / HTTP/1.1'); | ||
|
||
// Create a second request, let it finish but leave the connection opened using HTTP keep-alive | ||
const client2 = connect({ port, rejectUnauthorized: false }); | ||
let response = ''; | ||
|
||
client2.on('data', common.mustCall((chunk) => { | ||
response += chunk.toString('utf-8'); | ||
|
||
if (response.endsWith('0\r\n\r\n')) { | ||
assert(response.startsWith('HTTP/1.1 200 OK\r\nConnection: keep-alive')); | ||
assert.strictEqual(connections, 2); | ||
|
||
server.closeAllConnections(); | ||
server.close(common.mustCall()); | ||
|
||
// This timer should never go off as the server.close should shut everything down | ||
setTimeout(common.mustNotCall(), common.platformTimeout(1500)).unref(); | ||
} | ||
})); | ||
|
||
client2.on('close', common.mustCall()); | ||
|
||
client2.write('GET / HTTP/1.1\r\n\r\n'); | ||
}); |
Oops, something went wrong.