Catalyst-Plugin-OIDC
view release on metacpan or search on metacpan
t/auth-code-flow-IT.t view on Meta::CPAN
#!/usr/bin/env perl
use utf8;
use strict;
use warnings;
use Test::More;
use Test::MockModule;
use HTTP::Request::Common;
use HTTP::Cookies;
use FindBin qw($Bin);
use lib "$Bin/auth-code-flow-IT/MyCatalystApp/lib";
local $ENV{MOJO_LOG_LEVEL} = 'error';
local @ARGV = ('version');
my $provider_app = require "$Bin/auth-code-flow-IT/MyProviderApp/app.pl";
my $mock_oidc_client = Test::MockModule->new('OIDC::Client');
$mock_oidc_client->redefine('kid_keys' => sub { {} });
$mock_oidc_client->redefine('user_agent' => $provider_app->ua);
my $mock_data_uuid = Test::MockModule->new('Data::UUID');
$mock_data_uuid->redefine('create_str' => sub { 'fake_uuid' });
require Catalyst::Test;
Catalyst::Test->import('MyCatalystApp');
subtest 'Get public index page' => sub {
my $res = request('/');
ok($res->is_success, 'Status in success');
like( $res->content, qr/Welcome/, 'Expected text');
};
subtest 'Get protected page in error because invalid token format' => sub {
my $res = request('/protected');
ok($res->is_redirect, 'Response is a redirect');
like($res->header('Location'), qr[/authorize\?.+], 'Redirection to the authorize endpoint');
$res = follow_redirects($res);
is($res->code, 401, 'Expected error code');
is($res->content, 'Authentication Error', 'Expected error message');
};
my $mock_crypt_jwt = Test::MockModule->new('Crypt::JWT');
$mock_crypt_jwt->redefine('decode_jwt' => sub {
my %params = @_;
my %claims = (
iss => 'my_issuer',
iat => time - 10,
exp => time + 30,
aud => 'my_id',
sub => 'my_subject',
nonce => 'fake_uuid',
);
return (
$params{decode_header} ? { 'alg' => 'whatever' } : (),
\%claims,
);
});
subtest 'Get protected page ok' => sub {
my $res = request('/protected?a=b&c=d');
ok($res->is_redirect, 'Response is a redirect');
like($res->header('Location'), qr[/authorize\?.+], 'Redirection to the authorize endpoint');
$res = follow_redirects($res);
ok($res->is_success, 'Status in success');
like($res->content, qr/my_subject is authenticated/, 'Expected text');
like($res->request->uri, qr[/protected\?a=b&c=d$],
'Initial url is kept');
};
done_testing;
sub follow_redirects {
my ($res, $max_redirects) = @_;
$max_redirects //= 3;
( run in 1.931 second using v1.01-cache-2.11-cpan-39bf76dae61 )