~ubuntu-branches/ubuntu/saucy/nodejs/saucy-proposed

« back to all changes in this revision

Viewing changes to test/simple/test-tls-client-reject.js

  • Committer: Package Import Robot
  • Author(s): Jérémy Lal
  • Date: 2013-08-14 00:16:46 UTC
  • mfrom: (7.1.40 sid)
  • Revision ID: package-import@ubuntu.com-20130814001646-bzlysfh8sd6mukbo
Tags: 0.10.15~dfsg1-4
* Update 2005 patch, adding a handful of tests that can fail on
  slow platforms.
* Add 1004 patch to fix test failures when writing NaN to buffer
  on mipsel.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
// Copyright Joyent, Inc. and other Node contributors.
 
2
//
 
3
// Permission is hereby granted, free of charge, to any person obtaining a
 
4
// copy of this software and associated documentation files (the
 
5
// "Software"), to deal in the Software without restriction, including
 
6
// without limitation the rights to use, copy, modify, merge, publish,
 
7
// distribute, sublicense, and/or sell copies of the Software, and to permit
 
8
// persons to whom the Software is furnished to do so, subject to the
 
9
// following conditions:
 
10
//
 
11
// The above copyright notice and this permission notice shall be included
 
12
// in all copies or substantial portions of the Software.
 
13
//
 
14
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 
15
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 
16
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
 
17
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 
18
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
 
19
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
 
20
// USE OR OTHER DEALINGS IN THE SOFTWARE.
 
21
 
 
22
if (!process.versions.openssl) {
 
23
  console.error('Skipping because node compiled without OpenSSL.');
 
24
  process.exit(0);
 
25
}
 
26
 
 
27
var common = require('../common');
 
28
var assert = require('assert');
 
29
var tls = require('tls');
 
30
var fs = require('fs');
 
31
var path = require('path');
 
32
 
 
33
var options = {
 
34
  key: fs.readFileSync(path.join(common.fixturesDir, 'test_key.pem')),
 
35
  cert: fs.readFileSync(path.join(common.fixturesDir, 'test_cert.pem'))
 
36
};
 
37
 
 
38
var connectCount = 0;
 
39
 
 
40
var server = tls.createServer(options, function(socket) {
 
41
  ++connectCount;
 
42
  socket.on('data', function(data) {
 
43
    common.debug(data.toString());
 
44
    assert.equal(data, 'ok');
 
45
  });
 
46
}).listen(common.PORT, function() {
 
47
  unauthorized();
 
48
});
 
49
 
 
50
function unauthorized() {
 
51
  var socket = tls.connect({
 
52
    port: common.PORT,
 
53
    rejectUnauthorized: false
 
54
  }, function() {
 
55
    assert(!socket.authorized);
 
56
    socket.end();
 
57
    rejectUnauthorized();
 
58
  });
 
59
  socket.on('error', function(err) {
 
60
    assert(false);
 
61
  });
 
62
  socket.write('ok');
 
63
}
 
64
 
 
65
function rejectUnauthorized() {
 
66
  var socket = tls.connect(common.PORT, function() {
 
67
    assert(false);
 
68
  });
 
69
  socket.on('error', function(err) {
 
70
    common.debug(err);
 
71
    authorized();
 
72
  });
 
73
  socket.write('ng');
 
74
}
 
75
 
 
76
function authorized() {
 
77
  var socket = tls.connect(common.PORT, {
 
78
    ca: [fs.readFileSync(path.join(common.fixturesDir, 'test_cert.pem'))]
 
79
  }, function() {
 
80
    assert(socket.authorized);
 
81
    socket.end();
 
82
    server.close();
 
83
  });
 
84
  socket.on('error', function(err) {
 
85
    assert(false);
 
86
  });
 
87
  socket.write('ok');
 
88
}
 
89
 
 
90
process.on('exit', function() {
 
91
  assert.equal(connectCount, 3);
 
92
});