From be0931fdf77db3545eef6315cef4512014e2263d Mon Sep 17 00:00:00 2001 From: Tomas Cohen Arazi Date: Wed, 11 Sep 2024 12:55:40 -0300 Subject: [PATCH] Bug 37898: Wrap Relationships.t inside a transaction This tests leave data on the DB and need to be fixed. This patch does that. To test: 1. Run: $ ktd --shell k$ echo "SELECT COUNT(*) FROM borrowers \G" | koha-mysql kohadev k$ echo "SELECT COUNT(*) FROM borrower_relationships \G" | koha-mysql kohadev 2. Run: k$ prove t/db_dependent/Patron/Relationships.t => SUCCESS: Tests pass 3. Repeat 1 => FAIL: Numbers don't match the original ones! 4. Apply this patch 5. Repeat 2 and 3 => SUCCESS: Tests still pass! => SUCCESS: Numbers match! 6. Sign off :-D Signed-off-by: Martin Renvoize --- t/db_dependent/Patron/Relationships.t | 70 +++++++++++++-------------- 1 file changed, 33 insertions(+), 37 deletions(-) diff --git a/t/db_dependent/Patron/Relationships.t b/t/db_dependent/Patron/Relationships.t index d73e7ef796..dacac11bf3 100755 --- a/t/db_dependent/Patron/Relationships.t +++ b/t/db_dependent/Patron/Relationships.t @@ -20,6 +20,7 @@ use Modern::Perl; use Test::More tests => 54; use C4::Context; +use Koha::Database; use t::lib::TestBuilder; @@ -30,57 +31,52 @@ BEGIN { use_ok('Koha::Patron::Relationships'); } +my $schema = Koha::Database->new->schema; my $builder = t::lib::TestBuilder->new(); +$schema->storage->txn_begin; + # Father -my $kyle = Koha::Patrons->find( - $builder->build( - { - source => 'Borrower', - value => { - firstname => 'Kyle', - surname => 'Hall', - } +my $kyle = $builder->build_object( + { + class => 'Koha::Patrons', + value => { + firstname => 'Kyle', + surname => 'Hall', } - )->{borrowernumber} + } ); # Mother -my $chelsea = Koha::Patrons->find( - $builder->build( - { - source => 'Borrower', - value => { - firstname => 'Chelsea', - surname => 'Hall', - } +my $chelsea = $builder->build_object( + { + class => 'Koha::Patrons', + value => { + firstname => 'Chelsea', + surname => 'Hall', } - )->{borrowernumber} + } ); # Children -my $daria = Koha::Patrons->find( - $builder->build( - { - source => 'Borrower', - value => { - firstname => 'Daria', - surname => 'Hall', - } +my $daria = $builder->build_object( + { + class => 'Koha::Patrons', + value => { + firstname => 'Daria', + surname => 'Hall', } - )->{borrowernumber} + } ); -my $kylie = Koha::Patrons->find( - $builder->build( - { - source => 'Borrower', - value => { - firstname => 'Kylie', - surname => 'Hall', - } +my $kylie = $builder->build_object( + { + class => 'Koha::Patrons', + value => { + firstname => 'Kylie', + surname => 'Hall', } - )->{borrowernumber} + } ); Koha::Patron::Relationship->new({ guarantor_id => $kyle->id, guarantee_id => $daria->id, relationship => 'father' })->store(); @@ -152,4 +148,4 @@ is( $sibling->firstname, 'Kylie', 'Sibling from scalar first name matches correc is( $sibling->surname, 'Hall', 'Sibling from scalar surname matches correctly' ); is( $sibling->id, $kylie->id, 'Sibling from scalar patron id matches correctly' ); -1; +$schema->storage->txn_rollback; -- 2.39.5