Do not allow orders with unavailable items to be completed

This commit is contained in:
Raphael Michel
2018-11-13 17:55:56 +01:00
parent 0734715bab
commit 8ffc6550da
2 changed files with 16 additions and 2 deletions

View File

@@ -377,7 +377,7 @@ def _check_positions(event: Event, now_dt: datetime, positions: List[CartPositio
products_seen = Counter() products_seen = Counter()
for i, cp in enumerate(positions): for i, cp in enumerate(positions):
if not cp.item.active or (cp.variation and not cp.variation.active): if not cp.item.is_available() or (cp.variation and not cp.variation.active):
err = err or error_messages['unavailable'] err = err or error_messages['unavailable']
cp.delete() cp.delete()
continue continue

View File

@@ -1502,12 +1502,26 @@ class CheckoutTestCase(TestCase):
self.assertGreaterEqual(len(doc.select(".alert-danger")), 1) self.assertGreaterEqual(len(doc.select(".alert-danger")), 1)
self.assertFalse(CartPosition.objects.filter(id=cr1.id).exists()) self.assertFalse(CartPosition.objects.filter(id=cr1.id).exists())
def test_confirm_no_longer_available(self):
self.ticket.available_until = now() - timedelta(days=1)
self.ticket.save()
cr1 = CartPosition.objects.create(
event=self.event, cart_id=self.session_key, item=self.ticket,
price=23, expires=now() + timedelta(minutes=10)
)
self._set_session('payment', 'banktransfer')
response = self.client.post('/%s/%s/checkout/confirm/' % (self.orga.slug, self.event.slug), follow=True)
doc = BeautifulSoup(response.rendered_content, "lxml")
self.assertGreaterEqual(len(doc.select(".alert-danger")), 1)
self.assertFalse(CartPosition.objects.filter(id=cr1.id).exists())
def test_confirm_inactive(self): def test_confirm_inactive(self):
self.ticket.active = False self.ticket.active = False
self.ticket.save() self.ticket.save()
cr1 = CartPosition.objects.create( cr1 = CartPosition.objects.create(
event=self.event, cart_id=self.session_key, item=self.ticket, event=self.event, cart_id=self.session_key, item=self.ticket,
price=23, expires=now() - timedelta(minutes=10) price=23, expires=now() + timedelta(minutes=10)
) )
self._set_session('payment', 'banktransfer') self._set_session('payment', 'banktransfer')