From fdea245e991aca4ca3ddad9d1a15d511e427fc0a Mon Sep 17 00:00:00 2001 From: Tomas Cohen Arazi Date: Thu, 7 May 2020 18:05:29 -0300 Subject: [PATCH] Bug 23185: ->update can only be called on instantiated classes Since our use ok Koha::Objects, there's been an implicit instantiation happening in ->search that has somehow hidden the fact that classes need instantiation... This change in ->delete and ->update made it clear because of the failures/hangs on the tests. This patch instantiates Koha::Patron::Categories before attempting to call ->update. The original patches for this bug are correct and the only issue here is that we need to document better than for some methods, instantiation is not implicit and is required first. This is awkward and I would prefer to force everyone to call ->new first. But I understand it would be inconvenient. To test: 1. Run: $ kshell k$ prove t/db_dependent/Template/Plugin/Categories.t => FAIL: Notice it hangs, Ctrl+c to abort 2. Apply this patch 3. Repeat 1 => SUCCESS: Tests dong hang, and in fact pass 4. Sign off :-D Signed-off-by: Tomas Cohen Arazi --- Koha/Objects.pm | 3 ++- t/db_dependent/Template/Plugin/Categories.t | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/Koha/Objects.pm b/Koha/Objects.pm index 6a272cf6a4..c19ced53c1 100644 --- a/Koha/Objects.pm +++ b/Koha/Objects.pm @@ -196,7 +196,8 @@ sub delete { =head3 update - $object->update( $fields, [ { no_triggers => 0/1 } ] ); + my $objects = Koha::Objects->new; # or Koha::Objects->search + $objects->update( $fields, [ { no_triggers => 0/1 } ] ); This method overloads the DBIC inherited one so if code-level triggers exist (through the use of an overloaded I or I method in the Koha::Object diff --git a/t/db_dependent/Template/Plugin/Categories.t b/t/db_dependent/Template/Plugin/Categories.t index 93384deda4..b6080c7519 100644 --- a/t/db_dependent/Template/Plugin/Categories.t +++ b/t/db_dependent/Template/Plugin/Categories.t @@ -65,7 +65,7 @@ subtest 'can_any_reset_password() tests' => sub { $schema->storage->txn_begin; # Make sure all existing categories have reset_password set to 0 - Koha::Patron::Categories->update({ reset_password => 0 }); + Koha::Patron::Categories->search->update({ reset_password => 0 }); ok( !Koha::Template::Plugin::Categories->new->can_any_reset_password, 'No category is allowed to reset password' ); -- 2.39.5