#!/usr/bin/perl use strict; use warnings; use Test::More tests => 21; use Test::Exception; use Catalyst::Authentication::User; my $m; BEGIN { use_ok($m = "Catalyst::Plugin::Authorization::Roles") } my $user = MockUser->new; $user->roles(qw/admin user moose_trainer/); my $c = MockAuthz->new($user); can_ok( $m, "assert_user_roles" ); can_ok( $m, "check_user_roles" ); can_ok( $m, "assert_any_user_role" ); can_ok( $m, "check_any_user_role" ); lives_ok { $c->assert_user_roles( "admin" ) } "existing role is OK"; lives_ok { $c->assert_user_roles( $user->roles ) } "all roles is OK"; throws_ok { $c->assert_user_roles( "moose_feeder" ) } qr/missing role.*moose_feeder/i, "missing role throws error"; throws_ok { $c->assert_user_roles( qw/moose_trainer moose_feeder/ ) } qr/missing role.*moose_feeder/i, "also when there are existing roles"; throws_ok { $c->assert_user_roles( $user->roles, "moose_feeder" ) } qr/missing role.*moose_feeder/i, "even all roles"; lives_ok { $c->assert_any_user_role( qw/admin moose_feeder/ ) } "assert_any_user_role: has at least one role is OK"; lives_ok { $c->assert_any_user_role( $user->roles ) } "assert_any_user_role: has all roles is OK"; throws_ok { $c->assert_any_user_role( qw/moose_feeder climber/ ) } qr/missing role/i, "assert_any_user_role: has none of the listed roles"; ok( $c->check_user_roles( "admin" ), "check_user_roles true" ); ok( !$c->check_user_roles( "moose_feeder" ), "check_user_roles false" ); ok( $c->check_any_user_role( qw/admin moose_feeder/ ), "check_any_user_role true" ); ok( !$c->check_any_user_role( qw/moose_feeder climber/ ), "check_any_user_role false" ); $c = MockAuthz->new(undef); throws_ok { $c->assert_user_roles( "moose_trainer" ) } qr/no logged in user/i, "can't assert without logged user"; lives_ok { $c->assert_user_roles( $user, "moose_trainer" ) } "unless supplying user explicitly"; throws_ok { $c->assert_any_user_role( qw/moose_trainer/ ) } qr/no logged in user/i, "assert_any_user_role: can't assert without logged user"; lives_ok { $c->assert_any_user_role( $user, "moose_trainer" ) } "unless supplying user explicitly"; package MockAuthz; use base 'Catalyst::Plugin::Authorization::Roles'; sub new { my ($class, $user) = @_; return bless { user => $user }, $class; } sub user { return shift->{user}; } sub debug { return 0; } package MockUser; use base 'Catalyst::Authentication::User'; sub supported_features { return { roles => 1 } }; sub roles { my ($self, @roles) = @_; if (@roles) { $self->{_roles} = [@roles]; } $self->{_roles} ||= []; @{$self->{_roles}}; }