From 8d63f4c444b74393dcad62eb9011773a836321ab Mon Sep 17 00:00:00 2001 From: Luigi Pinca Date: Fri, 26 Apr 2019 16:11:14 +0200 Subject: [PATCH] test: refactor and deflake test-tls-sni-server-client - Run all tests in parallel. - Move `socket.end()` call to client. - Use `common.mustCall()` and `common.mustNotCall()`. Fixes: https://github.com/nodejs/node/issues/27219 Refs: https://github.com/nodejs/node/pull/27300 --- test/parallel/parallel.status | 2 - test/parallel/test-tls-sni-server-client.js | 138 ++++++++++---------- 2 files changed, 71 insertions(+), 69 deletions(-) diff --git a/test/parallel/parallel.status b/test/parallel/parallel.status index b1b4f4d40fab5b..e234c1b256c942 100644 --- a/test/parallel/parallel.status +++ b/test/parallel/parallel.status @@ -23,8 +23,6 @@ test-http2-client-upload-reject: PASS,FLAKY [$system==linux] [$system==macos] -# https://github.com/nodejs/node/issues/27219 -test-tls-sni-server-client: PASS,FLAKY # https://github.com/nodejs/node/issues/26938 test-tls-js-stream: PASS,FLAKY diff --git a/test/parallel/test-tls-sni-server-client.js b/test/parallel/test-tls-sni-server-client.js index 8ab025667ea68a..79f3601561ee19 100644 --- a/test/parallel/test-tls-sni-server-client.js +++ b/test/parallel/test-tls-sni-server-client.js @@ -54,73 +54,77 @@ const SNIContexts = { } }; -const clientsOptions = [{ - port: undefined, - ca: [loadPEM('ca1-cert')], - servername: 'a.example.com', - rejectUnauthorized: false -}, { - port: undefined, - ca: [loadPEM('ca2-cert')], - servername: 'b.test.com', - rejectUnauthorized: false -}, { - port: undefined, - ca: [loadPEM('ca2-cert')], - servername: 'a.b.test.com', - rejectUnauthorized: false -}, { - port: undefined, - ca: [loadPEM('ca1-cert')], - servername: 'c.wrong.com', - rejectUnauthorized: false -}, { - port: undefined, - ca: [loadPEM('ca1-cert')], - servername: 'chain.example.com', - rejectUnauthorized: false -}]; - -const serverResults = []; -const clientResults = []; - -const server = tls.createServer(serverOptions, function(c) { - serverResults.push(c.servername); - c.end(); -}); - -server.addContext('a.example.com', SNIContexts['a.example.com']); -server.addContext('*.test.com', SNIContexts['asterisk.test.com']); -server.addContext('chain.example.com', SNIContexts['chain.example.com']); - -server.listen(0, startTest); - -function startTest() { - let i = 0; - function start() { - // No options left - if (i === clientsOptions.length) - return server.close(); - - const options = clientsOptions[i++]; - options.port = server.address().port; - const client = tls.connect(options, function() { - clientResults.push( - client.authorizationError && - (client.authorizationError === 'ERR_TLS_CERT_ALTNAME_INVALID')); - - // Continue - start(); +test( + { + ca: [loadPEM('ca1-cert')], + servername: 'a.example.com' + }, + true, + 'a.example.com' +); + +test( + { + ca: [loadPEM('ca2-cert')], + servername: 'b.test.com', + }, + true, + 'b.test.com' +); + +test( + { + ca: [loadPEM('ca2-cert')], + servername: 'a.b.test.com', + }, + false, + 'a.b.test.com' +); + +test( + { + ca: [loadPEM('ca1-cert')], + servername: 'c.wrong.com', + }, + false, + 'c.wrong.com' +); + +test( + { + ca: [loadPEM('ca1-cert')], + servername: 'chain.example.com', + }, + true, + 'chain.example.com' +); + +function test(options, clientResult, serverResult) { + const server = tls.createServer(serverOptions, (c) => { + assert.strictEqual(c.servername, serverResult); + assert.strictEqual(c.authorized, false); + }); + + server.addContext('a.example.com', SNIContexts['a.example.com']); + server.addContext('*.test.com', SNIContexts['asterisk.test.com']); + server.addContext('chain.example.com', SNIContexts['chain.example.com']); + + server.on('tlsClientError', common.mustNotCall()); + + server.listen(0, () => { + const client = tls.connect({ + ...options, + port: server.address().port, + rejectUnauthorized: false + }, () => { + const result = client.authorizationError && + (client.authorizationError === 'ERR_TLS_CERT_ALTNAME_INVALID'); + assert.strictEqual(result, clientResult); + client.end(); }); - } - start(); + client.on('close', common.mustCall(() => { + server.close(); + })); + }); } - -process.on('exit', function() { - assert.deepStrictEqual(serverResults, [ - 'a.example.com', 'b.test.com', 'a.b.test.com', 'c.wrong.com', - 'chain.example.com' - ]); - assert.deepStrictEqual(clientResults, [true, true, false, false, true]); -});