'use strict'; const common = require('../common'); if (!common.hasCrypto) common.skip('missing crypto'); const assert = require('assert'); const tls = require('tls'); assert.throws(() => tls.createSecureContext({ ciphers: 1 }), /TypeError: Ciphers must be a string/); assert.throws(() => tls.createServer({ ciphers: 1 }), /TypeError: Ciphers must be a string/); assert.throws(() => tls.createSecureContext({ key: 'dummykey', passphrase: 1 }), /TypeError: Pass phrase must be a string/); assert.throws(() => tls.createServer({ key: 'dummykey', passphrase: 1 }), /TypeError: Pass phrase must be a string/); assert.throws(() => tls.createServer({ ecdhCurve: 1 }), /TypeError: ECDH curve name must be a string/); assert.throws(() => tls.createServer({ handshakeTimeout: 'abcd' }), common.expectsError({ code: 'ERR_INVALID_ARG_TYPE', type: TypeError, message: 'The "timeout" argument must be of type number' }) ); assert.throws(() => tls.createServer({ sessionTimeout: 'abcd' }), /TypeError: Session timeout must be a 32-bit integer/); assert.throws(() => tls.createServer({ ticketKeys: 'abcd' }), /TypeError: Ticket keys must be a buffer/); assert.throws(() => tls.createServer({ ticketKeys: Buffer.alloc(0) }), /TypeError: Ticket keys length must be 48 bytes/); assert.throws(() => tls.createSecurePair({}), /Error: First argument must be a tls module SecureContext/); { const buffer = Buffer.from('abcd'); const out = {}; tls.convertALPNProtocols(buffer, out); out.ALPNProtocols.write('efgh'); assert(buffer.equals(Buffer.from('abcd'))); assert(out.ALPNProtocols.equals(Buffer.from('efgh'))); } { const buffer = Buffer.from('abcd'); const out = {}; tls.convertNPNProtocols(buffer, out); out.NPNProtocols.write('efgh'); assert(buffer.equals(Buffer.from('abcd'))); assert(out.NPNProtocols.equals(Buffer.from('efgh'))); } { const buffer = new Uint8Array(Buffer.from('abcd')); const out = {}; tls.convertALPNProtocols(buffer, out); assert(out.ALPNProtocols.equals(Buffer.from('abcd'))); } { const buffer = new Uint8Array(Buffer.from('abcd')); const out = {}; tls.convertNPNProtocols(buffer, out); assert(out.NPNProtocols.equals(Buffer.from('abcd'))); }