Bug 14334: Remove AutoCommit from tests
[koha.git] / t / db_dependent / Serials / Numberpattern.t
1 #!/usr/bin/perl
2
3 use Modern::Perl;
4 use Test::More tests => 95;
5
6 use C4::Context;
7 use Koha::Database;
8
9 my $schema = Koha::Database->new->schema;
10 $schema->storage->txn_begin;
11 my $dbh = C4::Context->dbh;
12
13 use C4::Serials::Numberpattern;
14
15 # Start by deleting all numberpatterns.
16 my @numberpatterns = GetSubscriptionNumberpatterns();
17 foreach my $n (@numberpatterns) {
18     DelSubscriptionNumberpattern($n->{id});
19 }
20
21 @numberpatterns = GetSubscriptionNumberpatterns();
22 is(scalar @numberpatterns, 0, "There is no numberpatterns in database");
23
24 my $numberpattern = GetSubscriptionNumberpattern(1);
25 is($numberpattern, undef, "GetSubscriptionNumberpattern(1) returns undef");
26
27 my $rv = ModSubscriptionNumberpattern($numberpattern);
28 is($rv, undef, "ModSubscriptionNumberpattern(undef) returns undef");
29 $numberpattern = {};
30 $rv = ModSubscriptionNumberpattern($numberpattern);
31 is($rv, undef, "ModSubscriptionNumberpattern({}) returns undef");
32 # returns 0 because id doesn't exist
33 $numberpattern = { id => 1, label => "Test numberpattern 1", description => '' };
34 $rv = ModSubscriptionNumberpattern($numberpattern);
35 is($rv, '0E0', "ModSubscriptionNumberpattern({id=1,label=>'Test numberpattern 1'}) returns '0 but true'");
36
37 $numberpattern = undef;
38 my $id = AddSubscriptionNumberpattern($numberpattern);
39 is($id, undef, "AddSubscriptionNumberpattern(undef) returns undef");
40 $numberpattern = {};
41 $id = AddSubscriptionNumberpattern($numberpattern);
42 is($id, undef, "AddSubscriptionNumberpattern({}) returns undef");
43 $numberpattern = { label => "Test numberpattern 1", numberingmethod => "{X}", description => '' };
44 $id = AddSubscriptionNumberpattern($numberpattern);
45 ok((defined($id) && ($id > 0)), "AddSubscriptionNumberpattern({label => 'Test numberpattern 1', numberingmethod => '{X}'}) returns numberpattern id");
46
47 $numberpattern = GetSubscriptionNumberpattern($id);
48 isa_ok($numberpattern, 'HASH', "GetSubscriptionNumberpattern($id)");
49 is($numberpattern->{label}, "Test numberpattern 1", "label OK");
50 is($numberpattern->{numberingmethod}, '{X}', "unit OK");
51 is($numberpattern->{description}, '', "description OK");
52 is($numberpattern->{displayorder}, undef, "displayorder OK");
53 foreach my $key (qw(label add every setto whenmorethan numbering)) {
54     foreach my $index (1,2,3) {
55         ok(exists $numberpattern->{$key . $index}, "$key$index exists");
56         is($numberpattern->{$key . $index}, undef, "$key$index is undef");
57     }
58 }
59
60 $numberpattern->{label} = $numberpattern->{label} . " (modified)";
61 $numberpattern->{displayorder} = 1;
62 my $i = 0;
63 foreach my $key (qw(label add every setto whenmorethan numbering)) {
64     foreach my $index (1,2,3) {
65         $numberpattern->{$key . $index} = $i++;
66     }
67 }
68 $rv = ModSubscriptionNumberpattern($numberpattern);
69 is($rv, 1, "ModSubscriptionNumberpattern(\$numberpattern) returns 1");
70
71 $numberpattern = GetSubscriptionNumberpattern($id);
72 isa_ok($numberpattern, 'HASH', "GetSubscriptionNumberpattern($id)");
73 is($numberpattern->{label}, "Test numberpattern 1 (modified)", "label OK");
74 is($numberpattern->{numberingmethod}, '{X}', "unit OK");
75 is($numberpattern->{description}, '', "description OK");
76 is($numberpattern->{displayorder}, 1, "displayorder OK");
77 $i = 0;
78 foreach my $key (qw(label add every setto whenmorethan numbering)) {
79     foreach my $index (1,2,3) {
80         ok(exists $numberpattern->{$key . $index}, "$key$index exists");
81         is($numberpattern->{$key . $index}, $i++, "$key$index is $i");
82     }
83 }
84
85 @numberpatterns = GetSubscriptionNumberpatterns();
86 is(scalar @numberpatterns, 1, "There is one numberpattern");
87
88 # Add another numberpattern
89 undef $numberpattern->{id};
90 my $id2 = AddSubscriptionNumberpattern($numberpattern);
91
92 @numberpatterns = GetSubscriptionNumberpatterns();
93 is(scalar @numberpatterns, 2, "There are two numberpatterns");
94
95 # Delete one numberpattern
96 DelSubscriptionNumberpattern($id);
97 @numberpatterns = GetSubscriptionNumberpatterns();
98 is(scalar @numberpatterns, 1, "There is one numberpattern");
99
100 # Delete the other numberpattern
101 DelSubscriptionNumberpattern($id2);
102 @numberpatterns = GetSubscriptionNumberpatterns();
103 is(scalar @numberpatterns, 0, "There is no numberpattern");