Bug 18982: category.categorycode must be uppercase
[koha.git] / t / db_dependent / selenium / basic_workflow.t
1 #!/usr/bin/perl
2
3 # This file is part of Koha.
4 #
5 # Koha is free software; you can redistribute it and/or modify it
6 # under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 3 of the License, or
8 # (at your option) any later version.
9 #
10 # Koha is distributed in the hope that it will be useful, but
11 # WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with Koha; if not, see <http://www.gnu.org/licenses>.
17
18
19
20 # wget https://selenium-release.storage.googleapis.com/2.53/selenium-server-standalone-2.53.1.jar # Does not work with 3.4, did not test the ones between
21 # sudo apt-get install xvfb firefox-esr
22 # SELENIUM_PATH=/home/vagrant/selenium-server-standalone-2.53.1.jar
23 # Xvfb :1 -screen 0 1024x768x24 2>&1 >/dev/null &
24 # DISPLAY=:1 java -jar $SELENIUM_PATH
25 #
26 # Remove the rentalcharge:
27 # % UPDATE itemtypes SET rentalcharge = 0;
28 #
29 # Then you can execute the test file.
30 #
31 # If you get:
32 # Wide character in print at /usr/local/share/perl/5.20.2/Test2/Formatter/TAP.pm line 105.
33 # #                   'Koha › Patrons › Add patron test_patron_surname (Adult)'
34 # #     doesn't match '(?^u:Patron details for test_patron_surname)'
35 #
36 # Ignore and retry (FIXME LATER...)
37
38 use Modern::Perl;
39
40 use Time::HiRes qw(gettimeofday);
41 use C4::Context;
42 use C4::Biblio qw( AddBiblio ); # We shouldn't use it
43
44 use Test::More tests => 20;
45 use MARC::Record;
46 use MARC::Field;
47
48 my $dbh = C4::Context->dbh;
49 my $login = 'koha';
50 my $password = 'koha';
51 my $base_url= ( $ENV{KOHA_INTRANET_URL} || 'http://'.C4::Context->preference("staffClientBaseURL") ) . "/cgi-bin/koha/";
52
53 my $number_of_biblios_to_insert = 3;
54 our $sample_data = {
55     category => {
56         categorycode    => 'TEST_CAT',
57         description     => 'test cat description',
58         enrolmentperiod => '12',
59         category_type   => 'A'
60     },
61     patron => {
62         surname    => 'test_patron_surname',
63         cardnumber => '4242424242',
64         userid     => 'test_username',
65         password   => 'password',
66         password2  => 'password'
67     },
68 };
69 our ( $borrowernumber, $start, $prev_time, $cleanup_needed );
70
71 SKIP: {
72     eval { require Selenium::Remote::Driver; };
73     skip "Selenium::Remote::Driver is needed for selenium tests.", 20 if $@;
74
75     $cleanup_needed = 1;
76
77     open my $fh, '>>', '/tmp/output.txt';
78
79     my $driver = Selenium::Remote::Driver->new;
80     $start = gettimeofday;
81     $prev_time = $start;
82     $driver->get($base_url."mainpage.pl");
83     like( $driver->get_title(), qr(Log in to Koha), );
84     auth( $driver, $login, $password );
85     time_diff("main");
86
87     $driver->get($base_url.'admin/categories.pl');
88     like( $driver->get_title(), qr(Patron categories), );
89     $driver->find_element('//a[@id="newcategory"]')->click;
90     like( $driver->get_title(), qr(New category), );
91     fill_form( $driver, $sample_data->{category} );
92     $driver->find_element('//fieldset[@class="action"]/input[@type="submit"]')->click;
93
94     time_diff("add patron category");
95     $driver->get($base_url.'/members/memberentry.pl?op=add&amp;categorycode='.$sample_data->{category}{categorycode});
96     like( $driver->get_title(), qr(Add .*$sample_data->{category}{description}), );
97     fill_form( $driver, $sample_data->{patron} );
98     $driver->find_element('//button[@id="saverecord"]')->click;
99     like( $driver->get_title(), qr(Patron details for $sample_data->{patron}{surname}), );
100
101     ####$driver->get($base_url.'/members/members-home.pl');
102     ####fill_form( $driver, { searchmember => $sample_data->{patron}{cardnumber} } );
103     ####$driver->find_element('//div[@id="header_search"]/div/form/input[@type="submit"]')->click;
104     ####like( $driver->get_title(), qr(Patron details for), );
105
106     time_diff("add patron");
107
108     $borrowernumber = $dbh->selectcol_arrayref(q|SELECT borrowernumber FROM borrowers WHERE userid=?|, {}, $sample_data->{patron}{userid} )->[0];
109
110     my @biblionumbers;
111     for my $i ( 1 .. $number_of_biblios_to_insert ) {
112         my $biblio = MARC::Record->new();
113         my $title = 'test biblio '.$i;
114         if ( C4::Context->preference('marcflavour') eq 'UNIMARC' ) {
115             $biblio->append_fields(
116                 MARC::Field->new('200', ' ', ' ', a => 'test biblio '.$i),
117                 MARC::Field->new('200', ' ', ' ', f => 'test author '.$i),
118             );
119         } else {
120             $biblio->append_fields(
121                 MARC::Field->new('245', ' ', ' ', a => 'test biblio '.$i),
122                 MARC::Field->new('100', ' ', ' ', a => 'test author '.$i),
123             );
124         }
125         my ($biblionumber, $biblioitemnumber) = AddBiblio($biblio, '');
126         push @biblionumbers, $biblionumber;
127     }
128
129     time_diff("add biblio");
130
131     my $itemtype = $dbh->selectcol_arrayref(q|SELECT itemtype FROM itemtypes|);
132     $itemtype = $itemtype->[0];
133
134     for my $biblionumber ( @biblionumbers ) {
135         $driver->get($base_url."/cataloguing/additem.pl?biblionumber=$biblionumber");
136         like( $driver->get_title(), qr(test biblio \d+ by test author), );
137         my $form = $driver->find_element('//form[@name="f"]');
138         my $inputs = $driver->find_child_elements($form, '//input[@type="text"]');
139         for my $input ( @$inputs ) {
140             next if $input->is_hidden();
141
142             my $id = $input->get_attribute('id');
143             next unless $id =~ m|^tag_952_subfield|;
144
145             $input->send_keys('t_value_bib'.$biblionumber);
146         }
147
148         $driver->find_element('//input[@name="add_submit"]')->click;
149         like( $driver->get_title(), qr($biblionumber.*Items) );
150
151         $dbh->do(q|UPDATE items SET notforloan=0 WHERE biblionumber=?|, {}, $biblionumber );
152         $dbh->do(q|UPDATE biblioitems SET itemtype=? WHERE biblionumber=?|, {}, $itemtype, $biblionumber);
153         $dbh->do(q|UPDATE items SET itype=? WHERE biblionumber=?|, {}, $itemtype, $biblionumber);
154     }
155
156     time_diff("add items");
157
158     my $nb_of_checkouts = 0;
159     for my $biblionumber ( @biblionumbers ) {
160         $driver->get($base_url."/circ/circulation.pl?borrowernumber=".$borrowernumber);
161         $driver->find_element('//input[@id="barcode"]')->send_keys('t_value_bib'.$biblionumber);
162         $driver->find_element('//fieldset[@id="circ_circulation_issue"]/button[@type="submit"]')->click;
163         $nb_of_checkouts++;
164         like( $driver->get_title(), qr(Checking out to $sample_data->{patron}{surname}) );
165         is( $driver->find_element('//a[@href="#checkouts"]')->get_attribute('text'), $nb_of_checkouts.' Checkout(s)', );
166     }
167
168     time_diff("checkout");
169
170     for my $biblionumber ( @biblionumbers ) {
171         $driver->get($base_url."/circ/returns.pl");
172         $driver->find_element('//input[@id="barcode"]')->send_keys('t_value_bib'.$biblionumber);
173         $driver->find_element('//form[@id="checkin-form"]/div/fieldset/input[@type="submit"]')->click;
174         like( $driver->get_title(), qr(Check in test biblio \d+) );
175     }
176
177     time_diff("checkin");
178
179     close $fh;
180     $driver->quit();
181 };
182
183 END {
184     cleanup() if $cleanup_needed;
185 };
186
187 sub auth {
188     my ( $driver, $login, $password) = @_;
189     fill_form( $driver, { userid => 'koha', password => 'koha' } );
190     my $login_button = $driver->find_element('//input[@id="submit"]');
191     $login_button->submit();
192 }
193
194 sub fill_form {
195     my ( $driver, $values ) = @_;
196     while ( my ( $id, $value ) = each %$values ) {
197         my $element = $driver->find_element('//*[@id="'.$id.'"]');
198         my $tag = $element->get_tag_name();
199         if ( $tag eq 'input' ) {
200             $driver->find_element('//input[@id="'.$id.'"]')->send_keys($value);
201         } elsif ( $tag eq 'select' ) {
202             $driver->find_element('//select[@id="'.$id.'"]/option[@value="'.$value.'"]')->click;
203         }
204     }
205 }
206
207 sub cleanup {
208     my $dbh = C4::Context->dbh;
209     $dbh->do(q|DELETE FROM borrowers WHERE userid = ?|, {}, $sample_data->{patron}{userid});
210     $dbh->do(q|DELETE FROM categories WHERE categorycode = ?|, {}, $sample_data->{category}{categorycode});
211     for my $i ( 1 .. $number_of_biblios_to_insert ) {
212         $dbh->do(qq|DELETE FROM biblio WHERE title = "test biblio $i"|);
213     };
214
215     $dbh->do(q|DELETE FROM issues where borrowernumber=?|, {}, $borrowernumber);
216     $dbh->do(q|DELETE FROM old_issues where borrowernumber=?|, {}, $borrowernumber);
217     for my $i ( 1 .. $number_of_biblios_to_insert ) {
218         $dbh->do(qq|DELETE items, biblio FROM biblio INNER JOIN items ON biblio.biblionumber = items.biblionumber WHERE biblio.title = "test biblio$i"|);
219     };
220 }
221
222 sub time_diff {
223     my $lib = shift;
224     my $now = gettimeofday;
225     warn "CP $lib = " . sprintf("%.2f", $now - $prev_time ) . "\n";
226     $prev_time = $now;
227 }