Bug 13095: An email will be sent shortly
[koha.git] / t / Labels_split_lccn.t
blob87ab8ae37bee4a872fbf306ab3288c08072536b5
1 #!/usr/bin/perl
3 # This file is part of Koha.
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.
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.
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
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++;