Mojolicious-Plugin-HttpBasicAuth

 view release on metacpan or  search on metacpan

t/basic.t  view on Meta::CPAN

#!perl
use Mojo::Base -strict;

use Test::More;
use Mojolicious::Lite;
use Mojo::ByteStream 'b';
use Test::Mojo;

my $tested_realm;
my $custom_setting;

sub validate {
    my $c = shift;
    my $u = shift;
    my $p = shift;
    my $r = shift;
    $tested_realm = $r;

    return 1 if ($u eq 'foo' && $p eq 'bar');
    return 0;
}

plugin 'http_basic_auth' => {
    validate => \&validate
};

get '/' => sub {
    my $c = shift;
    return unless $c->basic_auth($custom_setting);
    $c->render(text => 'Hello Mojo!');
};

get '/delayed' => sub {
    my $c = shift;
    $c->render_later;
    Mojo::IOLoop->timer(0 => sub {
        return unless $c->basic_auth($custom_setting);
        $c->render(text => 'Hello Mojo!');
    });
};

under sub {
    my $c = shift;
    return unless $c->basic_auth($custom_setting);
};

get '/under-bridge' => sub {
    my $c = shift;
    $c->render(text => 'Hello Mojo!');
};

helper unauthorized => sub {
    my $c = shift;
    $c->res->code(401);
    $c->render(json => { error => 'Authorization Required' });
};

my $t = Test::Mojo->new;

my @tests = (
    {
        name    => 'default',
        options => undef,
    },
    {
        name    => 'custom realm',
        options => {
            realm => 'FOO',
        },
    },
    {
        name    => 'custom validate',
        options => {
            validate => \&validate,
        },
    },
    {
        name    => 'custom invalid',
        options => {
            invalid => sub {
                any => { data => 'Authorization Required' }
            },
        },
    },
    {
        name    => 'custom invalid with sub',
        options => {
            invalid => sub {
                any => sub { shift->render(text => 'Authorization Required') }
            },
        },
    },
    {
        name    => 'custom invalid with helper',
        options => {
            invalid => sub {
                any => sub { shift->unauthorized }
            },
        },
    }
);

for my $uri (qw(/ /under-bridge /delayed)) {
    for my $test (@tests) {

        $custom_setting = $test->{settings};
        my $realm = $custom_setting->{realm} // 'WWW';
        note "Testing " . $uri . " with settings: " . $test->{name};

        # auth required
        $t->get_ok($uri)->status_is(401)->header_is('WWW-Authenticate' => "Basic realm=\"$realm\"")->content_like(qr/Authorization Required/);

        # via Browser credentials

        # auth passed
        my $url = $t->ua->server->url->userinfo('foo:bar')->path($uri);
        $t->get_ok($url)->status_is(200)->content_like(qr/Hello Mojo!/);
        is($tested_realm, $realm, 'Testing sub gets correct Realm');
        $tested_realm = undef;

        # password only
        $url = $t->ua->server->url->userinfo(':bar')->path($uri);
        $t->get_ok($url)->status_is(401)->header_is('WWW-Authenticate' => "Basic realm=\"$realm\"")->content_like(qr/Authorization Required/);

        # user only
        $url = $t->ua->server->url->userinfo('foo:')->path($uri);
        $t->get_ok($url)->status_is(401)->header_is('WWW-Authenticate' => "Basic realm=\"$realm\"")->content_like(qr/Authorization Required/);

        # empty
        $url = $t->ua->server->url->userinfo(':')->path($uri);
        $t->get_ok($url)->status_is(401)->header_is('WWW-Authenticate' => "Basic realm=\"$realm\"")->content_like(qr/Authorization Required/);

        # via http header



( run in 1.353 second using v1.01-cache-2.11-cpan-d8267643d1d )