Bug 7034: de-nesting C4/Branch.pm
[koha.git] / t / Labels_split_lccn.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 under the
6 # terms of the GNU General Public License as published by the Free Software
7 # Foundation; either version 2 of the License, or (at your option) any later
8 # version.
9 #
10 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
11 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
13 #
14 # You should have received a copy of the GNU General Public License along with
15 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
16 # Suite 330, Boston, MA  02111-1307 USA
17 #
18 # for context, see http://bugs.koha-community.org/bugzilla3/show_bug.cgi?id=2691
19
20 use strict;
21 use warnings;
22
23 use Test::More;
24
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])],};
30     }
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         };
37     }
38     my $test_num = 1;
39     foreach (keys(%$lccns)) {
40         my $split_num += scalar(@{$lccns->{$_}});
41         $test_num += 2 * $split_num;
42         $test_num += 4;
43     }
44     plan tests => $test_num;
45     use_ok('C4::Labels::Label');
46     use vars qw($lccns);
47 }
48
49 foreach my $lccn (sort keys %$lccns) {
50     my (@parts, @expected);
51     ok($lccn, "lccn: $lccn");
52     ok(@expected = @{$lccns->{$lccn}}, "split expected to produce " . scalar(@expected) . " pieces");
53     ok(@parts = C4::Labels::Label::_split_lccn($lccn), "C4::Labels::Label::_split_lccn($lccn)");
54     ok(scalar(@expected) == scalar(@parts), sprintf("%d of %d pieces produced", scalar(@parts), scalar(@expected)));
55     my $i = 0;
56     foreach my $unit (@expected) {
57         my $part;
58         ok($part = $parts[$i], "($lccn)[$i] populated: " . (defined($part) ? $part : 'UNDEF'));
59         ok((defined($part) and $part eq $unit),     "($lccn)[$i]   matches: $unit");
60         $i++;
61     }
62 }
63