6 use RT::Test tests => 12;
10 my $q = RT::Queue->new(RT->SystemUser);
11 my $queue = 'SearchTests-'.$$;
12 $q->Create(Name => $queue);
13 ok ($q->id, "Created the queue");
15 my $t1 = RT::Ticket->new(RT->SystemUser);
16 my ( $id, undef, $msg ) = $t1->Create(
18 Subject => 'SearchTest1',
19 Requestor => ['search2@example.com'],
23 use_ok("RT::Search::Simple");
25 my $active_statuses = join( " OR ", map "Status = '$_'", RT::Queue->ActiveStatusArray());
27 my $tickets = RT::Tickets->new(RT->SystemUser);
28 my $quick = RT::Search::Simple->new(Argument => "",
29 TicketsObj => $tickets);
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 )");
40 while (my ($from, $to) = splice @tests, 0, 2) {
41 is($quick->QueryToSQL($from), $to, "<$from> -> <$to>");