3 use Test::More tests => 23;
5 diag("Test fine generation with closed date on checkin against the admin user.");
7 use constant WORKSTATION_NAME => 'BR4-test-04-overdue-with-closed-dates.t';
8 use constant WORKSTATION_LIB => 7;
9 use constant ITEM_BARCODE => 'CONC72000345';
10 use constant ITEM_ID => 1310;
12 use strict; use warnings;
14 use OpenILS::Utils::TestUtils;
15 my $script = OpenILS::Utils::TestUtils->new();
18 use DateTime::Format::ISO8601;
19 use OpenSRF::Utils qw/cleanse_ISO8601/;
21 our $apputils = "OpenILS::Application::AppUtils";
23 sub create_closed_date {
24 my $aoucd = Fieldmapper::actor::org_unit::closed_date->new;
25 $aoucd->org_unit(WORKSTATION_LIB);
26 $aoucd->reason('04-overdue_with_closed_dates.t');
28 DateTime->today()->subtract( days => 10 )->iso8601()
31 DateTime->today()->subtract( days => 9 )->subtract( seconds => 1 )->iso8601()
33 my $resp = $apputils->simplereq(
35 'open-ils.actor.org_unit.closed.create',
36 $script->authtoken, $aoucd);
40 # returns "1" on success, event on error
41 sub update_closed_date {
43 $aoucd->reason($aoucd->reason . ' modified');
45 my $cd = $apputils->simplereq(
47 'open-ils.actor.org_unit.closed.update',
48 $script->authtoken, $aoucd);
50 return ref $cd eq 'Fieldmapper::actor::org_unit::closed_date';
53 sub delete_closed_date {
55 my $resp = $apputils->simplereq(
57 'open-ils.actor.org_unit.closed.delete',
58 $script->authtoken, ref $aoucd ? $aoucd->id : $aoucd );
62 #----------------------------------------------------------------
63 # The tests... assumes stock sample data, full-auto install by
64 # eg_wheezy_installer.sh, etc.
65 #----------------------------------------------------------------
67 my $storage_ses = $script->session('open-ils.storage');
68 my $circ_ses = $script->session('open-ils.circ');
69 my $cstore_ses = $script->session('open-ils.cstore');
71 my $user_req = $storage_ses->request('open-ils.storage.direct.actor.user.retrieve', 1);
72 if (my $user_resp = $user_req->recv) {
73 if (my $user = $user_resp->content) {
76 'Fieldmapper::actor::user',
77 'open-ils.storage.direct.actor.user.retrieve returned aou object'
82 'User with id = 1 is admin user'
87 my $item_req = $storage_ses->request('open-ils.storage.direct.asset.copy.retrieve', ITEM_ID);
88 if (my $item_resp = $item_req->recv) {
89 if (my $item = $item_resp->content) {
92 'Fieldmapper::asset::copy',
93 'open-ils.storage.direct.asset.copy.retrieve returned acp object'
98 'Item with id = ' . ITEM_ID . ' has barcode ' . ITEM_BARCODE
101 $item->status == 7 || $item->status == 0,
102 'Item with id = ' . ITEM_ID . ' has status of Reshelving or Available'
107 $script->authenticate({
109 password => 'demo123',
115 my $ws = $script->register_workstation(WORKSTATION_NAME,WORKSTATION_LIB);
118 'Registered a new workstation'
122 $script->authenticate({
124 password => 'demo123',
126 workstation => WORKSTATION_NAME});
129 'Have an authtoken associated with the workstation'
132 my $closed_date_obj = create_closed_date();
134 ref $closed_date_obj,
135 'Fieldmapper::actor::org_unit::closed_date',
136 'Created a closed date for 10 days ago'
140 update_closed_date($closed_date_obj),
142 'Updated closed date reason'
145 my $checkout_resp = $script->do_checkout({
147 barcode => ITEM_BARCODE});
151 'Checkout request returned a HASH'
154 $checkout_resp->{ilsevent},
156 'Checkout returned a SUCCESS event'
159 ref $checkout_resp->{payload},
160 'Checkout response object has payload object'
163 ref $checkout_resp->{payload}->{circ},
164 'Payload object has circ object'
167 $checkout_resp->{payload}->{circ}->duration,
169 'Circ objection has loan duration of "7 days"'
172 my $circ = $checkout_resp->{payload}->{circ};
174 $item_req = $storage_ses->request('open-ils.storage.direct.asset.copy.retrieve', ITEM_ID);
175 if (my $item_resp = $item_req->recv) {
176 if (my $item = $item_resp->content) {
180 'Item with id = ' . ITEM_ID . ' has status of Checked Out after fresh Storage request'
185 my $bill_req = $circ_ses->request(
186 'open-ils.circ.money.billing.retrieve.all',
190 if (my $bill_resp = $bill_req->recv) {
191 if (my $bills = $bill_resp->content) {
193 scalar( @{ $bills } ),
195 'Zero bills associated with circulation'
200 my $xact_start = DateTime::Format::ISO8601->parse_datetime(cleanse_ISO8601($circ->xact_start));
201 my $due_date = DateTime::Format::ISO8601->parse_datetime(cleanse_ISO8601($circ->due_date));
203 # Rewrite history; technically we should rewrite status_changed_item on the copy as well, but, meh...
204 $circ->xact_start( $xact_start->subtract( days => 20 )->iso8601() );
205 $circ->due_date( $due_date->subtract( days => 20 )->iso8601() );
207 $cstore_ses->connect; # need stateful connection
208 my $xact = $cstore_ses->request('open-ils.cstore.transaction.begin')->gather(1);
209 my $update_req = $cstore_ses->request(
210 'open-ils.cstore.direct.action.circulation.update',
213 if (my $update_resp = $update_req->gather(1)) {
215 'rewrote circ to have happened 20 days ago'
219 'rewrote circ to have happened 20 days ago'
222 $cstore_ses->request('open-ils.cstore.transaction.commit')->gather(1);
226 my $checkin_resp = $script->do_checkin({
227 barcode => ITEM_BARCODE});
231 'Checkin request returned a HASH'
234 $checkin_resp->{ilsevent},
236 'Checkin returned a SUCCESS event'
239 $item_req = $storage_ses->request('open-ils.storage.direct.asset.copy.retrieve', ITEM_ID);
240 if (my $item_resp = $item_req->recv) {
241 if (my $item = $item_resp->content) {
243 $item->status == 7 || $item->status == 0,
244 'Item with id = ' . ITEM_ID . ' has status of Reshelving or Available after fresh Storage request'
249 $bill_req = $circ_ses->request(
250 'open-ils.circ.money.billing.retrieve.all',
254 if (my $bill_resp = $bill_req->recv) {
255 if (my $bills = $bill_resp->content) {
257 scalar( @{ $bills } ),
259 'Twelve bills associated with circulation (instead of 13, thanks to closed date)'
264 my $tmp = delete_closed_date($closed_date_obj);
265 is($tmp, 1, 'Removed closed date');