Koha/t/db_dependent/api/v1/erm_eholdings_titles.t
Pedro Amorim 55f024c0e3
Bug 35115: (QA follow-up):
Spelling.
Tidyness.
Removal of leftover warn

Nick's patch fixes the issue as described, and I agree that it is the ideal solution here.
prove t/db_dependent/api/v1/erm_eholdings* passes
prove t/db_dependent/Koha/BackgroundJob/CreateEHoldingsFromBiblios.t passes

Signed-off-by: Pedro Amorim <pedro.amorim@ptfs-europe.com>
Signed-off-by: Victor Grousset/tuxayo <victor@tuxayo.net>
Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
2023-11-29 17:36:10 -03:00

548 lines
19 KiB
Perl
Executable file

#!/usr/bin/env perl
# This file is part of Koha.
#
# Koha is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
#
# Koha is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Koha; if not, see <http://www.gnu.org/licenses>.
use Modern::Perl;
use Test::More tests => 5;
use Test::Mojo;
use t::lib::TestBuilder;
use t::lib::Mocks;
use C4::Biblio qw( GetMarcFromKohaField );
use Koha::ERM::EHoldings::Titles;
use Koha::ERM::EHoldings::Packages;
use Koha::Virtualshelves;
use Koha::Database;
my $schema = Koha::Database->new->schema;
my $builder = t::lib::TestBuilder->new;
my $t = Test::Mojo->new('Koha::REST::V1');
t::lib::Mocks::mock_preference( 'RESTBasicAuth', 1 );
subtest 'list() tests' => sub {
plan tests => 23;
$schema->storage->txn_begin;
Koha::ERM::EHoldings::Titles->search->delete;
my $librarian = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 2**28 }
}
);
my $password = 'thePassword123';
$librarian->set_password( { password => $password, skip_validation => 1 } );
my $userid = $librarian->userid;
my $patron = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 0 }
}
);
$patron->set_password( { password => $password, skip_validation => 1 } );
my $unauth_userid = $patron->userid;
## Authorized user tests
# No EHoldings title, so empty array should be returned
$t->get_ok("//$userid:$password@/api/v1/erm/eholdings/local/titles")
->status_is(200)->json_is( [] );
my $ehtitle =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
# One EHoldings title created, should get returned
$t->get_ok("//$userid:$password@/api/v1/erm/eholdings/local/titles")
->status_is(200)->json_is( [ $ehtitle->to_api ] );
my $another_ehtitle = $builder->build_object(
{
class => 'Koha::ERM::EHoldings::Titles',
value => { publication_type => $ehtitle->publication_type }
}
);
my $ehtitle_with_another_publication_type =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
# Two EHoldings titles created, they should both be returned
$t->get_ok("//$userid:$password@/api/v1/erm/eholdings/local/titles")
->status_is(200)->json_is(
[
$ehtitle->to_api,
$another_ehtitle->to_api,
$ehtitle_with_another_publication_type->to_api
]
);
# Filtering works, two EHoldings titles sharing publication_type
$t->get_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles?publication_type="
. $ehtitle->publication_type )->status_is(200)
->json_is( [ $ehtitle->to_api, $another_ehtitle->to_api ] );
# Attempt to search by publication_title like 'ko'
$ehtitle->delete;
$another_ehtitle->delete;
$ehtitle_with_another_publication_type->delete;
$t->get_ok(qq~//$userid:$password@/api/v1/erm/eholdings/local/titles?q=[{"me.publication_title":{"like":"%ko%"}}]~)
->status_is(200)->json_is( [] );
my $ehtitle_to_search = $builder->build_object(
{
class => 'Koha::ERM::EHoldings::Titles',
value => {
publication_title => 'koha',
}
}
);
# Search works, searching for publication_title like 'ko'
$t->get_ok(qq~//$userid:$password@/api/v1/erm/eholdings/local/titles?q=[{"me.publication_title":{"like":"%ko%"}}]~)
->status_is(200)->json_is( [ $ehtitle_to_search->to_api ] );
# Warn on unsupported query parameter
$t->get_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles?blah=blah")
->status_is(400)
->json_is(
[ { path => '/query/blah', message => 'Malformed query string' } ] );
# Unauthorized access
$t->get_ok("//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles")
->status_is(403);
$schema->storage->txn_rollback;
};
subtest 'get() tests' => sub {
plan tests => 11;
$schema->storage->txn_begin;
my $ehtitle =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
my $librarian = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 2**28 }
}
);
my $password = 'thePassword123';
$librarian->set_password( { password => $password, skip_validation => 1 } );
my $userid = $librarian->userid;
my $patron = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 0 }
}
);
$patron->set_password( { password => $password, skip_validation => 1 } );
my $unauth_userid = $patron->userid;
# This EHoldings title exists, should get returned
$t->get_ok( "//$userid:$password@/api/v1/erm/eholdings/local/titles/"
. $ehtitle->title_id )->status_is(200)->json_is( $ehtitle->to_api );
# Return one EHoldings title with embed
$t->get_ok( "//$userid:$password@/api/v1/erm/eholdings/local/titles/"
. $ehtitle->title_id =>
{ 'x-koha-embed' => 'resources,resources.package' } )->status_is(200)
->json_is( { %{ $ehtitle->to_api }, resources => [] } );
# Unauthorized access
$t->get_ok( "//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles/"
. $ehtitle->title_id )->status_is(403);
# Attempt to get non-existent EHoldings title
my $ehtitle_to_delete =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
my $non_existent_id = $ehtitle_to_delete->title_id;
$ehtitle_to_delete->delete;
$t->get_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$non_existent_id"
)->status_is(404)->json_is( '/error' => 'eHolding title not found' );
$schema->storage->txn_rollback;
};
subtest 'add() tests' => sub {
plan tests => 24;
$schema->storage->txn_begin;
my $librarian = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 2**28 }
}
);
my $password = 'thePassword123';
$librarian->set_password( { password => $password, skip_validation => 1 } );
my $userid = $librarian->userid;
my $patron = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 0 }
}
);
$patron->set_password( { password => $password, skip_validation => 1 } );
my $unauth_userid = $patron->userid;
my $ehtitle = {
publication_title => "Publication title",
print_identifier => "Print-format identifier",
online_identifier => "Online-format identifier",
date_first_issue_online =>
"Date of first serial issue available online",
num_first_vol_online => "Number of first volume available online",
num_first_issue_online => "Number of first issue available online",
date_last_issue_online => "Date of last issue available online",
num_last_vol_online => "Number of last volume available online",
num_last_issue_online => "Number of last issue available online",
title_url => "Title-level URL",
first_author => "First author",
embargo_info => "Embargo information",
coverage_depth => "Coverage depth",
notes => "Notes",
publisher_name => "Publisher name",
publication_type => "Book",
date_monograph_published_print =>
"Date the monograph is first published in print",
date_monograph_published_online =>
"Date the monograph is first published online",
monograph_volume => "Number of volume for monograph",
monograph_edition => "Edition of the monograph",
first_editor => "First editor",
parent_publication_title_id =>
"Title identifier of the parent publication",
preceding_publication_title_id =>
"Title identifier of any preceding publication title",
access_type => "Access type"
};
# Unauthorized attempt to write
$t->post_ok(
"//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles" =>
json => $ehtitle )->status_is(403);
# Authorized attempt to write invalid data
my $ehtitle_with_invalid_field = {
blah => "EHolding Title Blah",
publication_title => "Publication title",
print_identifier => "Print-format identifier"
};
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
$ehtitle_with_invalid_field )->status_is(400)->json_is(
"/errors" => [
{
message => "Properties not allowed: blah.",
path => "/body"
}
]
);
# Authorized attempt to write
my $ehtitle_id =
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
$ehtitle )->status_is( 201, 'SWAGGER3.2.1' )->header_like(
Location => qr|^/api/v1/erm/eholdings/local/titles/\d*|,
'SWAGGER3.4.1'
)->json_is( '/publication_title' => $ehtitle->{publication_title} )
->json_is( '/print_identifier' => $ehtitle->{print_identifier} )
->json_is( '/notes' => $ehtitle->{notes} )
->json_is( '/publisher_name' => $ehtitle->{publisher_name} )
->tx->res->json->{title_id};
# Import titles from virtualshelf to package
my $ehpackage_id =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Packages' } )
->package_id;
my $virtual_shelf =
$builder->build_object(
{
class => 'Koha::Virtualshelves',
} );
$virtual_shelf->transfer_ownership($librarian->borrowernumber);
my $virtual_shelf_id = $virtual_shelf->shelfnumber;
my $import_request =
{
list_id => $virtual_shelf_id,
package_id => $ehpackage_id
};
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/import" => json =>
$import_request )->status_is(201)->json_has('/job_id');
# Attempt to import titles from a virtualshelf that doesn't exist
$virtual_shelf->delete;
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/import" => json =>
$import_request )->status_is(404)->json_is(
{ error => 'List not found' }
);
# Authorized attempt to create with null id
$ehtitle->{title_id} = undef;
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
$ehtitle )->status_is(400)->json_has('/errors');
# Authorized attempt to create with existing id
$ehtitle->{title_id} = $ehtitle_id;
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
$ehtitle )->status_is(400)->json_is(
"/errors" => [
{
message => "Read-only.",
path => "/body/title_id"
}
]
);
$schema->storage->txn_rollback;
};
subtest 'update() tests' => sub {
plan tests => 16;
$schema->storage->txn_begin;
my $librarian = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 2**28 }
}
);
my $password = 'thePassword123';
$librarian->set_password( { password => $password, skip_validation => 1 } );
my $userid = $librarian->userid;
my $patron = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 0 }
}
);
$patron->set_password( { password => $password, skip_validation => 1 } );
my $unauth_userid = $patron->userid;
my $ehtitle_id =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles', value => { biblio_id => undef } } )
->title_id;
# Unauthorized attempt to update
$t->put_ok(
"//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id"
=> json =>
{ publication_title => 'New unauthorized publication_title change' } )
->status_is(403);
# Attempt partial update on a PUT
my $ehtitle_with_missing_field = { date_first_issue_online =>
"Date of first serial issue available online", };
$t->put_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
json => $ehtitle_with_missing_field )->status_is(400)->json_is(
"/errors" => [
{
message => "Missing property.",
path => "/body/publication_title"
}
]
);
# Full object update on PUT
my $ehtitle_with_updated_field = {
publication_title => "Publication title",
print_identifier => "Print-format identifier",
online_identifier => "Online-format identifier",
date_first_issue_online =>
"Date of first serial issue available online",
num_first_vol_online => "Number of first volume available online",
num_first_issue_online => "Number of first issue available online",
date_last_issue_online => "Date of last issue available online",
num_last_vol_online => "Number of last volume available online",
num_last_issue_online => "Number of last issue available online",
title_url => "Title-level URL",
first_author => "First author",
embargo_info => "Embargo information",
coverage_depth => "Coverage depth",
notes => "Notes",
publisher_name => "Publisher name",
publication_type => "Book",
date_monograph_published_print =>
"Date the monograph is first published in print",
date_monograph_published_online =>
"Date the monograph is first published online",
monograph_volume => "Number of volume for monograph",
monograph_edition => "Edition of the monograph",
first_editor => "First editor",
parent_publication_title_id =>
"Title identifier of the parent publication",
preceding_publication_title_id =>
"Title identifier of any preceding publication title",
access_type => "Access type"
};
$t->put_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
json => $ehtitle_with_updated_field )->status_is(200)
->json_is( '/publication_title' => 'Publication title' );
# Authorized attempt to write invalid data
my $ehtitle_with_invalid_field = {
blah => "EHolding Title Blah",
publication_title => "Publication title",
print_identifier => "Print-format identifier"
};
$t->put_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
json => $ehtitle_with_invalid_field )->status_is(400)->json_is(
"/errors" => [
{
message => "Properties not allowed: blah.",
path => "/body"
}
]
);
# Attempt to update non-existent EHolding title
my $ehtitle_to_delete =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
my $non_existent_id = $ehtitle_to_delete->title_id;
$ehtitle_to_delete->delete;
$t->put_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$non_existent_id"
=> json => $ehtitle_with_updated_field )->status_is(404);
# Wrong method (POST)
$ehtitle_with_updated_field->{title_id} = 2;
$t->post_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
json => $ehtitle_with_updated_field )->status_is(404);
subtest 'update eholdings title linked to biblio tests' => sub {
plan tests => 6;
my $biblio = $builder->build_sample_biblio();
my $record = $biblio->metadata->record();
my $ehtitle_id =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles', value => { biblio_id => $biblio->id } } )
->title_id;
my $ehtitle_updated_title = { publication_title => "The journal of writing unit tests :" };
$t->put_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" => json => $ehtitle_updated_title )
->status_is(200)->json_is( '/publication_title' => 'The journal of writing unit tests :' );
$biblio->discard_changes;
my $record_after = $biblio->metadata->record;
my ( $title_tag, $title_subfield ) = GetMarcFromKohaField('biblio.title');
is(
$record_after->subfield( $title_tag, $title_subfield ), "The journal of writing unit tests :",
"Biblio title is correctly updated by eholding title update"
);
is( $record->fields(), $record_after->fields(), "We have the same number of fields after edit" );
my ($author_tag) = GetMarcFromKohaField('biblio.author');
my $old_author = $record->field($author_tag);
my $new_author = $record_after->field($author_tag);
is( $old_author->as_string, $new_author->as_string, "The record is otherwise untouched" );
};
$schema->storage->txn_rollback;
};
subtest 'delete() tests' => sub {
plan tests => 7;
$schema->storage->txn_begin;
my $librarian = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 2**28 }
}
);
my $password = 'thePassword123';
$librarian->set_password( { password => $password, skip_validation => 1 } );
my $userid = $librarian->userid;
my $patron = $builder->build_object(
{
class => 'Koha::Patrons',
value => { flags => 0 }
}
);
$patron->set_password( { password => $password, skip_validation => 1 } );
my $unauth_userid = $patron->userid;
my $ehtitle_id =
$builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } )
->title_id;
# Unauthorized attempt to delete
$t->delete_ok(
"//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id"
)->status_is(403);
# Delete existing EHolding title
$t->delete_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id")
->status_is( 204, 'SWAGGER3.2.4' )->content_is( '', 'SWAGGER3.3.4' );
# Attempt to delete non-existent EHolding title
$t->delete_ok(
"//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id")
->status_is(404);
$schema->storage->txn_rollback;
};