added filter by shipping cost to product search
This commit is contained in:
@@ -460,6 +460,9 @@ class ProductSearchTest(TestCase):
|
||||
self.user.set_password(self.password)
|
||||
self.user.save()
|
||||
|
||||
def tearDown(self):
|
||||
self.model.objects.all().delete()
|
||||
|
||||
def test_anon_user_can_search(self):
|
||||
expected_instances = [
|
||||
self.factory(tags="lunares/rojos", category='zapatos', description="zapatos verdes"),
|
||||
@@ -478,7 +481,6 @@ class ProductSearchTest(TestCase):
|
||||
url = f"{self.endpoint}?query_string={query_string}"
|
||||
# send in request
|
||||
response = self.client.get(url)
|
||||
# import ipdb; ipdb.set_trace()
|
||||
|
||||
# check response
|
||||
self.assertEqual(response.status_code, 200)
|
||||
@@ -523,7 +525,56 @@ class ProductSearchTest(TestCase):
|
||||
# load response data
|
||||
payload = response.json()
|
||||
self.assertEquals(len(payload['products']), limit)
|
||||
self.assertEquals(payload['total_results'], len(expected_instances))
|
||||
self.assertEquals(payload['count'], len(expected_instances))
|
||||
|
||||
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"),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
# shipping_cost=true
|
||||
url = f"{self.endpoint}?query_string={query_string}&shipping_cost=true"
|
||||
# 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']), 3)
|
||||
|
||||
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"),
|
||||
]
|
||||
|
||||
query_string = quote("zapatos rojos")
|
||||
|
||||
# shipping_cost=false
|
||||
url = f"{self.endpoint}?query_string={query_string}&shipping_cost=false"
|
||||
# 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']), 2)
|
||||
|
||||
|
||||
class MyProductsViewTest(APITestCase):
|
||||
@@ -607,7 +658,3 @@ class FindRelatedProductsTest(APITestCase):
|
||||
# assert result
|
||||
self.assertTrue(len(results) == len(expected_instances))
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user