-
Notifications
You must be signed in to change notification settings - Fork 89
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Convert bool filters to 0 or 1 when querying the search service #3202
base: master
Are you sure you want to change the base?
Changes from 3 commits
b939828
2397515
f699f75
327991a
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -41,7 +41,12 @@ def execute_search(self): | |
if self.sort: | ||
url = url + f"&sort={self.sort}" | ||
for name, value in self._filters.items(): | ||
url = url + f"&{name}={value}" | ||
param_value = value | ||
# HACK: use the `.__class__.__name__` to avoid having to import `BoolFilter` here, as importing it at the top would make a import loop. | ||
if self.adapter.filters[name].__class__.__name__ == "BoolFilter": | ||
# The search service uses 1 and 0 for booleans. | ||
param_value = 1 if value == "true" else 0 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think if value is |
||
url = url + f"&{name}={param_value}" | ||
r = requests.get(url, timeout=current_app.config["SEARCH_SERVICE_REQUEST_TIMEOUT"]) | ||
r.raise_for_status() | ||
result = r.json() | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
from datetime import datetime | ||
|
||
from flask import url_for | ||
from flask import current_app, url_for | ||
|
||
import udata.core.organization.constants as org_constants | ||
from udata.core.dataset.apiv2 import DEFAULT_PAGE_SIZE | ||
|
@@ -53,6 +53,8 @@ def test_search_dataset(self): | |
_dataset_org = DatasetFactory(organization=org) | ||
dataset_org_public_service = DatasetFactory(organization=org_public_service) | ||
|
||
# This is needed or the test will fail if you have a search service configured in your udata.cfg file. | ||
current_app.config["SEARCH_SERVICE_API_URL"] = "" | ||
Comment on lines
+56
to
+57
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is unrelated to this PR, but this test will fail if you have a search service configured, which I needed to fix this PR ;) |
||
response = self.get( | ||
url_for("apiv2.dataset_search", organization_badge=org_constants.PUBLIC_SERVICE) | ||
) | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,5 @@ | ||
import pytest | ||
from flask import current_app | ||
|
||
from udata.core.dataset import tasks | ||
|
||
|
@@ -22,6 +23,9 @@ def test_purge_datasets(): | |
Dataset.objects.create(title="keep me"), | ||
] | ||
|
||
# This is needed or the test will fail if you have a search service configured in your udata.cfg file. | ||
current_app.config["SEARCH_SERVICE_API_URL"] = "" | ||
|
||
Comment on lines
+26
to
+28
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is unrelated to this PR, but this test will fail if you have a search service configured, which I needed to fix this PR ;) |
||
topic = Topic.objects.create(name="test topic", datasets=datasets) | ||
|
||
user = UserFactory() | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Somehow on udata-search-service side, featured is not set to 0 or 1 but 1 or 4 (probably for poorly decided scoring reasons) 🥲