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
|
#!/usr/bin/env perl
use strict;
use warnings;
use Test::More;
use Plack::Test;
use HTTP::Request::Common;
use Path::Class;
use Plack::Builder;
{
my $app = builder {
enable 'Auth::Htpasswd',
file => file(__FILE__)->dir->subdir('data', '01')->file('htpasswd');
sub {
[
200,
[ 'Content-Type' => 'text/plain' ],
[ "Hello $_[0]->{REMOTE_USER}" ],
]
};
};
test_psgi app => $app, client => sub {
my $cb = shift;
{
my $res = $cb->(GET "/");
is($res->code, 401, "plain request gets 401");
}
{
my $res = $cb->(
GET "/", "Authorization" => "Basic dGVzdDplZGNiYQ==",
);
is($res->code, 401, "request with wrong password gets 401");
}
{
my $res = $cb->(
GET "/", "Authorization" => "Basic dHNldDphYmNkZQ==",
);
is($res->code, 401, "request with unknown username gets 401");
}
{
my $res = $cb->(
GET "/", "Authorization" => "Basic dGVzdDphYmNkZQ==",
);
is($res->code, 200, "valid authentication succeeds");
is($res->content, "Hello test", "and gets the right content");
}
};
}
{
my $app = builder {
enable 'Auth::Htpasswd',
file => file(__FILE__)->dir->subdir('data', '01', 'htpasswd'),
realm => 'my realm';
sub {
[
200,
[ 'Content-Type' => 'text/plain' ],
[ "Hello $_[0]->{REMOTE_USER}" ],
]
};
};
test_psgi app => $app, client => sub {
my $cb = shift;
{
my $res = $cb->(GET "/");
is($res->header('WWW-Authenticate'), 'Basic realm="my realm"',
"can set realm");
}
};
}
done_testing;
|