mirror of
https://github.com/pretix/pretix.git
synced 2026-05-09 15:54:03 +00:00
Never create implicit payments for orders that require approval
This commit is contained in:
@@ -532,7 +532,7 @@ def _create_order(event: Event, email: str, positions: List[CartPosition], now_d
|
|||||||
fee.tax_rule = None # TODO: deprecate
|
fee.tax_rule = None # TODO: deprecate
|
||||||
fee.save()
|
fee.save()
|
||||||
|
|
||||||
if payment_provider:
|
if payment_provider and not order.require_approval:
|
||||||
order.payments.create(
|
order.payments.create(
|
||||||
state=OrderPayment.PAYMENT_STATE_CREATED,
|
state=OrderPayment.PAYMENT_STATE_CREATED,
|
||||||
provider=payment_provider.identifier,
|
provider=payment_provider.identifier,
|
||||||
|
|||||||
@@ -535,6 +535,8 @@ class PaymentStep(QuestionsViewMixin, CartMixin, TemplateFlowStep):
|
|||||||
|
|
||||||
for cartpos in get_cart(self.request):
|
for cartpos in get_cart(self.request):
|
||||||
if cartpos.item.require_approval:
|
if cartpos.item.require_approval:
|
||||||
|
if 'payment' in self.cart_session:
|
||||||
|
del self.cart_session['payment']
|
||||||
return False
|
return False
|
||||||
|
|
||||||
for p in self.request.event.get_payment_providers().values():
|
for p in self.request.event.get_payment_providers().values():
|
||||||
@@ -542,6 +544,9 @@ class PaymentStep(QuestionsViewMixin, CartMixin, TemplateFlowStep):
|
|||||||
if self._is_allowed(p, request):
|
if self._is_allowed(p, request):
|
||||||
self.cart_session['payment'] = p.identifier
|
self.cart_session['payment'] = p.identifier
|
||||||
return False
|
return False
|
||||||
|
elif self.cart_session.get('payment') == p.identifier:
|
||||||
|
# is_allowed might have changed, e.g. after add-on selection
|
||||||
|
del self.cart_session['payment']
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|||||||
@@ -15,7 +15,8 @@ from django_countries.fields import Country
|
|||||||
from pretix.base.decimal import round_decimal
|
from pretix.base.decimal import round_decimal
|
||||||
from pretix.base.models import (
|
from pretix.base.models import (
|
||||||
CartPosition, Event, Invoice, InvoiceAddress, Item, ItemCategory, Order,
|
CartPosition, Event, Invoice, InvoiceAddress, Item, ItemCategory, Order,
|
||||||
OrderPosition, Organizer, Question, QuestionAnswer, Quota, Voucher,
|
OrderPayment, OrderPosition, Organizer, Question, QuestionAnswer, Quota,
|
||||||
|
Voucher,
|
||||||
)
|
)
|
||||||
from pretix.base.models.items import ItemAddOn, ItemVariation, SubEventItem
|
from pretix.base.models.items import ItemAddOn, ItemVariation, SubEventItem
|
||||||
from pretix.testutils.sessions import get_cart_session_key
|
from pretix.testutils.sessions import get_cart_session_key
|
||||||
@@ -961,6 +962,36 @@ class CheckoutTestCase(TestCase):
|
|||||||
self.assertTrue(Order.objects.first().require_approval)
|
self.assertTrue(Order.objects.first().require_approval)
|
||||||
self.assertEqual(OrderPosition.objects.count(), 1)
|
self.assertEqual(OrderPosition.objects.count(), 1)
|
||||||
|
|
||||||
|
def test_require_approval_in_addon_to_free(self):
|
||||||
|
ItemAddOn.objects.create(base_item=self.ticket, addon_category=self.workshopcat, min_count=1,
|
||||||
|
price_included=True)
|
||||||
|
cp1 = CartPosition.objects.create(
|
||||||
|
event=self.event, cart_id=self.session_key, item=self.ticket,
|
||||||
|
price=0, expires=now() - timedelta(minutes=10)
|
||||||
|
)
|
||||||
|
self.ticket.default_price = 0
|
||||||
|
self.ticket.save()
|
||||||
|
self.client.get('/%s/%s/checkout/questions/' % (self.orga.slug, self.event.slug), follow=True)
|
||||||
|
|
||||||
|
self.workshop1.require_approval = True
|
||||||
|
self.workshop1.save()
|
||||||
|
CartPosition.objects.create(
|
||||||
|
event=self.event, cart_id=self.session_key, item=self.workshop1,
|
||||||
|
price=0, expires=now() - timedelta(minutes=10),
|
||||||
|
addon_to=cp1
|
||||||
|
)
|
||||||
|
self.client.get('/%s/%s/checkout/questions/' % (self.orga.slug, self.event.slug), follow=True)
|
||||||
|
|
||||||
|
response = self.client.post('/%s/%s/checkout/confirm/' % (self.orga.slug, self.event.slug), follow=True)
|
||||||
|
doc = BeautifulSoup(response.rendered_content, "lxml")
|
||||||
|
self.assertEqual(len(doc.select(".thank-you")), 1)
|
||||||
|
self.assertFalse(CartPosition.objects.filter(id=cp1.id).exists())
|
||||||
|
self.assertEqual(Order.objects.count(), 1)
|
||||||
|
self.assertEqual(Order.objects.first().status, Order.STATUS_PENDING)
|
||||||
|
self.assertTrue(Order.objects.first().require_approval)
|
||||||
|
self.assertEqual(OrderPayment.objects.count(), 0)
|
||||||
|
self.assertEqual(OrderPosition.objects.count(), 2)
|
||||||
|
|
||||||
def test_free_price(self):
|
def test_free_price(self):
|
||||||
self.ticket.free_price = True
|
self.ticket.free_price = True
|
||||||
self.ticket.save()
|
self.ticket.save()
|
||||||
|
|||||||
Reference in New Issue
Block a user