Switch repository to git (fREW Schmidt)
[catagits/Catalyst-Authentication-Store-DBIx-Class.git] / t / 08-simpledb-auth-roles-relationship.t
CommitLineData
81703a24 1#!perl
2
3use strict;
4use warnings;
5use DBI;
6use File::Path;
7use FindBin;
8use Test::More;
9use lib "$FindBin::Bin/lib";
10
11BEGIN {
12 eval { require DBD::SQLite }
13 or plan skip_all =>
14 "DBD::SQLite is required for this test";
15
16 eval { require DBIx::Class }
17 or plan skip_all =>
18 "DBIx::Class is required for this test";
19
20 eval { require Catalyst::Plugin::Authorization::Roles }
21 or plan skip_all =>
22 "Catalyst::Plugin::Authorization::Roles is required for this test";
23
24 plan tests => 8;
25
81703a24 26 $ENV{TESTAPP_CONFIG} = {
27 name => 'TestApp',
28 'Plugin::Authentication' => {
29 default => {
30 class => 'SimpleDB',
31 user_model => 'TestApp::User',
c388ac9d 32 password_type => 'clear'
81703a24 33 }
34 }
35 };
36
37 $ENV{TESTAPP_PLUGINS} = [
38 qw/Authentication
39 Authorization::Roles
40 /
41 ];
42}
43
81703a24 44use Catalyst::Test 'TestApp';
45
46# test user's admin access
47{
48 ok( my $res = request('http://localhost/user_login?username=jayk&password=letmein&detach=is_admin'), 'request ok' );
49 is( $res->content, 'ok', 'user is an admin' );
50}
51
52# test unauthorized user's admin access
53{
54 ok( my $res = request('http://localhost/user_login?username=nuffin&password=much&detach=is_admin'), 'request ok' );
55 is( $res->content, 'failed', 'user is not an admin' );
56}
57
58# test multiple auth roles
59{
60 ok( my $res = request('http://localhost/user_login?username=jayk&password=letmein&detach=is_admin_user'), 'request ok' );
61 is( $res->content, 'ok', 'user is an admin and a user' );
62}
63
64# test multiple unauth roles
65{
66 ok( my $res = request('http://localhost/user_login?username=nuffin&password=much&detach=is_admin_user'), 'request ok' );
67 is( $res->content, 'failed', 'user is not an admin and a user' );
68}