fix ticketing system error on bootstrap of new install
[freeside.git] / rt / t / ticket / cfsort-freeform-multiple.t
1
2 use RT::Test nodata => 1, tests => 41;
3
4 use strict;
5 use warnings;
6
7 use RT::Tickets;
8 use RT::Queue;
9 use RT::CustomField;
10
11 # Test Sorting by custom fields.
12
13 diag "Create a queue to test with.";
14 my $queue_name = "CFSortQueue-$$";
15 my $queue;
16 {
17     $queue = RT::Queue->new( RT->SystemUser );
18     my ($ret, $msg) = $queue->Create(
19         Name => $queue_name,
20         Description => 'queue for custom field sort testing'
21     );
22     ok($ret, "$queue_name - test queue creation. $msg");
23 }
24
25 diag "create a CF";
26 my $cf_name = "Order$$";
27 my $cf;
28 {
29     $cf = RT::CustomField->new( RT->SystemUser );
30     my ($ret, $msg) = $cf->Create(
31         Name  => $cf_name,
32         Queue => $queue->id,
33         Type  => 'FreeformMultiple',
34     );
35     ok($ret, "Custom Field Order created");
36 }
37
38 my (@data, @tickets, @test) = (0, ());
39
40
41
42 sub run_tests {
43     my $query_prefix = join ' OR ', map 'id = '. $_->id, @tickets;
44     foreach my $test ( @test ) {
45         my $query = join " AND ", map "( $_ )", grep defined && length,
46             $query_prefix, $test->{'Query'};
47
48         foreach my $order (qw(ASC DESC)) {
49             my $error = 0;
50             my $tix = RT::Tickets->new( RT->SystemUser );
51             $tix->FromSQL( $query );
52             $tix->OrderBy( FIELD => $test->{'Order'}, ORDER => $order );
53
54             ok($tix->Count, "found ticket(s)")
55                 or $error = 1;
56
57             my ($order_ok, $last) = (1, $order eq 'ASC'? '-': 'zzzzzz');
58             my $last_id = $tix->Last->id;
59             while ( my $t = $tix->Next ) {
60                 my $tmp;
61                 next if $t->id == $last_id and $t->Subject eq "-"; # Nulls are allowed to come last, in Pg
62
63                 if ( $order eq 'ASC' ) {
64                     $tmp = ((split( /,/, $last))[0] cmp (split( /,/, $t->Subject))[0]);
65                 } else {
66                     $tmp = -((split( /,/, $last))[-1] cmp (split( /,/, $t->Subject))[-1]);
67                 }
68                 if ( $tmp > 0 ) {
69                     $order_ok = 0; last;
70                 }
71                 $last = $t->Subject;
72             }
73
74             ok( $order_ok, "$order order of tickets is good" )
75                 or $error = 1;
76
77             if ( $error ) {
78                 diag "Wrong SQL query:". $tix->BuildSelectQuery;
79                 $tix->GotoFirstItem;
80                 while ( my $t = $tix->Next ) {
81                     diag sprintf "%02d - %s", $t->id, $t->Subject;
82                 }
83             }
84         }
85     }
86 }
87
88 @data = (
89     { Subject => '-' },
90     { Subject => 'b-d', 'CustomField-' . $cf->id => ['b', 'd'] },
91     { Subject => 'a-c', 'CustomField-' . $cf->id => ['a', 'c'] },
92 );
93 @tickets = RT::Test->create_tickets( {Queue => $queue->id, RandomOrder => 1 }, @data);
94 @test = (
95     { Order => "CF.{$cf_name}" },
96     { Order => "CF.$queue_name.{$cf_name}" },
97 );
98 run_tests();
99
100 @data = (
101     { Subject => 'm-a', 'CustomField-' . $cf->id => ['m', 'a'] },
102     { Subject => 'm', 'CustomField-' . $cf->id => ['m'] },
103     { Subject => 'm-o', 'CustomField-' . $cf->id => ['m', 'o'] },
104 );
105 @tickets = RT::Test->create_tickets( {Queue => $queue->id, RandomORder => 1 }, @data);
106 @test = (
107     { Order => "CF.{$cf_name}", Query => "CF.{$cf_name} = 'm'" },
108     { Order => "CF.$queue_name.{$cf_name}", Query => "CF.{$cf_name} = 'm'" },
109 );
110 run_tests();
111
112 @tickets = ();
113