enabled search by category

This commit is contained in:
Sam
2021-02-23 12:36:12 +00:00
parent cbfbfb93f3
commit 28d61c75c0
3 changed files with 44 additions and 25 deletions

View File

@@ -526,15 +526,15 @@ class ProductSearchTest(TestCase):
def test_anon_user_can_filter_shipping_cost_true(self):
expected_instances = [
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", shipping_cost=None),
self.factory(tags="colores/rojos, tono/brillante", shipping_cost=100.00),
self.factory(tags="lunares/azules", description="zapatos rojos", shipping_cost=12.00),
self.factory(tags="lunares/rojos", description="zapatos", shipping_cost=0.00),
self.factory(attributes='"zapatos de campo", tono/oscuro', shipping_cost=9.00),
]
unexpected_instances = [
self.factory(description="chanclas"),
self.factory(tags="azules"),
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", shipping_cost=None),
self.factory(tags="lunares/rojos", description="zapatos", shipping_cost=0.00),
]
query_string = quote("zapatos rojos")
@@ -546,19 +546,16 @@ class ProductSearchTest(TestCase):
self.assertEqual(response.status_code, 200)
# load response data
payload = response.json()
self.assertEquals(len(payload['products']), 3)
self.assertEquals(len(payload['products']), len(expected_instances))
def test_anon_user_can_filter_shipping_cost_false(self):
expected_instances = [
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", shipping_cost=None),
self.factory(tags="colores/rojos, tono/brillante", shipping_cost=100.00),
self.factory(tags="lunares/azules", description="zapatos rojos", shipping_cost=12.00),
self.factory(tags="lunares/rojos", description="zapatos", shipping_cost=0.00),
self.factory(attributes='"zapatos de campo", tono/oscuro', shipping_cost=9.00),
]
unexpected_instances = [
self.factory(description="chanclas"),
self.factory(tags="azules"),
self.factory(description="chanclas", shipping_cost=100.00),
self.factory(tags="azules", shipping_cost=10.00),
]
query_string = quote("zapatos rojos")
@@ -571,19 +568,17 @@ class ProductSearchTest(TestCase):
self.assertEqual(response.status_code, 200)
# load response data
payload = response.json()
self.assertEquals(len(payload['products']), 2)
self.assertEquals(len(payload['products']), len(expected_instances))
def test_anon_user_can_filter_discount_true(self):
expected_instances = [
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", discount=None),
self.factory(tags="colores/rojos, tono/brillante", discount=100.00),
self.factory(tags="lunares/azules", description="zapatos rojos", discount=12.00),
self.factory(tags="lunares/rojos", description="zapatos", discount=0.00),
self.factory(attributes='"zapatos de campo", tono/oscuro', discount=9.00),
]
unexpected_instances = [
self.factory(description="chanclas"),
self.factory(tags="azules"),
self.factory(description="chanclas", discount=0.00),
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", discount=None),
]
query_string = quote("zapatos rojos")
@@ -595,19 +590,17 @@ class ProductSearchTest(TestCase):
self.assertEqual(response.status_code, 200)
# load response data
payload = response.json()
self.assertEquals(len(payload['products']), 3)
self.assertEquals(len(payload['products']), len(expected_instances))
def test_anon_user_can_filter_discount_false(self):
expected_instances = [
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes", discount=None),
self.factory(tags="colores/rojos, tono/brillante", discount=100.00),
self.factory(tags="lunares/azules", description="zapatos rojos", discount=12.00),
self.factory(tags="lunares/azules", description="zapatos rojos", discount=0.00),
self.factory(tags="lunares/rojos", description="zapatos", discount=0.00),
self.factory(attributes='"zapatos de campo", tono/oscuro', discount=9.00),
]
unexpected_instances = [
self.factory(description="chanclas"),
self.factory(tags="azules"),
self.factory(description="chanclas", discount=100.00),
self.factory(tags="azules", discount=9.00),
]
query_string = quote("zapatos rojos")
@@ -619,7 +612,7 @@ class ProductSearchTest(TestCase):
self.assertEqual(response.status_code, 200)
# load response data
payload = response.json()
self.assertEquals(len(payload['products']), 2)
self.assertEquals(len(payload['products']), len(expected_instances))
def test_anon_user_can_search_empty_string(self):
expected_instances = [
@@ -628,8 +621,6 @@ class ProductSearchTest(TestCase):
self.factory(tags="lunares/azules", description="zapatos rojos", discount=12.00),
self.factory(tags="lunares/rojos", description="zapatos", discount=0.00),
self.factory(attributes='"zapatos de campo", tono/oscuro', discount=9.00),
]
unexpected_instances = [
self.factory(description="chanclas"),
self.factory(tags="azules"),
]
@@ -643,7 +634,29 @@ class ProductSearchTest(TestCase):
self.assertEqual(response.status_code, 200)
# load response data
payload = response.json()
self.assertEquals(len(payload['products']), len(expected_instances) + len(unexpected_instances))
self.assertEquals(len(payload['products']), len(expected_instances))
def test_anon_user_can_filter_by_category(self):
expected_instances = [
self.factory(tags="lunares/rojos", category='ropa', description="zapatos verdes", discount=None),
self.factory(tags="lunares/rojos", category="ropa", discount=0.00),
self.factory(attributes='"zapatos de campo", tono/oscuro', category="ropa", discount=9.00),
]
unexpected_instances = [
self.factory(description="chanclas", tags='rojos'),
self.factory(tags="zapatos/azules", category="deporte", description='rojos', discount=12.00),
]
query_string = quote("zapatos rojos")
# discount=true
url = f"{self.endpoint}?query_string={query_string}&category=ropa"
# 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))
class MyProductsViewTest(APITestCase):