%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
'use strict'; const common = require('../common'); if (!common.hasCrypto) common.skip('missing crypto'); // This test ensures that `getProtocol` returns the right protocol // from a TLS connection const assert = require('assert'); const tls = require('tls'); const fixtures = require('../common/fixtures'); const clientConfigs = [ { secureProtocol: 'TLSv1_method', version: 'TLSv1' }, { secureProtocol: 'TLSv1_1_method', version: 'TLSv1.1' }, { secureProtocol: 'TLSv1_2_method', version: 'TLSv1.2' }, ]; const serverConfig = { secureProtocol: 'TLS_method', ciphers: 'RSA@SECLEVEL=0', key: fixtures.readKey('agent2-key.pem'), cert: fixtures.readKey('agent2-cert.pem') }; const server = tls.createServer(serverConfig, common.mustCall(function() { }, clientConfigs.length)).listen(0, common.localhostIPv4, function() { let connected = 0; clientConfigs.forEach(function(v) { tls.connect({ host: common.localhostIPv4, port: server.address().port, rejectUnauthorized: false, secureProtocol: v.secureProtocol }, common.mustCall(function() { assert.strictEqual(this.getProtocol(), v.version); this.on('end', common.mustCall()); this.on('close', common.mustCall(function() { assert.strictEqual(this.getProtocol(), null); })).end(); if (++connected === clientConfigs.length) server.close(); })); }); });