-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
basicAuth.test.js
105 lines (88 loc) · 2.37 KB
/
basicAuth.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/**
* Module dependencies.
*/
var connect = require('../')
, assert = require('assert')
, http = require('http');
// sync
var app = connect(
connect.basicAuth(function(user, pass){
return 'tj' == user && 'tobi' == pass;
}),
function(req, res){
res.end('wahoo');
}
);
// async
var User = {
authenticate: function(query, fn){
if (query.name == 'tj' && query.pass == 'tobi') {
fn(null, { name: 'tj' });
} else {
fn(new Error('user not found'));
}
}
}
var async = connect(
connect.basicAuth(function(user, pass, fn){
User.authenticate({ name: user, pass: pass }, fn);
}),
function(req, res){
res.end('wahoo');
}
);
module.exports = {
'test user / pass options': function(){
var app = connect(
connect.basicAuth('tj', 'tobi'),
function(req, res){
res.send('wahoo');
}
);
assert.response(app,
{ url: '/' },
{ body: 'Unauthorized' });
assert.response(app,
{ url: '/', headers: { Authorization: 'Basic dGo6dG9iaQo=' }},
{ body: 'Unauthorized' });
},
'test missing Authorization field': function(){
assert.response(app,
{ url: '/' },
{ body: 'Unauthorized'
, status: 401
, headers: {
'WWW-Authenticate': 'Basic realm="Authorization Required"'
}});
},
'test authorized': function(){
assert.response(app,
{ url: '/', headers: { Authorization: 'Basic dGo6dG9iaQ==' }},
{ body: 'wahoo', status: 200 });
},
'test unauthorized': function(){
assert.response(app,
{ url: '/', headers: { Authorization: 'Basic dasdfasdfas' }},
{ body: 'Unauthorized', status: 401 });
},
'test bad request': function(){
assert.response(app,
{ url: '/', headers: { Authorization: 'Foo asdfasdf' }},
{ body: 'Bad Request', status: 400 });
},
'test async authorized': function(){
assert.response(async,
{ url: '/', headers: { Authorization: 'Basic dGo6dG9iaQ==' }},
{ body: 'wahoo', status: 200 });
},
'test async unauthorized': function(){
assert.response(async,
{ url: '/', headers: { Authorization: 'Basic dasdfasdfas' }},
{ body: 'Unauthorized', status: 401 });
},
'test async bad request': function(){
assert.response(async,
{ url: '/', headers: { Authorization: 'Foo asdfasdf' }},
{ body: 'Bad Request', status: 400 });
},
};