3 # This file is part of Koha.
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
20 use Test::More tests => 5;
23 use t::lib::TestBuilder;
26 use Koha::ERM::EHoldings::Titles;
27 use Koha::ERM::EHoldings::Packages;
28 use Koha::Virtualshelves;
31 my $schema = Koha::Database->new->schema;
32 my $builder = t::lib::TestBuilder->new;
34 my $t = Test::Mojo->new('Koha::REST::V1');
35 t::lib::Mocks::mock_preference( 'RESTBasicAuth', 1 );
37 subtest 'list() tests' => sub {
41 $schema->storage->txn_begin;
43 Koha::ERM::EHoldings::Titles->search->delete;
45 my $librarian = $builder->build_object(
47 class => 'Koha::Patrons',
48 value => { flags => 2**28 }
51 my $password = 'thePassword123';
52 $librarian->set_password( { password => $password, skip_validation => 1 } );
53 my $userid = $librarian->userid;
55 my $patron = $builder->build_object(
57 class => 'Koha::Patrons',
58 value => { flags => 0 }
62 $patron->set_password( { password => $password, skip_validation => 1 } );
63 my $unauth_userid = $patron->userid;
65 ## Authorized user tests
66 # No EHoldings title, so empty array should be returned
67 $t->get_ok("//$userid:$password@/api/v1/erm/eholdings/local/titles")
68 ->status_is(200)->json_is( [] );
71 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
73 # One EHoldings title created, should get returned
74 $t->get_ok("//$userid:$password@/api/v1/erm/eholdings/local/titles")
75 ->status_is(200)->json_is( [ $ehtitle->to_api ] );
77 my $another_ehtitle = $builder->build_object(
79 class => 'Koha::ERM::EHoldings::Titles',
80 value => { publication_type => $ehtitle->publication_type }
83 my $ehtitle_with_another_publication_type =
84 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
86 # Two EHoldings titles created, they should both be returned
87 $t->get_ok("//$userid:$password@/api/v1/erm/eholdings/local/titles")
88 ->status_is(200)->json_is(
91 $another_ehtitle->to_api,
92 $ehtitle_with_another_publication_type->to_api
96 # Filtering works, two EHoldings titles sharing publication_type
98 "//$userid:$password@/api/v1/erm/eholdings/local/titles?publication_type="
99 . $ehtitle->publication_type )->status_is(200)
100 ->json_is( [ $ehtitle->to_api, $another_ehtitle->to_api ] );
102 # Attempt to search by publication_title like 'ko'
104 $another_ehtitle->delete;
105 $ehtitle_with_another_publication_type->delete;
106 $t->get_ok(qq~//$userid:$password@/api/v1/erm/eholdings/local/titles?q=[{"me.publication_title":{"like":"%ko%"}}]~)
107 ->status_is(200)->json_is( [] );
109 my $ehtitle_to_search = $builder->build_object(
111 class => 'Koha::ERM::EHoldings::Titles',
113 publication_title => 'koha',
118 # Search works, searching for publication_title like 'ko'
119 $t->get_ok(qq~//$userid:$password@/api/v1/erm/eholdings/local/titles?q=[{"me.publication_title":{"like":"%ko%"}}]~)
120 ->status_is(200)->json_is( [ $ehtitle_to_search->to_api ] );
122 # Warn on unsupported query parameter
124 "//$userid:$password@/api/v1/erm/eholdings/local/titles?blah=blah")
127 [ { path => '/query/blah', message => 'Malformed query string' } ] );
129 # Unauthorized access
130 $t->get_ok("//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles")
133 $schema->storage->txn_rollback;
136 subtest 'get() tests' => sub {
140 $schema->storage->txn_begin;
143 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
144 my $librarian = $builder->build_object(
146 class => 'Koha::Patrons',
147 value => { flags => 2**28 }
150 my $password = 'thePassword123';
151 $librarian->set_password( { password => $password, skip_validation => 1 } );
152 my $userid = $librarian->userid;
154 my $patron = $builder->build_object(
156 class => 'Koha::Patrons',
157 value => { flags => 0 }
161 $patron->set_password( { password => $password, skip_validation => 1 } );
162 my $unauth_userid = $patron->userid;
164 # This EHoldings title exists, should get returned
165 $t->get_ok( "//$userid:$password@/api/v1/erm/eholdings/local/titles/"
166 . $ehtitle->title_id )->status_is(200)->json_is( $ehtitle->to_api );
168 # Return one EHoldings title with embed
169 $t->get_ok( "//$userid:$password@/api/v1/erm/eholdings/local/titles/"
170 . $ehtitle->title_id =>
171 { 'x-koha-embed' => 'resources,resources.package' } )->status_is(200)
172 ->json_is( { %{ $ehtitle->to_api }, resources => [] } );
174 # Unauthorized access
175 $t->get_ok( "//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles/"
176 . $ehtitle->title_id )->status_is(403);
178 # Attempt to get non-existent EHoldings title
179 my $ehtitle_to_delete =
180 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
181 my $non_existent_id = $ehtitle_to_delete->title_id;
182 $ehtitle_to_delete->delete;
185 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$non_existent_id"
186 )->status_is(404)->json_is( '/error' => 'eHolding title not found' );
188 $schema->storage->txn_rollback;
191 subtest 'add() tests' => sub {
195 $schema->storage->txn_begin;
197 my $librarian = $builder->build_object(
199 class => 'Koha::Patrons',
200 value => { flags => 2**28 }
203 my $password = 'thePassword123';
204 $librarian->set_password( { password => $password, skip_validation => 1 } );
205 my $userid = $librarian->userid;
207 my $patron = $builder->build_object(
209 class => 'Koha::Patrons',
210 value => { flags => 0 }
214 $patron->set_password( { password => $password, skip_validation => 1 } );
215 my $unauth_userid = $patron->userid;
218 publication_title => "Publication title",
219 print_identifier => "Print-format identifier",
220 online_identifier => "Online-format identifier",
221 date_first_issue_online =>
222 "Date of first serial issue available online",
223 num_first_vol_online => "Number of first volume available online",
224 num_first_issue_online => "Number of first issue available online",
225 date_last_issue_online => "Date of last issue available online",
226 num_last_vol_online => "Number of last volume available online",
227 num_last_issue_online => "Number of last issue available online",
228 title_url => "Title-level URL",
229 first_author => "First author",
230 embargo_info => "Embargo information",
231 coverage_depth => "Coverage depth",
233 publisher_name => "Publisher name",
234 publication_type => "Book",
235 date_monograph_published_print =>
236 "Date the monograph is first published in print",
237 date_monograph_published_online =>
238 "Date the monograph is first published online",
239 monograph_volume => "Number of volume for monograph",
240 monograph_edition => "Edition of the monograph",
241 first_editor => "First editor",
242 parent_publication_title_id =>
243 "Title identifier of the parent publication",
244 preceeding_publication_title_id =>
245 "Title identifier of any preceding publication title",
246 access_type => "Access type"
249 # Unauthorized attempt to write
251 "//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles" =>
252 json => $ehtitle )->status_is(403);
254 # Authorized attempt to write invalid data
255 my $ehtitle_with_invalid_field = {
256 blah => "EHolding Title Blah",
257 publication_title => "Publication title",
258 print_identifier => "Print-format identifier"
262 "//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
263 $ehtitle_with_invalid_field )->status_is(400)->json_is(
266 message => "Properties not allowed: blah.",
272 # Authorized attempt to write
275 "//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
276 $ehtitle )->status_is( 201, 'SWAGGER3.2.1' )->header_like(
277 Location => qr|^/api/v1/erm/eholdings/local/titles/\d*|,
279 )->json_is( '/publication_title' => $ehtitle->{publication_title} )
280 ->json_is( '/print_identifier' => $ehtitle->{print_identifier} )
281 ->json_is( '/notes' => $ehtitle->{notes} )
282 ->json_is( '/publisher_name' => $ehtitle->{publisher_name} )
283 ->tx->res->json->{title_id};
285 # Import titles from virtualshelf to package
287 $builder->build_object( { class => 'Koha::ERM::EHoldings::Packages' } )
291 $builder->build_object(
293 class => 'Koha::Virtualshelves',
295 $virtual_shelf->transfer_ownership($librarian->borrowernumber);
296 my $virtual_shelf_id = $virtual_shelf->shelfnumber;
300 list_id => $virtual_shelf_id,
301 package_id => $ehpackage_id
305 "//$userid:$password@/api/v1/erm/eholdings/local/titles/import" => json =>
306 $import_request )->status_is(201)->json_has('/job_id');
308 # Attempt to import titles from a virtualshelf that doesn't exist
309 $virtual_shelf->delete;
311 "//$userid:$password@/api/v1/erm/eholdings/local/titles/import" => json =>
312 $import_request )->status_is(404)->json_is(
313 { error => 'List not found' }
316 # Authorized attempt to create with null id
317 $ehtitle->{title_id} = undef;
319 "//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
320 $ehtitle )->status_is(400)->json_has('/errors');
322 # Authorized attempt to create with existing id
323 $ehtitle->{title_id} = $ehtitle_id;
325 "//$userid:$password@/api/v1/erm/eholdings/local/titles" => json =>
326 $ehtitle )->status_is(400)->json_is(
329 message => "Read-only.",
330 path => "/body/title_id"
335 $schema->storage->txn_rollback;
338 subtest 'update() tests' => sub {
342 $schema->storage->txn_begin;
344 my $librarian = $builder->build_object(
346 class => 'Koha::Patrons',
347 value => { flags => 2**28 }
350 my $password = 'thePassword123';
351 $librarian->set_password( { password => $password, skip_validation => 1 } );
352 my $userid = $librarian->userid;
354 my $patron = $builder->build_object(
356 class => 'Koha::Patrons',
357 value => { flags => 0 }
361 $patron->set_password( { password => $password, skip_validation => 1 } );
362 my $unauth_userid = $patron->userid;
365 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } )
368 # Unauthorized attempt to update
370 "//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id"
372 { publication_title => 'New unauthorized publication_title change' } )
375 # Attempt partial update on a PUT
376 my $ehtitle_with_missing_field = { date_first_issue_online =>
377 "Date of first serial issue available online", };
380 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
381 json => $ehtitle_with_missing_field )->status_is(400)->json_is(
384 message => "Missing property.",
385 path => "/body/publication_title"
390 # Full object update on PUT
391 my $ehtitle_with_updated_field = {
392 publication_title => "Publication title",
393 print_identifier => "Print-format identifier",
394 online_identifier => "Online-format identifier",
395 date_first_issue_online =>
396 "Date of first serial issue available online",
397 num_first_vol_online => "Number of first volume available online",
398 num_first_issue_online => "Number of first issue available online",
399 date_last_issue_online => "Date of last issue available online",
400 num_last_vol_online => "Number of last volume available online",
401 num_last_issue_online => "Number of last issue available online",
402 title_url => "Title-level URL",
403 first_author => "First author",
404 embargo_info => "Embargo information",
405 coverage_depth => "Coverage depth",
407 publisher_name => "Publisher name",
408 publication_type => "Book",
409 date_monograph_published_print =>
410 "Date the monograph is first published in print",
411 date_monograph_published_online =>
412 "Date the monograph is first published online",
413 monograph_volume => "Number of volume for monograph",
414 monograph_edition => "Edition of the monograph",
415 first_editor => "First editor",
416 parent_publication_title_id =>
417 "Title identifier of the parent publication",
418 preceeding_publication_title_id =>
419 "Title identifier of any preceding publication title",
420 access_type => "Access type"
424 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
425 json => $ehtitle_with_updated_field )->status_is(200)
426 ->json_is( '/publication_title' => 'Publication title' );
428 # Authorized attempt to write invalid data
429 my $ehtitle_with_invalid_field = {
430 blah => "EHolding Title Blah",
431 publication_title => "Publication title",
432 print_identifier => "Print-format identifier"
436 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
437 json => $ehtitle_with_invalid_field )->status_is(400)->json_is(
440 message => "Properties not allowed: blah.",
446 # Attempt to update non-existent EHolding title
447 my $ehtitle_to_delete =
448 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } );
449 my $non_existent_id = $ehtitle_to_delete->title_id;
450 $ehtitle_to_delete->delete;
453 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$non_existent_id"
454 => json => $ehtitle_with_updated_field )->status_is(404);
456 # Wrong method (POST)
457 $ehtitle_with_updated_field->{title_id} = 2;
460 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id" =>
461 json => $ehtitle_with_updated_field )->status_is(404);
463 $schema->storage->txn_rollback;
466 subtest 'delete() tests' => sub {
470 $schema->storage->txn_begin;
472 my $librarian = $builder->build_object(
474 class => 'Koha::Patrons',
475 value => { flags => 2**28 }
478 my $password = 'thePassword123';
479 $librarian->set_password( { password => $password, skip_validation => 1 } );
480 my $userid = $librarian->userid;
482 my $patron = $builder->build_object(
484 class => 'Koha::Patrons',
485 value => { flags => 0 }
489 $patron->set_password( { password => $password, skip_validation => 1 } );
490 my $unauth_userid = $patron->userid;
493 $builder->build_object( { class => 'Koha::ERM::EHoldings::Titles' } )
496 # Unauthorized attempt to delete
498 "//$unauth_userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id"
501 # Delete existing EHolding title
503 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id")
504 ->status_is( 204, 'SWAGGER3.2.4' )->content_is( '', 'SWAGGER3.3.4' );
506 # Attempt to delete non-existent EHolding title
508 "//$userid:$password@/api/v1/erm/eholdings/local/titles/$ehtitle_id")
511 $schema->storage->txn_rollback;