diff --git a/tests/43search.pl b/tests/43search.pl deleted file mode 100644 index 13b68d6c5..000000000 --- a/tests/43search.pl +++ /dev/null @@ -1,379 +0,0 @@ -use List::Util qw( first ); -use Future::Utils qw( repeat ); - - -test "Can search for an event by body", - requires => [ local_user_and_room_fixtures() ], - - check => sub { - my ( $user, $room_id ) = @_; - - my ( $event_id ); - - matrix_send_room_text_message_synced( $user, $room_id, - body => "hello, world", - )->then( sub { - ( $event_id ) = @_; - - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - content => { - search_categories => { - room_events => { - keys => [ "content.body" ], - search_term => "hello", - } - } - } - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "Search Result Body:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - - my $room_events = $body->{search_categories}{room_events}; - assert_json_keys( $room_events, qw( count results ) ); - - $room_events->{count} == 1 or die "Expected one search result"; - - my $results = $room_events->{results}; - my $result = first { $_->{result}{event_id} eq $event_id } @$results; - - assert_json_keys( $result, qw( rank result ) ); - assert_json_keys( $result->{result}, qw( - event_id room_id content type - )); - - $result->{result}{content}{body} eq "hello, world" - or die "Unexpected event content in search result"; - - Future->done(1); - }); - }; - -test "Can get context around search results", - requires => [ local_user_and_room_fixtures() ], - - check => sub { - my ( $user, $room_id ) = @_; - - my ( @event_ids ); - - my $search_query = { - search_categories => { - room_events => { - keys => [ "content.body" ], - search_term => "Message 4", - order_by => "recent", - filter => { limit => 1}, - event_context => { - before_limit => 2, - after_limit => 2, - } - } - } - }; - - repeat( sub { - my $msgnum = $_[0]; - - matrix_send_room_text_message_synced( $user, $room_id, - body => "Message number $msgnum" - )->on_done( sub { ( $event_ids[$msgnum] ) = @_ } ); - }, foreach => [ 1 .. 7 ] )->then( sub { - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - content => $search_query, - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "First search result:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - my $room_events = $body->{search_categories}{room_events}; - - assert_json_keys( $room_events, qw( count results next_batch ) ); - assert_eq( $room_events->{count}, 1, 'event count' ); - - my $results = $room_events->{results}; - assert_eq( scalar @$results, 1, 'search results' ); - - my $context = $results->[0]{context}; - assert_json_keys( $context, qw( events_before events_after )); - my $events_before = $context->{events_before}; - my $events_after = $context->{events_after}; - - assert_eq( scalar @$events_before, 2, 'events_before' ); - assert_eq( scalar @$events_after, 2, 'events_after' ); - - assert_eq( $events_before->[0]{content}{body}, "Message number 3" ); - assert_eq( $events_before->[1]{content}{body}, "Message number 2" ); - assert_eq( $events_after->[0]{content}{body}, "Message number 5" ); - assert_eq( $events_after->[1]{content}{body}, "Message number 6" ); - - Future->done(1); - }); - }; - -test "Can back-paginate search results", - requires => [ local_user_and_room_fixtures() ], - - check => sub { - my ( $user, $room_id ) = @_; - - my ( @event_ids ); - - my $search_query = { - search_categories => { - room_events => { - keys => [ "content.body" ], - search_term => "Message", - order_by => "recent", - filter => { limit => 10 }, - } - } - }; - - repeat( sub { - my $msgnum = $_[0]; - matrix_send_room_text_message_synced( $user, $room_id, - body => "Message number $msgnum" ) - ->on_done( sub { ( $event_ids[$msgnum] ) = @_ } ) - }, foreach => [ 0 .. 19 ] )->then( sub { - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - content => $search_query, - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "First search result:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - my $room_events = $body->{search_categories}{room_events}; - - assert_json_keys( $room_events, qw( count results next_batch ) ); - assert_eq( $room_events->{count}, 20, 'event count' ); - - my $results = $room_events->{results}; - assert_eq( scalar @$results, 10, 'search results' ); - - assert_eq( $results->[0]{result}{event_id}, $event_ids[19], - 'first result event_id' ); - assert_eq( $results->[9]{result}{event_id}, $event_ids[10], - 'final result event_id' ); - - my $next_batch = $room_events->{next_batch}; - - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - params => { next_batch => $next_batch }, - content => $search_query, - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "Second search result:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - my $room_events = $body->{search_categories}{room_events}; - - assert_json_keys( $room_events, qw( count results next_batch ) ); - assert_eq( $room_events->{count}, 20, 'event count' ); - - my $results = $room_events->{results}; - assert_eq( scalar @$results, 10, 'search results' ); - - assert_eq( $results->[0]{result}{event_id}, $event_ids[9], - 'first result event_id' ); - assert_eq( $results->[9]{result}{event_id}, $event_ids[0], - 'final result event_id' ); - - my $next_batch = $room_events->{next_batch}; - - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - params => { next_batch => $next_batch }, - content => $search_query, - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "Third search result:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - my $room_events = $body->{search_categories}{room_events}; - - assert_json_keys( $room_events, qw( count results ) ); - not exists( $room_events->{next_batch} ) or die "unexpected next_batch"; - - assert_eq( $room_events->{count}, 20, 'event count' ); - - my $results = $room_events->{results}; - assert_eq( scalar @$results, 0, 'search results' ); - - Future->done( 1 ); - }); - }; - -test "Search works across an upgraded room and its predecessor", - requires => [ - local_user_and_room_fixtures(), - qw ( can_upgrade_room_version ), - ], - - check => sub { - my ( $user, $room_id ) = @_; - - my ( $event_id_one, $event_id_two ); - - matrix_send_room_text_message_synced( $user, $room_id, - body => "message 1", - )->then( sub { - ( $event_id_one ) = @_; - - upgrade_room_synced( - $user, $room_id, - new_version => $main::TEST_NEW_VERSION, - ); - })->then( sub { - my ( $new_room_id ) = @_; - - matrix_send_room_text_message_synced( $user, $new_room_id, - body => "message 2", - ); - })->then( sub { - ( $event_id_two ) = @_; - - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - content => { - search_categories => { - room_events => { - keys => [ "content.body" ], - search_term => "message", - } - } - } - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "Search Result Body:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - - my $room_events = $body->{search_categories}{room_events}; - assert_json_keys( $room_events, qw( count results ) ); - - $room_events->{count} == 2 or die "Expected two search results"; - - my $results = $room_events->{results}; - my $result = first { $_->{result}{event_id} eq $event_id_one } @$results; - - assert_json_keys( $result, qw( rank result ) ); - assert_json_keys( $result->{result}, qw( - event_id room_id content type - )); - - $result->{result}{content}{body} eq "message 1" - or die "Unexpected event content in search result"; - - my $result_two = first { $_->{result}{event_id} eq $event_id_two } @$results; - - assert_json_keys( $result_two, qw( rank result ) ); - assert_json_keys( $result_two->{result}, qw( - event_id room_id content type - )); - - $result_two->{result}{content}{body} eq "message 2" - or die "Unexpected event content in search result"; - - Future->done(1); - }); - }; - -foreach my $ordering_type ( qw ( rank recent ) ) { - test "Search results with $ordering_type ordering do not include redacted events", - requires => [ - local_user_and_room_fixtures(), - ], - - check => sub { - my ( $user, $room_id ) = @_; - - my ( $event_id_one, $event_id_two ); - - matrix_send_room_text_message_synced( $user, $room_id, - body => "message 1", - )->then( sub { - ( $event_id_one ) = @_; - - matrix_send_room_text_message_synced( $user, $room_id, - body => "message 2", - ); - })->then( sub { - ( $event_id_two ) = @_; - - matrix_redact_event( $user, $room_id, $event_id_one ); - })->then( sub { - do_request_json_for( $user, - method => "POST", - uri => "/v3/search", - content => { - search_categories => { - room_events => { - keys => [ "content.body" ], - search_term => "message", - order_by => $ordering_type, - } - } - } - ); - })->then( sub { - my ( $body ) = @_; - - log_if_fail "Search Result Body:", $body; - - assert_json_keys( $body, qw( search_categories ) ); - assert_json_keys( $body->{search_categories}, qw ( room_events ) ); - - my $room_events = $body->{search_categories}{room_events}; - assert_json_keys( $room_events, qw( count results ) ); - - # TODO: Force count to be 1 search result instead of 2 - # Synapse doesn't currently support an accurate count here - - my $results = $room_events->{results}; - my $results_length = scalar @$results; - assert_eq( $results_length, 1 ); - - my $result = first { $_->{result}{event_id} eq $event_id_two } @$results; - - assert_json_keys( $result, qw( rank result ) ); - assert_json_keys( $result->{result}, qw( - event_id room_id content type - )); - - $result->{result}{content}{body} eq "message 2" - or die "Unexpected event content in search result"; - - Future->done(1); - }); - }; -}