Adds a validation based on available_products to validate_cart, and a test based on simple enabling conditions

This commit is contained in:
Christopher Neugebauer 2016-04-06 10:22:44 +10:00
parent 8b13bb9bc5
commit f5d9458d1a
2 changed files with 47 additions and 6 deletions

View file

@ -203,15 +203,35 @@ class CartController(object):
''' Determines whether the status of the current cart is valid; ''' Determines whether the status of the current cart is valid;
this is normally called before generating or paying an invoice ''' this is normally called before generating or paying an invoice '''
cart = self.cart
user = self.cart.user
errors = []
# TODO: validate vouchers # TODO: validate vouchers
items = rego.ProductItem.objects.filter(cart=self.cart) items = rego.ProductItem.objects.filter(cart=cart)
products = set(i.product for i in items)
available = set(ProductController.available_products(
user,
products=products,
))
if products != available:
# Then we have products that aren't available any more.
for product in products:
if product not in available:
message = "%s is no longer available to you." % product
errors.append(ValidationError(message))
product_quantities = list((i.product, i.quantity) for i in items) product_quantities = list((i.product, i.quantity) for i in items)
try:
self._test_limits(product_quantities) self._test_limits(product_quantities)
except ValidationError as ve:
errors.append(ve)
# Validate the discounts # Validate the discounts
discount_items = rego.DiscountItem.objects.filter(cart=self.cart) discount_items = rego.DiscountItem.objects.filter(cart=cart)
seen_discounts = set() seen_discounts = set()
for discount_item in discount_items: for discount_item in discount_items:
@ -223,12 +243,17 @@ class CartController(object):
pk=discount.pk) pk=discount.pk)
cond = ConditionController.for_condition(real_discount) cond = ConditionController.for_condition(real_discount)
if not cond.is_met(self.cart.user): if not cond.is_met(user):
raise ValidationError("Discounts are no longer available") errors.append(
ValidationError("Discounts are no longer available")
)
if errors:
raise ValidationError(errors)
@transaction.atomic
def recalculate_discounts(self): def recalculate_discounts(self):
''' Calculates all of the discounts available for this product. ''' Calculates all of the discounts available for this product.
NB should be transactional, and it's terribly inefficient.
''' '''
# Delete the existing entries. # Delete the existing entries.

View file

@ -293,3 +293,19 @@ class EnablingConditionTestCases(RegistrationCartTestCase):
self.assertTrue(self.CAT_1 in cats) self.assertTrue(self.CAT_1 in cats)
self.assertTrue(self.CAT_2 in cats) self.assertTrue(self.CAT_2 in cats)
def test_validate_cart_when_enabling_conditions_become_unmet(self):
self.add_product_enabling_condition(mandatory=False)
cart = TestingCartController.for_user(self.USER_1)
cart.add_to_cart(self.PROD_2, 1)
cart.add_to_cart(self.PROD_1, 1)
# Should pass
cart.validate_cart()
cart.set_quantity(self.PROD_2, 0)
# Should fail
with self.assertRaises(ValidationError):
cart.validate_cart()