Bug 11371 - Add a new report : Orders by fund with more options
[koha.git] / t / Labels_split_lccn.t
blob4034e2105f4a57223c842ae37332bb953ff17ab9
1 #!/usr/bin/perl
3 # This file is part of Koha.
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.
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.
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>.
18 # for context, see http://bugs.koha-community.org/bugzilla3/show_bug.cgi?id=2691
20 use strict;
21 use warnings;
23 use Test::More;
25 BEGIN {
26 our $lccns = {};
27 if ($ARGV[0]) {
28 BAIL_OUT("USAGE: perl Labels_split_lccn.t 'HE 8700.7 .P6 T44 1983' 'HE,8700.7,.P6,T44,1983'") unless $ARGV[1];
29 $lccns = {$ARGV[0] => [split (/,/,$ARGV[1])],};
31 else {
32 $lccns = {
33 'HE8700.7 .P6T44 1983' => [qw(HE 8700.7 .P6 T44 1983)],
34 'BS2545.E8 H39 1996' => [qw(BS 2545 .E8 H39 1996)],
35 'NX512.S85 A4 2006' => [qw(NX 512 .S85 A4 2006)],
36 'QH541.15.C6 C25 2012' => [qw(QH 541.15 .C6 C25 2012)],
37 '123 ABC FOO BAR' => [qw(123 ABC FOO BAR)],
40 my $test_num = 1;
41 foreach (keys(%$lccns)) {
42 my $split_num += scalar(@{$lccns->{$_}});
43 $test_num += 2 * $split_num;
44 $test_num += 4;
46 plan tests => $test_num;
47 use_ok('C4::Labels::Label');
48 use vars qw($lccns);
51 foreach my $lccn (sort keys %$lccns) {
52 my (@parts, @expected);
53 ok($lccn, "lccn: $lccn");
54 ok(@expected = @{$lccns->{$lccn}}, "split expected to produce " . scalar(@expected) . " pieces");
55 ok(@parts = C4::Labels::Label::_split_lccn($lccn), "C4::Labels::Label::_split_lccn($lccn)");
56 ok(scalar(@expected) == scalar(@parts), sprintf("%d of %d pieces produced", scalar(@parts), scalar(@expected)));
57 my $i = 0;
58 foreach my $unit (@expected) {
59 my $part;
60 ok($part = $parts[$i], "($lccn)[$i] populated: " . (defined($part) ? $part : 'UNDEF'));
61 ok((defined($part) and $part eq $unit), "($lccn)[$i] matches: $unit");
62 $i++;