Bug 37389: Add tests

prove t/Koha/REST/Plugin/Query.t
prove t/db_dependent/Koha/Objects/Mixin/ExtendedAttributes.t

Co-authored-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
Signed-off-by: David Nind <david@davidnind.com>
Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
Signed-off-by: Katrin Fischer <katrin.fischer@bsz-bw.de>
This commit is contained in:
Pedro Amorim 2024-07-25 15:27:42 +00:00 committed by Katrin Fischer
parent 1293980793
commit bbf52b754f
Signed by: kfischer
GPG key ID: 0EF6E2C03357A834
2 changed files with 256 additions and 6 deletions

View file

@ -331,12 +331,35 @@ get '/dbic_extended_attributes_join' => sub {
]; ];
my $attributes = { 'prefetch' => ['extended_attributes'] }; my $attributes = { 'prefetch' => ['extended_attributes'] };
$c->dbic_extended_attributes_join( my $result_set = Koha::Patrons->new;
$c->render( json => { 'attributes' => $attributes, 'filtered_params' => $filtered_params }, status => 200 );
};
get '/dbic_extended_attributes_join_multiple_values' => sub {
my ( $c, $args ) = @_;
my $filtered_params = [
{ {
'filtered_params' => $filtered_params, '-and' => [
'attributes' => $attributes [
{
'extended_attributes.attribute' => { 'like' => 'abc%' },
'extended_attributes.code' => 'CODE_1'
} }
); ],
[
{
'extended_attributes.code' => 'CODE_2',
'extended_attributes.attribute' => { 'like' => '123%' }
}
]
]
}
];
my $attributes = { 'prefetch' => ['extended_attributes'] };
my $result_set = Koha::Patrons->new;
$c->render( json => { 'attributes' => $attributes, 'filtered_params' => $filtered_params }, status => 200 ); $c->render( json => { 'attributes' => $attributes, 'filtered_params' => $filtered_params }, status => 200 );
}; };
@ -350,7 +373,7 @@ sub to_model {
# The tests # The tests
use Test::More tests => 9; use Test::More tests => 10;
use Test::Mojo; use Test::Mojo;
subtest 'extract_reserved_params() tests' => sub { subtest 'extract_reserved_params() tests' => sub {
@ -684,5 +707,43 @@ subtest 'dbic_validate_operators' => sub {
# Invalid queries # Invalid queries
$q = [ { "-and" => [ [ { "biblio_id" => { "like(sleep(1/100000))or" => "%a%" } } ] ] } ]; $q = [ { "-and" => [ [ { "biblio_id" => { "like(sleep(1/100000))or" => "%a%" } } ] ] } ];
$t->get_ok( '/dbic_validate_operators' => json => { q => $q } )->status_is(400); $t->get_ok( '/dbic_validate_operators' => json => { q => $q } )->status_is(400);
};
subtest 'dbic_extended_attributes_join() tests' => sub {
plan tests => 4;
my $t = Test::Mojo->new;
$t->get_ok( '/dbic_extended_attributes_join_multiple_values' => { 'x-koha-embed' => 'extended_attributes' } )
->json_has(
'/attributes' => {
'join' => [
'extended_attributes_CODE_1',
'extended_attributes_CODE_2'
],
'prefetch' => ['extended_attributes']
}
);
$t->get_ok( '/dbic_extended_attributes_join' => { 'x-koha-embed' => 'extended_attributes' } )->json_has(
'/filtered_params' => [
{
'-and' => [
[
{
'extended_attributes_CODE_1.code' => 'CODE_1',
'extended_attributes_CODE_1.attribute' => { 'like' => 'abc%' }
}
],
[
{
'extended_attributes_CODE_2.code' => 'CODE_2',
'extended_attributes_CODE_2.attribute' => { 'like' => 'abc%' }
}
],
]
}
]
);
}; };

View file

@ -0,0 +1,189 @@
#!/usr/bin/perl
# Copyright 2024 Koha Development team
#
# 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 => 2;
use C4::Context;
use Koha::Database;
use t::lib::TestBuilder;
my $schema = Koha::Database->new->schema;
$schema->storage->txn_begin;
my $builder = t::lib::TestBuilder->new;
subtest 'extended_attributes patrons join searches() tests' => sub {
plan tests => 3;
$schema->storage->txn_begin;
my $builder = t::lib::TestBuilder->new;
my $patron1 = $builder->build( { source => 'Borrower' } )->{borrowernumber};
my $patron2 = $builder->build( { source => 'Borrower' } )->{borrowernumber};
my $attribute_type_1 = $builder->build(
{
source => 'BorrowerAttributeType',
value => { repeatable => 1, is_date => 0, code => 'CODE_1' },
}
);
my $attribute_type_2 = $builder->build(
{
source => 'BorrowerAttributeType',
value => { repeatable => 1, is_date => 0, code => 'CODE_2' }
}
);
my $attr1 = Koha::Patron::Attribute->new(
{
borrowernumber => $patron1,
code => $attribute_type_1->{code},
attribute => 'Bar'
}
)->store;
my $attr2 = Koha::Patron::Attribute->new(
{
borrowernumber => $patron1,
code => $attribute_type_2->{code},
attribute => 'Foo'
}
)->store;
my $patrons_search = Koha::Patrons->search(
[
'-and'=>[
{
'extended_attributes.attribute' => { 'like' => '%Bar%' },
'extended_attributes.code' => $attr1->code
},
{
'extended_attributes.attribute' => { 'like' => '%Foo%' },
'extended_attributes.code' => $attr2->code
}
],
],
{ 'prefetch' => ['extended_attributes'] }
);
is( $patrons_search->count, 1, "Patrons extended_attribute 'AND' query works." );
my $patrons_search2 = Koha::Patrons->search(
[
'-and' => [
{
'extended_attributes.attribute' => { 'like' => '%Bar%' },
'extended_attributes.code' => $attr1->code
},
{
'extended_attributes.attribute' => { 'like' => '%Bar%' },
'extended_attributes.code' => $attr2->code
}
],
],
{ 'prefetch' => ['extended_attributes'] }
);
is( $patrons_search2->count, 0, "Second patrons extended_attribute 'AND' query works." );
my $patrons_search3 = Koha::Patrons->search(
[
[
{
'extended_attributes.attribute' => { 'like' => '%Bar%' },
'extended_attributes.code' => $attr1->code
}
],
[
{
'extended_attributes.attribute' => { 'like' => '%Foo%' },
'extended_attributes.code' => $attr2->code
}
],
[
{
'extended_attributes.attribute' => { 'like' => '%Foo%' },
'extended_attributes.code' => $attr1->code
}
],
],
{ 'prefetch' => ['extended_attributes'] }
);
is( $patrons_search3->count, 1, "Patrons extended_attribute 'OR' search works" );
$schema->storage->txn_rollback;
};
subtest 'extended_attributes ill requests join searches() tests' => sub {
plan tests => 1;
$schema->storage->txn_begin;
my $builder = t::lib::TestBuilder->new;
# ILL::Requests
my $illrequest1 = $builder->build( { source => 'Illrequest' } )->{illrequest_id};
my $illrequest2 = $builder->build( { source => 'Illrequest' } )->{illrequest_id};
my $illrequest_attribute1 = 'author';
my $ill_attr1 = Koha::ILL::Request::Attribute->new(
{
illrequest_id => $illrequest1,
type => 'author',
value => 'Pedro'
}
)->store;
my $ill_attr2 = Koha::ILL::Request::Attribute->new(
{
illrequest_id => $illrequest2,
type => 'author',
value => 'Pedro'
}
)->store;
my $ill_requests = Koha::ILL::Requests->search(
[
[
{
'extended_attributes.value' => { 'like' => '%Pedro%' },
'extended_attributes.type' => $illrequest_attribute1
}
],
[
{
'extended_attributes.value' => { 'like' => '%field2 value%' },
'extended_attributes.type' => $illrequest_attribute1
}
],
],
{ 'prefetch' => ['extended_attributes'] }
);
is( $ill_requests->count, 2, "ILL requests extended_attribute search works" );
$schema->storage->txn_rollback;
};