7604e9842b
While this means we need an additional query for initial lookup, it makes the *filtering* query (which is the heavy part) require far fewer joins, thus making it more efficient. Also adds a new unit test to verify that our filter filters to the correct set of repositories.
36 lines
1.1 KiB
Python
36 lines
1.1 KiB
Python
import pytest
|
|
|
|
from playhouse.test_utils import assert_query_count
|
|
|
|
from endpoints.api.search import ConductRepositorySearch, ConductSearch
|
|
from endpoints.api.test.shared import conduct_api_call
|
|
from endpoints.test.shared import client_with_identity
|
|
from test.fixtures import *
|
|
|
|
@pytest.mark.parametrize('query', [
|
|
(''),
|
|
('simple'),
|
|
('public'),
|
|
('repository'),
|
|
])
|
|
def test_repository_search(query, client):
|
|
with client_with_identity('devtable', client) as cl:
|
|
params = {'query': query}
|
|
with assert_query_count(7):
|
|
result = conduct_api_call(cl, ConductRepositorySearch, 'GET', params, None, 200).json
|
|
assert result['start_index'] == 0
|
|
assert result['page'] == 1
|
|
assert len(result['results'])
|
|
|
|
|
|
@pytest.mark.parametrize('query', [
|
|
('simple'),
|
|
('public'),
|
|
('repository'),
|
|
])
|
|
def test_search_query_count(query, client):
|
|
with client_with_identity('devtable', client) as cl:
|
|
params = {'query': query}
|
|
with assert_query_count(10):
|
|
result = conduct_api_call(cl, ConductSearch, 'GET', params, None, 200).json
|
|
assert len(result['results'])
|