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 'DBIx::Class::Schema::Loader';
|
||||||
requires 'SQL::Translator';
|
requires 'SQL::Translator';
|
||||||
requires 'DateTime';
|
requires 'DateTime';
|
||||||
|
requires 'DateTime::Format::SQLite';
|
||||||
requires 'TryCatch';
|
requires 'TryCatch';
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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
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