fix ticketing system error on bootstrap of new install
[freeside.git] / rt / t / ticket / simple_search.t
1
2
3 use strict;
4 use warnings;
5
6 use RT::Test tests => 12;
7 use_ok('RT');
8
9
10 my $q = RT::Queue->new(RT->SystemUser);
11 my $queue = 'SearchTests-'.$$;
12 $q->Create(Name => $queue);
13 ok ($q->id, "Created the queue");
14
15 my $t1 = RT::Ticket->new(RT->SystemUser);
16 my ( $id, undef, $msg ) = $t1->Create(
17     Queue      => $q->id,
18     Subject    => 'SearchTest1',
19     Requestor => ['search2@example.com'],
20 );
21 ok( $id, $msg );
22
23 use_ok("RT::Search::Simple");
24
25 my $active_statuses = join( " OR ", map "Status = '$_'", RT::Queue->ActiveStatusArray());
26
27 my $tickets = RT::Tickets->new(RT->SystemUser);
28 my $quick = RT::Search::Simple->new(Argument => "",
29                                  TicketsObj => $tickets);
30 my @tests = (
31     "General new open root"     => "( Owner = 'root' ) AND ( Queue = 'General' ) AND ( Status = 'new' OR Status = 'open' )", 
32     "General"              => "( Queue = 'General' ) AND ( $active_statuses )",
33     "General any"          => "( Queue = 'General' )",
34     "fulltext:jesse"       => "( Content LIKE 'jesse' ) AND ( $active_statuses )",
35     $queue                 => "( Queue = '$queue' ) AND ( $active_statuses )",
36     "root $queue"          => "( Owner = 'root' ) AND ( Queue = '$queue' ) AND ( $active_statuses )",
37     "notauser $queue"      => "( Subject LIKE 'notauser' ) AND ( Queue = '$queue' ) AND ( $active_statuses )",
38     "notauser $queue root" => "( Subject LIKE 'notauser' ) AND ( Owner = 'root' ) AND ( Queue = '$queue' ) AND ( $active_statuses )");
39
40 while (my ($from, $to) = splice @tests, 0, 2) {
41     is($quick->QueryToSQL($from), $to, "<$from> -> <$to>");
42 }