Concurrent queries for global search results

remotes/origin/enhancement/email-actions
Alejandro Alonso 2015-06-25 09:37:51 +02:00 committed by Jesús Espino
parent 30e08c61ef
commit 8b05f206b2
2 changed files with 28 additions and 9 deletions

View File

@ -26,6 +26,7 @@ from . import services
from . import serializers
from concurrent import futures
class SearchViewSet(viewsets.ViewSet):
def list(self, request, **kwargs):
@ -35,14 +36,32 @@ class SearchViewSet(viewsets.ViewSet):
project = self._get_project(project_id)
result = {}
with futures.ThreadPoolExecutor(max_workers=4) as executor:
futures_list = []
if user_has_perm(request.user, "view_us", project):
result["userstories"] = self._search_user_stories(project, text)
uss_future = executor.submit(self._search_user_stories, project, text)
uss_future.result_key = "userstories"
futures_list.append(uss_future)
if user_has_perm(request.user, "view_tasks", project):
result["tasks"] = self._search_tasks(project, text)
tasks_future = executor.submit(self._search_tasks, project, text)
tasks_future.result_key = "tasks"
futures_list.append(tasks_future)
if user_has_perm(request.user, "view_issues", project):
result["issues"] = self._search_issues(project, text)
issues_future = executor.submit(self._search_issues, project, text)
issues_future.result_key = "issues"
futures_list.append(issues_future)
if user_has_perm(request.user, "view_wiki_pages", project):
result["wikipages"] = self._search_wiki_pages(project, text)
wiki_pages_future = executor.submit(self._search_wiki_pages, project, text)
wiki_pages_future.result_key = "wikipages"
futures_list.append(wiki_pages_future)
for future in futures.as_completed(futures_list):
try:
data = future.result()
except Exception as exc:
print('%s generated an exception: %s' % (future.result_key, exc))
else:
result[future.result_key] = data
result["count"] = sum(map(lambda x: len(x), result.values()))
return response.Ok(result)

View File

@ -25,7 +25,7 @@ from taiga.permissions.permissions import MEMBERS_PERMISSIONS
from tests.utils import disconnect_signals, reconnect_signals
pytestmark = pytest.mark.django_db
pytestmark = pytest.mark.django_db(transaction=True)
def setup_module(module):