|
|
|
var assert = require('assert')
|
|
|
|
, http = require('http')
|
|
|
|
, request = require('../index')
|
|
|
|
;
|
|
|
|
|
|
|
|
var numBasicRequests = 0;
|
|
|
|
|
|
|
|
var basicServer = http.createServer(function (req, res) {
|
|
|
|
console.error('Basic auth server: ', req.method, req.url);
|
|
|
|
numBasicRequests++;
|
|
|
|
|
|
|
|
var ok;
|
|
|
|
|
|
|
|
if (req.headers.authorization) {
|
|
|
|
if (req.headers.authorization == 'Basic ' + new Buffer('test:testing2').toString('base64')) {
|
|
|
|
ok = true;
|
|
|
|
} else if ( req.headers.authorization == 'Basic ' + new Buffer(':apassword').toString('base64')) {
|
|
|
|
ok = true;
|
|
|
|
} else if ( req.headers.authorization == 'Basic ' + new Buffer('justauser').toString('base64')) {
|
|
|
|
ok = true;
|
|
|
|
} else {
|
|
|
|
// Bad auth header, don't send back WWW-Authenticate header
|
|
|
|
ok = false;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// No auth header, send back WWW-Authenticate header
|
|
|
|
ok = false;
|
|
|
|
res.setHeader('www-authenticate', 'Basic realm="Private"');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (req.url == '/post/') {
|
|
|
|
var expectedContent = 'data_key=data_value';
|
|
|
|
req.on('data', function(data) {
|
|
|
|
assert.equal(data, expectedContent);
|
|
|
|
console.log('received request data: ' + data);
|
|
|
|
});
|
|
|
|
assert.equal(req.method, 'POST');
|
|
|
|
assert.equal(req.headers['content-length'], '' + expectedContent.length);
|
|
|
|
assert.equal(req.headers['content-type'], 'application/x-www-form-urlencoded; charset=utf-8');
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ok) {
|
|
|
|
console.log('request ok');
|
|
|
|
res.end('ok');
|
|
|
|
} else {
|
|
|
|
console.log('status=401');
|
|
|
|
res.statusCode = 401;
|
|
|
|
res.end('401');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
basicServer.listen(6767);
|
|
|
|
|
|
|
|
var tests = [
|
|
|
|
function(next) {
|
|
|
|
request({
|
|
|
|
'method': 'GET',
|
|
|
|
'uri': 'http://localhost:6767/test/',
|
|
|
|
'auth': {
|
|
|
|
'user': 'test',
|
|
|
|
'pass': 'testing2',
|
|
|
|
'sendImmediately': false
|
|
|
|
}
|
|
|
|
}, function(error, res, body) {
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert.equal(numBasicRequests, 2);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
// If we don't set sendImmediately = false, request will send basic auth
|
|
|
|
request({
|
|
|
|
'method': 'GET',
|
|
|
|
'uri': 'http://localhost:6767/test2/',
|
|
|
|
'auth': {
|
|
|
|
'user': 'test',
|
|
|
|
'pass': 'testing2'
|
|
|
|
}
|
|
|
|
}, function(error, res, body) {
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert.equal(numBasicRequests, 3);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
request({
|
|
|
|
'method': 'GET',
|
|
|
|
'uri': 'http://test:testing2@localhost:6767/test2/'
|
|
|
|
}, function(error, res, body) {
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert.equal(numBasicRequests, 4);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
request({
|
|
|
|
'method': 'POST',
|
|
|
|
'form': { 'data_key': 'data_value' },
|
|
|
|
'uri': 'http://localhost:6767/post/',
|
|
|
|
'auth': {
|
|
|
|
'user': 'test',
|
|
|
|
'pass': 'testing2',
|
|
|
|
'sendImmediately': false
|
|
|
|
}
|
|
|
|
}, function(error, res, body) {
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert.equal(numBasicRequests, 6);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
assert.doesNotThrow( function() {
|
|
|
|
request({
|
|
|
|
'method': 'GET',
|
|
|
|
'uri': 'http://localhost:6767/allow_empty_user/',
|
|
|
|
'auth': {
|
|
|
|
'user': '',
|
|
|
|
'pass': 'apassword',
|
|
|
|
'sendImmediately': false
|
|
|
|
}
|
|
|
|
}, function(error, res, body ) {
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert.equal(numBasicRequests, 8);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
assert.doesNotThrow( function() {
|
|
|
|
request({
|
|
|
|
'method': 'GET',
|
|
|
|
'uri': 'http://localhost:6767/allow_undefined_password/',
|
|
|
|
'auth': {
|
|
|
|
'user': 'justauser',
|
|
|
|
'pass': undefined,
|
|
|
|
'sendImmediately': false
|
|
|
|
}
|
|
|
|
}, function(error, res, body ) {
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert.equal(numBasicRequests, 10);
|
|
|
|
next();
|
|
|
|
});
|
|
|
|
})
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
function runTest(i) {
|
|
|
|
if (i < tests.length) {
|
|
|
|
tests[i](function() {
|
|
|
|
runTest(i + 1);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
console.log('All tests passed');
|
|
|
|
basicServer.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
runTest(0);
|