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');
44 return $apputils->simplereq(
46 'open-ils.actor.org_unit.closed.update',
47 $script->authtoken, $aoucd);
50 sub delete_closed_date {
52 my $resp = $apputils->simplereq(
54 'open-ils.actor.org_unit.closed.delete',
55 $script->authtoken, ref $aoucd ? $aoucd->id : $aoucd );
59 #----------------------------------------------------------------
60 # The tests... assumes stock sample data, full-auto install by
61 # eg_wheezy_installer.sh, etc.
62 #----------------------------------------------------------------
64 my $storage_ses = $script->session('open-ils.storage');
65 my $circ_ses = $script->session('open-ils.circ');
66 my $cstore_ses = $script->session('open-ils.cstore');
68 my $user_req = $storage_ses->request('open-ils.storage.direct.actor.user.retrieve', 1);
69 if (my $user_resp = $user_req->recv) {
70 if (my $user = $user_resp->content) {
73 'Fieldmapper::actor::user',
74 'open-ils.storage.direct.actor.user.retrieve returned aou object'
79 'User with id = 1 is admin user'
84 my $item_req = $storage_ses->request('open-ils.storage.direct.asset.copy.retrieve', ITEM_ID);
85 if (my $item_resp = $item_req->recv) {
86 if (my $item = $item_resp->content) {
89 'Fieldmapper::asset::copy',
90 'open-ils.storage.direct.asset.copy.retrieve returned acp object'
95 'Item with id = ' . ITEM_ID . ' has barcode ' . ITEM_BARCODE
98 $item->status == 7 || $item->status == 0,
99 'Item with id = ' . ITEM_ID . ' has status of Reshelving or Available'
104 $script->authenticate({
106 password => 'demo123',
112 my $ws = $script->register_workstation(WORKSTATION_NAME,WORKSTATION_LIB);
115 'Registered a new workstation'
119 $script->authenticate({
121 password => 'demo123',
123 workstation => WORKSTATION_NAME});
126 'Have an authtoken associated with the workstation'
129 my $closed_date_obj = create_closed_date();
131 ref $closed_date_obj,
132 'Fieldmapper::actor::org_unit::closed_date',
133 'Created a closed date for 10 days ago'
137 update_closed_date($closed_date_obj),
139 'Updated closed date reason'
142 my $checkout_resp = $script->do_checkout({
144 barcode => ITEM_BARCODE});
148 'Checkout request returned a HASH'
151 $checkout_resp->{ilsevent},
153 'Checkout returned a SUCCESS event'
156 ref $checkout_resp->{payload},
157 'Checkout response object has payload object'
160 ref $checkout_resp->{payload}->{circ},
161 'Payload object has circ object'
164 $checkout_resp->{payload}->{circ}->duration,
166 'Circ objection has loan duration of "7 days"'
169 my $circ = $checkout_resp->{payload}->{circ};
171 $item_req = $storage_ses->request('open-ils.storage.direct.asset.copy.retrieve', ITEM_ID);
172 if (my $item_resp = $item_req->recv) {
173 if (my $item = $item_resp->content) {
177 'Item with id = ' . ITEM_ID . ' has status of Checked Out after fresh Storage request'
182 my $bill_req = $circ_ses->request(
183 'open-ils.circ.money.billing.retrieve.all',
187 if (my $bill_resp = $bill_req->recv) {
188 if (my $bills = $bill_resp->content) {
190 scalar( @{ $bills } ),
192 'Zero bills associated with circulation'
197 my $xact_start = DateTime::Format::ISO8601->parse_datetime(cleanse_ISO8601($circ->xact_start));
198 my $due_date = DateTime::Format::ISO8601->parse_datetime(cleanse_ISO8601($circ->due_date));
200 # Rewrite history; technically we should rewrite status_changed_item on the copy as well, but, meh...
201 $circ->xact_start( $xact_start->subtract( days => 20 )->iso8601() );
202 $circ->due_date( $due_date->subtract( days => 20 )->iso8601() );
204 $cstore_ses->connect; # need stateful connection
205 my $xact = $cstore_ses->request('open-ils.cstore.transaction.begin')->gather(1);
206 my $update_req = $cstore_ses->request(
207 'open-ils.cstore.direct.action.circulation.update',
210 if (my $update_resp = $update_req->gather(1)) {
212 'rewrote circ to have happened 20 days ago'
216 'rewrote circ to have happened 20 days ago'
219 $cstore_ses->request('open-ils.cstore.transaction.commit')->gather(1);
223 my $checkin_resp = $script->do_checkin({
224 barcode => ITEM_BARCODE});
228 'Checkin request returned a HASH'
231 $checkin_resp->{ilsevent},
233 'Checkin returned a SUCCESS event'
236 $item_req = $storage_ses->request('open-ils.storage.direct.asset.copy.retrieve', ITEM_ID);
237 if (my $item_resp = $item_req->recv) {
238 if (my $item = $item_resp->content) {
240 $item->status == 7 || $item->status == 0,
241 'Item with id = ' . ITEM_ID . ' has status of Reshelving or Available after fresh Storage request'
246 $bill_req = $circ_ses->request(
247 'open-ils.circ.money.billing.retrieve.all',
251 if (my $bill_resp = $bill_req->recv) {
252 if (my $bills = $bill_resp->content) {
254 scalar( @{ $bills } ),
256 'Twelve bills associated with circulation (instead of 13, thanks to closed date)'
261 my $tmp = delete_closed_date($closed_date_obj);
262 is($tmp, 1, 'Removed closed date');