Bug 28772: Fix Koha/Object.t
Koha::ApiKeys is no longer the simple object we need to test Koha::Object->store, let use Koha::Library::Groups Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
This commit is contained in:
parent
bded25d262
commit
206cafb8e8
1 changed files with 28 additions and 23 deletions
|
@ -32,7 +32,7 @@ use Koha::Acquisition::Orders;
|
|||
use Koha::DateUtils qw( dt_from_string );
|
||||
use Koha::Libraries;
|
||||
use Koha::Patrons;
|
||||
use Koha::ApiKeys;
|
||||
use Koha::Library::Groups;
|
||||
|
||||
use JSON;
|
||||
use Scalar::Util qw( isvstring );
|
||||
|
@ -628,24 +628,29 @@ subtest 'store() tests' => sub {
|
|||
|
||||
plan tests => 16;
|
||||
|
||||
# Using Koha::ApiKey to test Koha::Object>-store
|
||||
# Using Koha::Library::Groups to test Koha::Object>-store
|
||||
# Simple object with foreign keys and unique key
|
||||
|
||||
$schema->storage->txn_begin;
|
||||
|
||||
# Create a patron to make sure its ID doesn't exist on the DB
|
||||
my $patron = $builder->build_object({ class => 'Koha::Patrons' });
|
||||
my $patron_id = $patron->id;
|
||||
$patron->delete;
|
||||
# Create a library to make sure its ID doesn't exist on the DB
|
||||
my $library = $builder->build_object({ class => 'Koha::Libraries' });
|
||||
my $branchcode = $library->branchcode;
|
||||
$library->delete;
|
||||
|
||||
my $api_key = Koha::ApiKey->new({ patron_id => $patron_id, secret => 'a secret', description => 'a description' });
|
||||
my $library_group = Koha::Library::Group->new(
|
||||
{
|
||||
branchcode => $library->branchcode,
|
||||
title => 'a title',
|
||||
}
|
||||
);
|
||||
|
||||
my $dbh = $schema->storage->dbh;
|
||||
{
|
||||
local *STDERR;
|
||||
open STDERR, '>', '/dev/null';
|
||||
throws_ok
|
||||
{ $api_key->store }
|
||||
{ $library_group->store }
|
||||
'Koha::Exceptions::Object::FKConstraint',
|
||||
'Exception is thrown correctly';
|
||||
is(
|
||||
|
@ -655,21 +660,21 @@ subtest 'store() tests' => sub {
|
|||
);
|
||||
is(
|
||||
$@->broken_fk,
|
||||
'patron_id',
|
||||
'branchcode',
|
||||
'Exception field is correct'
|
||||
);
|
||||
|
||||
$patron = $builder->build_object({ class => 'Koha::Patrons' });
|
||||
$api_key = $builder->build_object({ class => 'Koha::ApiKeys' });
|
||||
$library_group = $builder->build_object({ class => 'Koha::Library::Groups' });
|
||||
|
||||
my $new_api_key = Koha::ApiKey->new({
|
||||
patron_id => $patron_id,
|
||||
secret => $api_key->secret,
|
||||
description => 'a description',
|
||||
});
|
||||
my $new_library_group = Koha::Library::Group->new(
|
||||
{
|
||||
branchcode => $library_group->branchcode,
|
||||
title => $library_group->title,
|
||||
}
|
||||
);
|
||||
|
||||
throws_ok
|
||||
{ $new_api_key->store }
|
||||
{ $new_library_group->store }
|
||||
'Koha::Exceptions::Object::DuplicateID',
|
||||
'Exception is thrown correctly';
|
||||
|
||||
|
@ -681,18 +686,18 @@ subtest 'store() tests' => sub {
|
|||
|
||||
like(
|
||||
$@->duplicate_id,
|
||||
qr/(api_keys\.)?secret/,
|
||||
qr/(library_groups\.)?title/,
|
||||
'Exception field is correct (note that MySQL 8 is displaying the tablename)'
|
||||
);
|
||||
close STDERR;
|
||||
}
|
||||
|
||||
# Successful test
|
||||
$api_key->set({ secret => 'Manuel' });
|
||||
my $ret = $api_key->store;
|
||||
is( ref($ret), 'Koha::ApiKey', 'store() returns the object on success' );
|
||||
$library_group->set({ title => 'Manuel' });
|
||||
my $ret = $library_group->store;
|
||||
is( ref($ret), 'Koha::Library::Group', 'store() returns the object on success' );
|
||||
|
||||
my $library = $builder->build_object( { class => 'Koha::Libraries' } );
|
||||
$library = $builder->build_object( { class => 'Koha::Libraries' } );
|
||||
my $patron_category = $builder->build_object(
|
||||
{
|
||||
class => 'Koha::Patron::Categories',
|
||||
|
@ -700,7 +705,7 @@ subtest 'store() tests' => sub {
|
|||
}
|
||||
);
|
||||
|
||||
$patron = eval {
|
||||
my $patron = eval {
|
||||
Koha::Patron->new(
|
||||
{
|
||||
categorycode => $patron_category->categorycode,
|
||||
|
|
Loading…
Reference in a new issue