Do not create duplicate memberships on order changes (Z#23163336) (#4408)

This commit is contained in:
Raphael Michel
2024-08-21 17:30:42 +02:00
committed by GitHub
parent eb2ad48089
commit b96374fcf6
4 changed files with 46 additions and 3 deletions

View File

@@ -1662,7 +1662,7 @@ class OrderChangeManagerTests(TestCase):
mt = self.event.organizer.membership_types.create(name="foo")
customer = self.event.organizer.customers.create()
self.order.customer = customer
self.o.save()
self.order.save()
m = customer.memberships.create(
membership_type=mt,
date_start=now(),
@@ -1674,6 +1674,37 @@ class OrderChangeManagerTests(TestCase):
m.refresh_from_db()
assert m.canceled
@classscope(attr='o')
def test_create_membership_after_change(self):
mt = self.event.organizer.membership_types.create(name="foo")
customer = self.event.organizer.customers.create()
self.ticket.grant_membership_type = mt
self.ticket.save()
self.ticket2.grant_membership_type = mt
self.ticket2.save()
self.order.customer = customer
self.order.status = Order.STATUS_PAID
self.order.save()
assert customer.memberships.count() == 0
self.ocm.change_item(self.op1, item=self.ticket2, variation=None)
self.ocm.cancel(self.op2)
self.ocm.commit()
self.order.refresh_from_db()
self.op1.refresh_from_db()
customer.refresh_from_db()
assert self.op1.granted_memberships.count() == 1
assert customer.memberships.count() == 1
# But only once
self.ocm = OrderChangeManager(self.order, None)
self.ocm.change_item(self.op1, item=self.ticket, variation=None)
self.ocm.commit()
customer.refresh_from_db()
assert self.op1.granted_memberships.count() == 1
assert customer.memberships.count() == 1
@classscope(attr='o')
def test_cancel_issued_giftcard_used(self):
gc = self.o.issued_gift_cards.create(currency="EUR", issued_in=self.op1)