added search filter by min and max price
This commit is contained in:
@@ -680,6 +680,54 @@ class ProductSearchTest(TestCase):
|
|||||||
payload = response.json()
|
payload = response.json()
|
||||||
self.assertEquals(len(payload['products']), len(expected_instances))
|
self.assertEquals(len(payload['products']), len(expected_instances))
|
||||||
|
|
||||||
|
def test_anon_user_can_filter_by_min_price(self):
|
||||||
|
expected_instances = [
|
||||||
|
self.factory(tags="colores/rojos, tono/brillante", price=100.00),
|
||||||
|
self.factory(tags="lunares/azules", description="zapatos rojos", price=12.00),
|
||||||
|
self.factory(attributes='"zapatos de campo", tono/oscuro', price=9.00),
|
||||||
|
]
|
||||||
|
unexpected_instances = [
|
||||||
|
self.factory(description="zapatos", price=4.00),
|
||||||
|
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", price=None),
|
||||||
|
]
|
||||||
|
price_min = 5.00
|
||||||
|
query_string = quote("zapatos rojos")
|
||||||
|
url = f"{self.endpoint}?query_string={query_string}&price_min={price_min}"
|
||||||
|
# send in request
|
||||||
|
response = self.client.get(url)
|
||||||
|
|
||||||
|
# check response
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
# load response data
|
||||||
|
payload = response.json()
|
||||||
|
self.assertEquals(len(payload['products']), len(expected_instances))
|
||||||
|
for product in payload['products']:
|
||||||
|
self.assertTrue(float(product['price']) >= price_min)
|
||||||
|
|
||||||
|
def test_anon_user_can_filter_by_max_price(self):
|
||||||
|
expected_instances = [
|
||||||
|
self.factory(tags="colores/rojos, tono/brillante", price=10.00),
|
||||||
|
self.factory(tags="lunares/azules", description="zapatos rojos", price=12.00),
|
||||||
|
self.factory(attributes='"zapatos de campo", tono/oscuro', price=49.00),
|
||||||
|
]
|
||||||
|
unexpected_instances = [
|
||||||
|
self.factory(description="zapatos", price=60.00),
|
||||||
|
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", price=100.00),
|
||||||
|
]
|
||||||
|
price_max = 50.00
|
||||||
|
query_string = quote("zapatos rojos")
|
||||||
|
url = f"{self.endpoint}?query_string={query_string}&price_max={price_max}"
|
||||||
|
# send in request
|
||||||
|
response = self.client.get(url)
|
||||||
|
|
||||||
|
# check response
|
||||||
|
self.assertEqual(response.status_code, 200)
|
||||||
|
# load response data
|
||||||
|
payload = response.json()
|
||||||
|
self.assertEquals(len(payload['products']), len(expected_instances))
|
||||||
|
for product in payload['products']:
|
||||||
|
self.assertTrue(float(product['price']) <= price_max)
|
||||||
|
|
||||||
|
|
||||||
class MyProductsViewTest(APITestCase):
|
class MyProductsViewTest(APITestCase):
|
||||||
"""my_products tests
|
"""my_products tests
|
||||||
|
|||||||
@@ -125,7 +125,7 @@ def find_related_products_v3(keyword):
|
|||||||
return set(products_qs)
|
return set(products_qs)
|
||||||
|
|
||||||
|
|
||||||
def find_related_products_v6(keyword, shipping_cost=None, discount=None, category=None, tags=None):
|
def find_related_products_v6(keyword, shipping_cost=None, discount=None, category=None, tags=None, price_min=None,price_max=None):
|
||||||
"""
|
"""
|
||||||
Ranked product search
|
Ranked product search
|
||||||
|
|
||||||
@@ -151,7 +151,7 @@ def find_related_products_v6(keyword, shipping_cost=None, discount=None, categor
|
|||||||
if tags is not None:
|
if tags is not None:
|
||||||
products_qs = products_qs.filter(tags=tags)
|
products_qs = products_qs.filter(tags=tags)
|
||||||
|
|
||||||
# filter for shipping cost
|
# filter by shipping cost
|
||||||
if shipping_cost is True:
|
if shipping_cost is True:
|
||||||
# only instances with shipping costs
|
# only instances with shipping costs
|
||||||
products_qs = products_qs.filter(
|
products_qs = products_qs.filter(
|
||||||
@@ -162,7 +162,7 @@ def find_related_products_v6(keyword, shipping_cost=None, discount=None, categor
|
|||||||
# only intances without shpping costs
|
# only intances without shpping costs
|
||||||
products_qs = products_qs.filter(Q(shipping_cost=None)|Q(shipping_cost=0.00))
|
products_qs = products_qs.filter(Q(shipping_cost=None)|Q(shipping_cost=0.00))
|
||||||
|
|
||||||
# filter for discount
|
# filter by discount
|
||||||
if discount is True:
|
if discount is True:
|
||||||
# only instances with shipping costs
|
# only instances with shipping costs
|
||||||
products_qs = products_qs.filter(
|
products_qs = products_qs.filter(
|
||||||
@@ -173,6 +173,12 @@ def find_related_products_v6(keyword, shipping_cost=None, discount=None, categor
|
|||||||
# only intances without shpping costs
|
# only intances without shpping costs
|
||||||
products_qs = products_qs.filter(Q(discount=None)|Q(discount=0.00))
|
products_qs = products_qs.filter(Q(discount=None)|Q(discount=0.00))
|
||||||
|
|
||||||
|
# filter by price
|
||||||
|
if price_min is not None:
|
||||||
|
products_qs = products_qs.filter(price__gt=price_min)
|
||||||
|
if price_max is not None:
|
||||||
|
products_qs = products_qs.filter(price__lt=price_max)
|
||||||
|
|
||||||
return set(products_qs)
|
return set(products_qs)
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -177,6 +177,8 @@ def product_search(request):
|
|||||||
discount = None
|
discount = None
|
||||||
category = request.GET.get('category', None)
|
category = request.GET.get('category', None)
|
||||||
tags = request.GET.get('tags', None)
|
tags = request.GET.get('tags', None)
|
||||||
|
price_min = request.GET.get('price_min', None)
|
||||||
|
price_max = request.GET.get('price_max', None)
|
||||||
|
|
||||||
if query_string is None:
|
if query_string is None:
|
||||||
return Response({"errors": {"details": "No query string to parse"}})
|
return Response({"errors": {"details": "No query string to parse"}})
|
||||||
@@ -193,7 +195,7 @@ def product_search(request):
|
|||||||
# split query string into single words
|
# split query string into single words
|
||||||
chunks = query_string.split(' ')
|
chunks = query_string.split(' ')
|
||||||
for chunk in chunks:
|
for chunk in chunks:
|
||||||
product_set = find_related_products_v6(chunk, shipping_cost, discount, category, tags)
|
product_set = find_related_products_v6(chunk, shipping_cost, discount, category, tags, price_min, price_max)
|
||||||
# add to result set
|
# add to result set
|
||||||
result_set.update(product_set)
|
result_set.update(product_set)
|
||||||
# TODO: add search for entire phrase ???
|
# TODO: add search for entire phrase ???
|
||||||
|
|||||||
Reference in New Issue
Block a user