Added admin test and logout function

This commit is contained in:
Tom Bloor 2017-04-08 13:38:54 +01:00
parent b10daa469a
commit a78de6ea8e
4 changed files with 106 additions and 0 deletions

View file

@ -12,4 +12,5 @@ requires 'DBIx::Class';
requires 'DBIx::Class::Schema::Loader'; requires 'DBIx::Class::Schema::Loader';
requires 'SQL::Translator'; requires 'SQL::Translator';
requires 'DateTime'; requires 'DateTime';
requires 'DateTime::Format::SQLite';
requires 'TryCatch'; requires 'TryCatch';

View file

@ -49,6 +49,7 @@ sub startup {
my $r = $self->routes; my $r = $self->routes;
$r->any('/')->to('root#index'); $r->any('/')->to('root#index');
$r->any('/logout')->to('root#auth_logout');
$r->get('/admin')->to('admin#index'); $r->get('/admin')->to('admin#index');
$r->post('/admin')->to('admin#login'); $r->post('/admin')->to('admin#login');
my $api = $r->under('/api' => sub { my $api = $r->under('/api' => sub {

View file

@ -6,4 +6,12 @@ sub index {
} }
sub auth_logout {
my $c = shift;
$c->logout;
$c->redirect_to('/');
}
1; 1;

96
t/admin/login.t Normal file
View file

@ -0,0 +1,96 @@
use strict;
use warnings;
use FindBin qw/ $Bin /;
use lib "$Bin/../../lib";
use File::Temp;
use Test::More;
use Test::Mojo;
use DateTime;
my $file = File::Temp->new;
print $file <<'END';
{
dsn => "dbi:SQLite::memory:",
user => undef,
pass => undef,
}
END
$file->seek( 0, SEEK_END );
$ENV{MOJO_CONFIG} = $file->filename;
my $t = Test::Mojo->new('Pear::LocalLoop');
my $schema = $t->app->schema;
$schema->deploy;
$schema->resultset('User')->create({
email => 'admin@example.com',
hashedpassword => $t->app->generate_hashed_password('abc123'),
administrator => {},
joindate => DateTime->now,
});
$schema->resultset('User')->create({
email => 'user@example.com',
hashedpassword => $t->app->generate_hashed_password('abc123'),
joindate => DateTime->now,
});
is $schema->resultset('User')->count, 2, 'Users Created';
is $schema->resultset('Administrator')->count, 1, 'Admin Created';
my $location_is = sub {
my ($t, $value, $desc) = @_;
$desc ||= "Location: $value";
local $Test::Builder::Level = $Test::Builder::Level + 1;
return $t->success(is($t->tx->res->headers->location, $value, $desc));
};
$t->get_ok('/admin')
->status_is(200)
->content_like(qr/Login/);
$t->ua->max_redirects(10);
$t->post_ok('/admin', form => {
email => 'user@example.com',
password => 'abc123',
})->status_is(200)
->content_like(qr/Hello!/, 'Redirected to root as not an admin');
$t->ua->max_redirects(0);
$t->get_ok('/admin/home')
->status_is(302)
->$location_is('/');
$t->get_ok('/logout')
->status_is(302)
->$location_is('/');
$t->get_ok('/admin/home')
->status_is(302)
->$location_is('/', 'Logged out');
$t->ua->max_redirects(10);
$t->post_ok('/admin', form => {
email => 'admin@example.com',
password => 'abc123',
})->status_is(200)
->content_like(qr/Admin/);
$t->ua->max_redirects(0);
$t->get_ok('/admin/home')
->status_is(200)
->content_like(qr/Admin/);
$t->get_ok('/logout')
->status_is(302)
->$location_is('/');
$t->get_ok('/admin/home')
->status_is(302)
->$location_is('/', 'Logged out');
done_testing;