From 7e459294d1e49c0e3397b897fb4d4b733a23bb99 Mon Sep 17 00:00:00 2001 From: Bill Erickson <berick@esilibrary.com> Date: Tue, 18 Feb 2014 08:53:59 -0500 Subject: [PATCH] LP#1187035 Remove OpenILS::Utils::Editor part 4. Make sure all CStoreEditors in ClosedDates run updates in transactions, roll back transactions on error, and commit the transactions on success. Added a live test for closed data updating. Signed-off-by: Bill Erickson <berick@esilibrary.com> Signed-off-by: Jeff Godin <jgodin@tadl.org> --- .../lib/OpenILS/Application/Actor/ClosedDates.pm | 28 ++++++++++++---------- .../perlmods/live_t/04-overdue_with_closed_dates.t | 18 +++++++++++++- 2 files changed, 32 insertions(+), 14 deletions(-) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Actor/ClosedDates.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Actor/ClosedDates.pm index 28cd1230a4..46337f5be1 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Actor/ClosedDates.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Actor/ClosedDates.pm @@ -67,12 +67,13 @@ __PACKAGE__->register_method( sub delete_date { my( $self, $conn, $auth, $id ) = @_; - my $e = new_editor(authtoken=>$auth); - return $e->event unless $e->checkauth; - my $date = $e->retrieve_actor_org_unit_closed_date($id) or return $e->event; - return $e->event unless $e->allowed( # rely on the editor perm eventually + my $e = new_editor(authtoken=>$auth, xact => 1); + return $e->die_event unless $e->checkauth; + my $date = $e->retrieve_actor_org_unit_closed_date($id) or return $e->die_event; + return $e->die_event unless $e->allowed( 'actor.org_unit.closed_date.delete', $date->org_unit); - $e->delete_actor_org_unit_closed_date($date) or return $e->event; + $e->delete_actor_org_unit_closed_date($date) or return $e->die_event; + $e->commit; return 1; } @@ -91,15 +92,15 @@ sub create_date { my( $self, $conn, $auth, $date ) = @_; my $e = new_editor(authtoken=>$auth, xact =>1); - return $e->event unless $e->checkauth; + return $e->die_event unless $e->checkauth; - return $e->event unless $e->allowed( # rely on the editor perm eventually + return $e->die_event unless $e->allowed( 'actor.org_unit.closed_date.create', $date->org_unit); - $e->create_actor_org_unit_closed_date($date) or return $e->event; + $e->create_actor_org_unit_closed_date($date) or return $e->die_event; my $newobj = $e->retrieve_actor_org_unit_closed_date($date->id) - or return $e->event; + or return $e->die_event; $e->commit; return $newobj; @@ -117,16 +118,17 @@ __PACKAGE__->register_method( sub edit_date { my( $self, $conn, $auth, $date ) = @_; my $e = new_editor(authtoken=>$auth, xact =>1); - return $e->event unless $e->checkauth; + return $e->die_event unless $e->checkauth; # First make sure they have the right to update the selected date object my $odate = $e->retrieve_actor_org_unit_closed_date($date->id) - or return $e->event; + or return $e->die_event; - return $e->event unless $e->allowed( # rely on the editor perm eventually + return $e->die_event unless $e->allowed( 'actor.org_unit.closed_date.update', $odate->org_unit); - $e->update_actor_org_unit_closed_date($date) or return $e->event; + $e->update_actor_org_unit_closed_date($date) or return $e->die_event; + $e->commit; return 1; } diff --git a/Open-ILS/src/perlmods/live_t/04-overdue_with_closed_dates.t b/Open-ILS/src/perlmods/live_t/04-overdue_with_closed_dates.t index 3f9f3f5200..e00496e8cb 100644 --- a/Open-ILS/src/perlmods/live_t/04-overdue_with_closed_dates.t +++ b/Open-ILS/src/perlmods/live_t/04-overdue_with_closed_dates.t @@ -1,6 +1,6 @@ #!perl -use Test::More tests => 22; +use Test::More tests => 23; diag("Test fine generation with closed date on checkin against the admin user."); @@ -45,6 +45,16 @@ sub create_closed_date { return $resp; } +# returns "1" on success, event on error +sub update_closed_date { + my $aoucd = shift; + $aoucd->reason($aoucd->reason . ' modified'); + return $apputils->simplereq( + 'open-ils.actor', + 'open-ils.actor.org_unit.closed.update', + $script->authtoken, $aoucd); +} + sub delete_closed_date { my $aoucd = shift; my $resp = $apputils->simplereq( @@ -131,6 +141,12 @@ is( 'Created a closed date for 10 days ago' ); +is( + update_closed_date($closed_date_obj), + '1', + 'Updated closed date reason' +); + my $checkout_resp = $script->do_checkout({ patron => 1, barcode => ITEM_BARCODE}); -- 2.11.0