Added admin test and logout function
This commit is contained in:
parent
b10daa469a
commit
a78de6ea8e
4 changed files with 106 additions and 0 deletions
1
cpanfile
1
cpanfile
|
@ -12,4 +12,5 @@ requires 'DBIx::Class';
|
|||
requires 'DBIx::Class::Schema::Loader';
|
||||
requires 'SQL::Translator';
|
||||
requires 'DateTime';
|
||||
requires 'DateTime::Format::SQLite';
|
||||
requires 'TryCatch';
|
||||
|
|
|
@ -49,6 +49,7 @@ sub startup {
|
|||
|
||||
my $r = $self->routes;
|
||||
$r->any('/')->to('root#index');
|
||||
$r->any('/logout')->to('root#auth_logout');
|
||||
$r->get('/admin')->to('admin#index');
|
||||
$r->post('/admin')->to('admin#login');
|
||||
my $api = $r->under('/api' => sub {
|
||||
|
|
|
@ -6,4 +6,12 @@ sub index {
|
|||
|
||||
}
|
||||
|
||||
sub auth_logout {
|
||||
my $c = shift;
|
||||
|
||||
$c->logout;
|
||||
$c->redirect_to('/');
|
||||
}
|
||||
|
||||
|
||||
1;
|
||||
|
|
96
t/admin/login.t
Normal file
96
t/admin/login.t
Normal 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;
|
||||
|
Reference in a new issue