'use strict'; var common = require('../common'); if (!common.hasCrypto) { common.skip('missing crypto'); return; } var crypto = require('crypto'); var tls = require('tls'); crypto.DEFAULT_ENCODING = 'buffer'; var fs = require('fs'); var certPem = fs.readFileSync(common.fixturesDir + '/test_cert.pem', 'ascii'); var options = { key: fs.readFileSync(common.fixturesDir + '/keys/agent1-key.pem'), cert: fs.readFileSync(common.fixturesDir + '/keys/agent1-cert.pem') }; var server = tls.Server(options, function(socket) { setImmediate(function() { console.log('sending'); verify(); setImmediate(function() { socket.destroy(); }); }); }); function verify() { console.log('verify'); crypto.createVerify('RSA-SHA1') .update('Test') .verify(certPem, 'asdfasdfas', 'base64'); } server.listen(common.PORT, function() { tls.connect({ port: common.PORT, rejectUnauthorized: false }, function() { verify(); }).on('data', function(data) { console.log(data); }).on('error', function(err) { throw err; }).on('close', function() { server.close(); }).resume(); }); server.unref();