forked from CGM_Public/pretix_original
Integrate django-scopes (#1319)
* Install django-scopes * Fix tests.api * Update tasks and cronjobs * Fix remaining tests * Remove unused import * Fix tests after rebase * Disable scopes for get_Events_with_any_permission * Disable scopes for a management command
This commit is contained in:
@@ -3,6 +3,7 @@ import decimal
|
||||
import json
|
||||
|
||||
from django.utils.timezone import now
|
||||
from django_scopes import scopes_disabled
|
||||
from tests.base import SoupTest, extract_form_fields
|
||||
|
||||
from pretix.base.models import (
|
||||
@@ -12,6 +13,7 @@ from pretix.base.models import (
|
||||
|
||||
|
||||
class VoucherFormTest(SoupTest):
|
||||
@scopes_disabled()
|
||||
def setUp(self):
|
||||
super().setUp()
|
||||
self.user = User.objects.create_user('dummy@dummy.dummy', 'dummy')
|
||||
@@ -38,30 +40,34 @@ class VoucherFormTest(SoupTest):
|
||||
self.quota_tickets.items.add(self.ticket)
|
||||
|
||||
def _create_voucher(self, data, expected_failure=False):
|
||||
count_before = self.event.vouchers.count()
|
||||
with scopes_disabled():
|
||||
count_before = self.event.vouchers.count()
|
||||
doc = self.get_doc('/control/event/%s/%s/vouchers/add' % (self.orga.slug, self.event.slug))
|
||||
form_data = extract_form_fields(doc.select('.container-fluid form')[0])
|
||||
form_data.update(data)
|
||||
doc = self.post_doc('/control/event/%s/%s/vouchers/add' % (self.orga.slug, self.event.slug), form_data)
|
||||
if expected_failure:
|
||||
assert doc.select(".alert-danger, .has-error")
|
||||
assert count_before == self.event.vouchers.count()
|
||||
else:
|
||||
assert doc.select(".alert-success")
|
||||
assert count_before + 1 == self.event.vouchers.count()
|
||||
with scopes_disabled():
|
||||
if expected_failure:
|
||||
assert doc.select(".alert-danger, .has-error")
|
||||
assert count_before == self.event.vouchers.count()
|
||||
else:
|
||||
assert doc.select(".alert-success")
|
||||
assert count_before + 1 == self.event.vouchers.count()
|
||||
|
||||
def _create_bulk_vouchers(self, data, expected_failure=False):
|
||||
count_before = self.event.vouchers.count()
|
||||
with scopes_disabled():
|
||||
count_before = self.event.vouchers.count()
|
||||
doc = self.get_doc('/control/event/%s/%s/vouchers/bulk_add' % (self.orga.slug, self.event.slug))
|
||||
form_data = extract_form_fields(doc.select('.container-fluid form')[0])
|
||||
form_data.update(data)
|
||||
doc = self.post_doc('/control/event/%s/%s/vouchers/bulk_add' % (self.orga.slug, self.event.slug), form_data)
|
||||
if expected_failure:
|
||||
assert doc.select(".alert-danger")
|
||||
assert count_before == self.event.vouchers.count()
|
||||
else:
|
||||
assert doc.select(".alert-success")
|
||||
assert count_before + len(form_data.get('codes').split("\n")) == self.event.vouchers.count()
|
||||
with scopes_disabled():
|
||||
if expected_failure:
|
||||
assert doc.select(".alert-danger")
|
||||
assert count_before == self.event.vouchers.count()
|
||||
else:
|
||||
assert doc.select(".alert-success")
|
||||
assert count_before + len(form_data.get('codes').split("\n")) == self.event.vouchers.count()
|
||||
|
||||
def _change_voucher(self, v, data, expected_failure=False):
|
||||
doc = self.get_doc('/control/event/%s/%s/vouchers/%s/' % (self.orga.slug, self.event.slug, v.pk))
|
||||
@@ -74,59 +80,66 @@ class VoucherFormTest(SoupTest):
|
||||
assert doc.select(".alert-success")
|
||||
|
||||
def test_list(self):
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG')
|
||||
with scopes_disabled():
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG')
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/' % (self.orga.slug, self.event.slug))
|
||||
assert 'ABCDEFG' in doc.rendered_content
|
||||
assert 'ABCDEFG' in doc.content.decode()
|
||||
|
||||
def test_csv(self):
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG')
|
||||
with scopes_disabled():
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG')
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?download=yes' % (self.orga.slug, self.event.slug))
|
||||
assert doc.content.strip() == '"Voucher code","Valid until","Product","Reserve quota","Bypass quota",' \
|
||||
'"Price effect","Value","Tag","Redeemed","Maximum usages"\r\n"ABCDEFG","",' \
|
||||
'"Early-bird ticket","No","No","No effect","","","0","1"'.encode('utf-8')
|
||||
assert doc.content.decode().strip() == '"Voucher code","Valid until","Product","Reserve quota",' \
|
||||
'"Bypass quota","Price effect","Value","Tag","Redeemed","Maximum usages"' \
|
||||
'\r\n"ABCDEFG","","Early-bird ticket","No","No","No effect","","","0","1"'
|
||||
|
||||
def test_filter_status_valid(self):
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?status=v' % (self.orga.slug, self.event.slug))
|
||||
assert v.code in doc.rendered_content
|
||||
assert v.code in doc.content.decode()
|
||||
v.redeemed = 1
|
||||
v.save()
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?status=v' % (self.orga.slug, self.event.slug))
|
||||
assert v.code not in doc.rendered_content
|
||||
assert v.code not in doc.content.decode()
|
||||
|
||||
def test_filter_status_redeemed(self):
|
||||
v = self.event.vouchers.create(item=self.ticket, redeemed=1)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket, redeemed=1)
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?status=r' % (self.orga.slug, self.event.slug))
|
||||
assert v.code in doc.rendered_content
|
||||
assert v.code in doc.content.decode()
|
||||
v.redeemed = 0
|
||||
v.save()
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?status=r' % (self.orga.slug, self.event.slug))
|
||||
assert v.code not in doc.rendered_content
|
||||
assert v.code not in doc.content.decode()
|
||||
|
||||
def test_filter_status_expired(self):
|
||||
v = self.event.vouchers.create(item=self.ticket, valid_until=now() + datetime.timedelta(days=1))
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket, valid_until=now() + datetime.timedelta(days=1))
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?status=e' % (self.orga.slug, self.event.slug))
|
||||
assert v.code not in doc.rendered_content
|
||||
assert v.code not in doc.content.decode()
|
||||
v.valid_until = now() - datetime.timedelta(days=1)
|
||||
v.save()
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?status=e' % (self.orga.slug, self.event.slug))
|
||||
assert v.code in doc.rendered_content
|
||||
assert v.code in doc.content.decode()
|
||||
|
||||
def test_filter_tag(self):
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG', comment='Foo', tag='bar')
|
||||
with scopes_disabled():
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG', comment='Foo', tag='bar')
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?tag=bar' % (self.orga.slug, self.event.slug))
|
||||
assert 'ABCDEFG' in doc.rendered_content
|
||||
assert 'ABCDEFG' in doc.content.decode()
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?tag=baz' % (self.orga.slug, self.event.slug))
|
||||
assert 'ABCDEFG' not in doc.rendered_content
|
||||
assert 'ABCDEFG' not in doc.content.decode()
|
||||
|
||||
def test_search_code(self):
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG', comment='Foo')
|
||||
with scopes_disabled():
|
||||
self.event.vouchers.create(item=self.ticket, code='ABCDEFG', comment='Foo')
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?search=ABCDEFG' % (self.orga.slug, self.event.slug))
|
||||
assert 'ABCDEFG' in doc.rendered_content
|
||||
assert 'ABCDEFG' in doc.content.decode()
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?search=Foo' % (self.orga.slug, self.event.slug))
|
||||
assert 'ABCDEFG' in doc.rendered_content
|
||||
assert 'ABCDEFG' in doc.content.decode()
|
||||
doc = self.client.get('/control/event/%s/%s/vouchers/?search=12345' % (self.orga.slug, self.event.slug))
|
||||
assert 'ABCDEFG' not in doc.rendered_content
|
||||
assert 'ABCDEFG' not in doc.content.decode()
|
||||
|
||||
def test_bulk_rng(self):
|
||||
rng = self.client.get('/control/event/%s/%s/vouchers/rng?num=7' % (self.orga.slug, self.event.slug))
|
||||
@@ -135,19 +148,22 @@ class VoucherFormTest(SoupTest):
|
||||
assert all([len(r) == 16 for r in codes])
|
||||
|
||||
def test_display_voucher_code(self):
|
||||
count_before = self.event.vouchers.count()
|
||||
with scopes_disabled():
|
||||
count_before = self.event.vouchers.count()
|
||||
doc = self.get_doc('/control/event/%s/%s/vouchers/add' % (self.orga.slug, self.event.slug))
|
||||
form_data = extract_form_fields(doc.select('.container-fluid form')[0])
|
||||
form_data.update({
|
||||
'itemvar': '%d' % self.ticket.pk
|
||||
})
|
||||
doc = self.post_doc('/control/event/%s/%s/vouchers/add' % (self.orga.slug, self.event.slug), form_data)
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert v.code in doc.select(".alert-success")[0].text
|
||||
assert count_before + 1 == self.event.vouchers.count()
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert v.code in doc.select(".alert-success")[0].text
|
||||
assert count_before + 1 == self.event.vouchers.count()
|
||||
|
||||
def test_create_voucher_for_addon_item(self):
|
||||
c = self.event.categories.create(name="Foo", is_addon=True)
|
||||
with scopes_disabled():
|
||||
c = self.event.categories.create(name="Foo", is_addon=True)
|
||||
self.ticket.category = c
|
||||
self.ticket.save()
|
||||
self._create_voucher({
|
||||
@@ -158,7 +174,8 @@ class VoucherFormTest(SoupTest):
|
||||
self._create_voucher({
|
||||
'itemvar': '%d' % self.ticket.pk
|
||||
})
|
||||
v = Voucher.objects.latest('pk')
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert not v.block_quota
|
||||
assert v.item.pk == self.ticket.pk
|
||||
assert v.variation is None
|
||||
@@ -168,7 +185,8 @@ class VoucherFormTest(SoupTest):
|
||||
self._create_voucher({
|
||||
'itemvar': '%d-%d' % (self.shirt.pk, self.shirt_red.pk)
|
||||
})
|
||||
v = Voucher.objects.latest('pk')
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert not v.block_quota
|
||||
assert v.item.pk == self.shirt.pk
|
||||
assert v.variation.pk == self.shirt_red.pk
|
||||
@@ -178,7 +196,8 @@ class VoucherFormTest(SoupTest):
|
||||
self._create_voucher({
|
||||
'itemvar': 'q-%d' % self.quota_tickets.pk
|
||||
})
|
||||
v = Voucher.objects.latest('pk')
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert not v.block_quota
|
||||
assert v.item is None
|
||||
assert v.variation is None
|
||||
@@ -189,7 +208,8 @@ class VoucherFormTest(SoupTest):
|
||||
'itemvar': '%d' % self.ticket.pk,
|
||||
'block_quota': 'on'
|
||||
})
|
||||
v = Voucher.objects.latest('pk')
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert v.block_quota
|
||||
|
||||
def test_create_blocking_item_voucher_quota_full(self):
|
||||
@@ -213,7 +233,8 @@ class VoucherFormTest(SoupTest):
|
||||
'itemvar': '%d-%d' % (self.shirt.pk, self.shirt_red.pk),
|
||||
'block_quota': 'on'
|
||||
})
|
||||
v = Voucher.objects.latest('pk')
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert v.block_quota
|
||||
|
||||
def test_create_short_code(self):
|
||||
@@ -235,7 +256,8 @@ class VoucherFormTest(SoupTest):
|
||||
'itemvar': 'q-%d' % self.quota_tickets.pk,
|
||||
'block_quota': 'on'
|
||||
})
|
||||
v = Voucher.objects.latest('pk')
|
||||
with scopes_disabled():
|
||||
v = Voucher.objects.latest('pk')
|
||||
assert v.block_quota
|
||||
|
||||
def test_create_blocking_quota_voucher_quota_full(self):
|
||||
@@ -247,7 +269,8 @@ class VoucherFormTest(SoupTest):
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_change_non_blocking_voucher(self):
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': 'q-%d' % self.quota_tickets.pk
|
||||
})
|
||||
@@ -259,14 +282,16 @@ class VoucherFormTest(SoupTest):
|
||||
def test_change_blocking_voucher_unchanged_quota_full(self):
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
})
|
||||
v.refresh_from_db()
|
||||
assert v.block_quota
|
||||
|
||||
def test_change_voucher_reduce_max_usages(self):
|
||||
v = self.event.vouchers.create(item=self.ticket, max_usages=5, redeemed=3)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket, max_usages=5, redeemed=3)
|
||||
self._change_voucher(v, {
|
||||
'max_usages': '2'
|
||||
}, expected_failure=True)
|
||||
@@ -274,13 +299,15 @@ class VoucherFormTest(SoupTest):
|
||||
def test_change_voucher_to_blocking_quota_full(self):
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
self._change_voucher(v, {
|
||||
'block_quota': 'on'
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_change_voucher_to_blocking_quota_free(self):
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket)
|
||||
self._change_voucher(v, {
|
||||
'block_quota': 'on'
|
||||
})
|
||||
@@ -290,8 +317,9 @@ class VoucherFormTest(SoupTest):
|
||||
def test_change_voucher_validity_to_valid_quota_full(self):
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
v = self.event.vouchers.create(item=self.ticket, valid_until=now() - datetime.timedelta(days=3),
|
||||
block_quota=True)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket, valid_until=now() - datetime.timedelta(days=3),
|
||||
block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'valid_until_0': (now() + datetime.timedelta(days=3)).strftime('%Y-%m-%d'),
|
||||
'valid_until_1': (now() + datetime.timedelta(days=3)).strftime('%H:%M:%S')
|
||||
@@ -300,8 +328,9 @@ class VoucherFormTest(SoupTest):
|
||||
assert v.valid_until < now()
|
||||
|
||||
def test_change_voucher_validity_to_valid_quota_free(self):
|
||||
v = self.event.vouchers.create(item=self.ticket, valid_until=now() - datetime.timedelta(days=3),
|
||||
block_quota=True)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(item=self.ticket, valid_until=now() - datetime.timedelta(days=3),
|
||||
block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'valid_until_0': (now() + datetime.timedelta(days=3)).strftime('%Y-%m-%d'),
|
||||
'valid_until_1': (now() + datetime.timedelta(days=3)).strftime('%H:%M:%S')
|
||||
@@ -310,9 +339,10 @@ class VoucherFormTest(SoupTest):
|
||||
assert v.valid_until > now()
|
||||
|
||||
def test_change_item_of_blocking_voucher_quota_free(self):
|
||||
ticket2 = Item.objects.create(event=self.event, name='Late-bird ticket', default_price=23)
|
||||
self.quota_tickets.items.add(ticket2)
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
with scopes_disabled():
|
||||
ticket2 = Item.objects.create(event=self.event, name='Late-bird ticket', default_price=23)
|
||||
self.quota_tickets.items.add(ticket2)
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': '%d' % ticket2.pk,
|
||||
})
|
||||
@@ -320,72 +350,81 @@ class VoucherFormTest(SoupTest):
|
||||
def test_change_item_of_blocking_voucher_quota_full(self):
|
||||
self.quota_shirts.size = 0
|
||||
self.quota_shirts.save()
|
||||
hoodie = Item.objects.create(event=self.event, name='Hoodie', default_price=23)
|
||||
self.quota_shirts.items.add(hoodie)
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
with scopes_disabled():
|
||||
hoodie = Item.objects.create(event=self.event, name='Hoodie', default_price=23)
|
||||
self.quota_shirts.items.add(hoodie)
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': '%d' % hoodie.pk,
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_change_variation_of_blocking_voucher_quota_free(self):
|
||||
self.quota_shirts.variations.remove(self.shirt_blue)
|
||||
self.quota_tickets.variations.add(self.shirt_blue)
|
||||
v = self.event.vouchers.create(item=self.shirt, variation=self.shirt_red, block_quota=True)
|
||||
with scopes_disabled():
|
||||
self.quota_shirts.variations.remove(self.shirt_blue)
|
||||
self.quota_tickets.variations.add(self.shirt_blue)
|
||||
v = self.event.vouchers.create(item=self.shirt, variation=self.shirt_red, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': '%d-%d' % (self.shirt.pk, self.shirt_blue.pk),
|
||||
})
|
||||
|
||||
def test_change_variation_of_blocking_voucher_quota_full(self):
|
||||
self.quota_shirts.variations.remove(self.shirt_blue)
|
||||
self.quota_tickets.variations.add(self.shirt_blue)
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
v = self.event.vouchers.create(item=self.shirt, variation=self.shirt_red, block_quota=True)
|
||||
with scopes_disabled():
|
||||
self.quota_shirts.variations.remove(self.shirt_blue)
|
||||
self.quota_tickets.variations.add(self.shirt_blue)
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
v = self.event.vouchers.create(item=self.shirt, variation=self.shirt_red, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': '%d-%d' % (self.shirt.pk, self.shirt_blue.pk),
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_change_quota_of_blocking_voucher_quota_free(self):
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets, block_quota=True)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': 'q-%d' % self.quota_shirts.pk,
|
||||
})
|
||||
|
||||
def test_change_quota_of_blocking_voucher_quota_full(self):
|
||||
self.quota_shirts.size = 0
|
||||
self.quota_shirts.save()
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets, block_quota=True)
|
||||
with scopes_disabled():
|
||||
self.quota_shirts.size = 0
|
||||
self.quota_shirts.save()
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': 'q-%d' % self.quota_shirts.pk,
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_change_item_of_blocking_voucher_without_quota_change(self):
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
ticket2 = Item.objects.create(event=self.event, name='Standard Ticket', default_price=23)
|
||||
self.quota_tickets.items.add(ticket2)
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
with scopes_disabled():
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
ticket2 = Item.objects.create(event=self.event, name='Standard Ticket', default_price=23)
|
||||
self.quota_tickets.items.add(ticket2)
|
||||
v = self.event.vouchers.create(item=self.ticket, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': '%d' % ticket2.pk,
|
||||
})
|
||||
|
||||
def test_change_variation_of_blocking_voucher_without_quota_change(self):
|
||||
self.quota_shirts.size = 0
|
||||
self.quota_shirts.save()
|
||||
v = self.event.vouchers.create(item=self.shirt, variation=self.shirt_red, block_quota=True)
|
||||
with scopes_disabled():
|
||||
self.quota_shirts.size = 0
|
||||
self.quota_shirts.save()
|
||||
v = self.event.vouchers.create(item=self.shirt, variation=self.shirt_red, block_quota=True)
|
||||
self._change_voucher(v, {
|
||||
'itemvar': '%d-%d' % (self.shirt.pk, self.shirt_blue.pk),
|
||||
})
|
||||
|
||||
def test_create_duplicate_code(self):
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
self._create_voucher({
|
||||
'code': v.code,
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_change_code_to_duplicate(self):
|
||||
v1 = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
v2 = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
with scopes_disabled():
|
||||
v1 = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
v2 = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
self._change_voucher(v1, {
|
||||
'code': v2.code
|
||||
}, expected_failure=True)
|
||||
@@ -430,14 +469,16 @@ class VoucherFormTest(SoupTest):
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_create_bulk_with_duplicate_code(self):
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
self._create_bulk_vouchers({
|
||||
'codes': 'ABCDE\n%s' % v.code,
|
||||
'itemvar': '%d' % self.shirt.pk,
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_delete_voucher(self):
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets)
|
||||
doc = self.get_doc('/control/event/%s/%s/vouchers/%s/delete' % (self.orga.slug, self.event.slug, v.pk),
|
||||
follow=True)
|
||||
assert not doc.select(".alert-danger")
|
||||
@@ -445,10 +486,12 @@ class VoucherFormTest(SoupTest):
|
||||
doc = self.post_doc('/control/event/%s/%s/vouchers/%s/delete' % (self.orga.slug, self.event.slug, v.pk),
|
||||
{}, follow=True)
|
||||
assert doc.select(".alert-success")
|
||||
assert not self.event.vouchers.filter(pk=v.id).exists()
|
||||
with scopes_disabled():
|
||||
assert not self.event.vouchers.filter(pk=v.id).exists()
|
||||
|
||||
def test_delete_voucher_redeemed(self):
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets, redeemed=1)
|
||||
with scopes_disabled():
|
||||
v = self.event.vouchers.create(quota=self.quota_tickets, redeemed=1)
|
||||
doc = self.get_doc('/control/event/%s/%s/vouchers/%s/delete' % (self.orga.slug, self.event.slug, v.pk),
|
||||
follow=True)
|
||||
assert doc.select(".alert-danger")
|
||||
@@ -465,13 +508,14 @@ class VoucherFormTest(SoupTest):
|
||||
})
|
||||
|
||||
def test_subevent_non_blocking_quota_no_date(self):
|
||||
self.event.has_subevents = True
|
||||
self.event.save()
|
||||
se1 = self.event.subevents.create(name="Foo", date_from=now())
|
||||
self.event.subevents.create(name="Bar", date_from=now())
|
||||
with scopes_disabled():
|
||||
self.event.has_subevents = True
|
||||
self.event.save()
|
||||
se1 = self.event.subevents.create(name="Foo", date_from=now())
|
||||
self.event.subevents.create(name="Bar", date_from=now())
|
||||
|
||||
self.quota_tickets.subevent = se1
|
||||
self.quota_tickets.save()
|
||||
self.quota_tickets.subevent = se1
|
||||
self.quota_tickets.save()
|
||||
|
||||
self._create_voucher({
|
||||
'itemvar': 'q-%d' % self.quota_tickets.pk,
|
||||
@@ -486,15 +530,16 @@ class VoucherFormTest(SoupTest):
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_subevent_blocking_quota_free(self):
|
||||
self.event.has_subevents = True
|
||||
self.event.save()
|
||||
se1 = self.event.subevents.create(name="Foo", date_from=now())
|
||||
se2 = self.event.subevents.create(name="Bar", date_from=now())
|
||||
with scopes_disabled():
|
||||
self.event.has_subevents = True
|
||||
self.event.save()
|
||||
se1 = self.event.subevents.create(name="Foo", date_from=now())
|
||||
se2 = self.event.subevents.create(name="Bar", date_from=now())
|
||||
|
||||
self.quota_tickets.subevent = se1
|
||||
self.quota_tickets.save()
|
||||
q2 = Quota.objects.create(event=self.event, name='Tickets', size=0, subevent=se2)
|
||||
q2.items.add(self.ticket)
|
||||
self.quota_tickets.subevent = se1
|
||||
self.quota_tickets.save()
|
||||
q2 = Quota.objects.create(event=self.event, name='Tickets', size=0, subevent=se2)
|
||||
q2.items.add(self.ticket)
|
||||
|
||||
self._create_voucher({
|
||||
'itemvar': '%d' % self.ticket.pk,
|
||||
@@ -505,14 +550,15 @@ class VoucherFormTest(SoupTest):
|
||||
def test_subevent_blocking_quota_full(self):
|
||||
self.event.has_subevents = True
|
||||
self.event.save()
|
||||
se1 = self.event.subevents.create(name="Foo", date_from=now())
|
||||
se2 = self.event.subevents.create(name="Bar", date_from=now())
|
||||
with scopes_disabled():
|
||||
se1 = self.event.subevents.create(name="Foo", date_from=now())
|
||||
se2 = self.event.subevents.create(name="Bar", date_from=now())
|
||||
|
||||
self.quota_tickets.subevent = se1
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
q2 = Quota.objects.create(event=self.event, name='Tickets', size=5, subevent=se2)
|
||||
q2.items.add(self.ticket)
|
||||
self.quota_tickets.subevent = se1
|
||||
self.quota_tickets.size = 0
|
||||
self.quota_tickets.save()
|
||||
q2 = Quota.objects.create(event=self.event, name='Tickets', size=5, subevent=se2)
|
||||
q2.items.add(self.ticket)
|
||||
|
||||
self._create_voucher({
|
||||
'itemvar': '%d' % self.ticket.pk,
|
||||
@@ -521,32 +567,33 @@ class VoucherFormTest(SoupTest):
|
||||
}, expected_failure=True)
|
||||
|
||||
def test_order_warning_deduplication(self):
|
||||
shirt_voucher = Voucher.objects.create(
|
||||
event=self.event, item=self.shirt, price_mode='set', value=0.0, max_usages=100
|
||||
)
|
||||
with scopes_disabled():
|
||||
shirt_voucher = Voucher.objects.create(
|
||||
event=self.event, item=self.shirt, price_mode='set', value=0.0, max_usages=100
|
||||
)
|
||||
|
||||
shirt_order = Order.objects.create(
|
||||
code='DEDUP', event=self.event, email='dummy@dummy.test',
|
||||
status=Order.STATUS_PAID,
|
||||
datetime=now(), expires=now() + datetime.timedelta(days=10),
|
||||
total=0, locale='en'
|
||||
)
|
||||
shirt_order = Order.objects.create(
|
||||
code='DEDUP', event=self.event, email='dummy@dummy.test',
|
||||
status=Order.STATUS_PAID,
|
||||
datetime=now(), expires=now() + datetime.timedelta(days=10),
|
||||
total=0, locale='en'
|
||||
)
|
||||
|
||||
OrderPosition.objects.create(
|
||||
order=shirt_order,
|
||||
item=self.shirt,
|
||||
variation=self.shirt_red,
|
||||
price=decimal.Decimal("0"),
|
||||
voucher=shirt_voucher
|
||||
)
|
||||
OrderPosition.objects.create(
|
||||
order=shirt_order,
|
||||
item=self.shirt,
|
||||
variation=self.shirt_red,
|
||||
price=decimal.Decimal("0"),
|
||||
voucher=shirt_voucher
|
||||
)
|
||||
|
||||
OrderPosition.objects.create(
|
||||
order=shirt_order,
|
||||
item=self.shirt,
|
||||
variation=self.shirt_blue,
|
||||
price=decimal.Decimal("0"),
|
||||
voucher=shirt_voucher
|
||||
)
|
||||
OrderPosition.objects.create(
|
||||
order=shirt_order,
|
||||
item=self.shirt,
|
||||
variation=self.shirt_blue,
|
||||
price=decimal.Decimal("0"),
|
||||
voucher=shirt_voucher
|
||||
)
|
||||
|
||||
shirt_voucher.redeemed = 2
|
||||
shirt_voucher.save()
|
||||
|
||||
Reference in New Issue
Block a user