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:
Raphael Michel
2019-06-17 10:46:55 +02:00
committed by GitHub
parent b1db5dbb3e
commit d85ddb5bda
130 changed files with 6253 additions and 4509 deletions

View File

@@ -1,5 +1,6 @@
import datetime
from django_scopes import scopes_disabled
from tests.base import SoupTest, extract_form_fields
from pretix.base.models import Event, Item, Organizer, Team, User
@@ -7,6 +8,7 @@ from pretix.plugins.ticketoutputpdf.models import TicketLayoutItem
class TicketLayoutFormTest(SoupTest):
@scopes_disabled()
def setUp(self):
super().setUp()
self.user = User.objects.create_user('dummy@dummy.dummy', 'dummy')
@@ -31,13 +33,15 @@ class TicketLayoutFormTest(SoupTest):
doc = self.post_doc('/control/event/%s/%s/pdfoutput/add' % (self.orga1.slug, self.event1.slug), form_data)
assert doc.select(".alert-success")
self.assertIn("Layout 1", doc.select("#page-wrapper")[0].text)
assert self.event1.ticket_layouts.get(
default=True, name='Layout 1'
)
with scopes_disabled():
assert self.event1.ticket_layouts.get(
default=True, name='Layout 1'
)
def test_set_default(self):
bl1 = self.event1.ticket_layouts.create(name="Layout 1", default=True)
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
with scopes_disabled():
bl1 = self.event1.ticket_layouts.create(name="Layout 1", default=True)
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
self.post_doc('/control/event/%s/%s/pdfoutput/%s/default' % (self.orga1.slug, self.event1.slug, bl2.id), {})
bl1.refresh_from_db()
assert not bl1.default
@@ -45,21 +49,24 @@ class TicketLayoutFormTest(SoupTest):
assert bl2.default
def test_delete(self):
bl1 = self.event1.ticket_layouts.create(name="Layout 1", default=True)
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
with scopes_disabled():
bl1 = self.event1.ticket_layouts.create(name="Layout 1", default=True)
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
doc = self.get_doc('/control/event/%s/%s/pdfoutput/%s/delete' % (self.orga1.slug, self.event1.slug, bl1.id))
form_data = extract_form_fields(doc.select('.container-fluid form')[0])
doc = self.post_doc('/control/event/%s/%s/pdfoutput/%s/delete' % (self.orga1.slug, self.event1.slug, bl1.id),
form_data)
assert doc.select(".alert-success")
self.assertNotIn("Layout 1", doc.select("#page-wrapper")[0].text)
assert self.event1.ticket_layouts.count() == 1
with scopes_disabled():
assert self.event1.ticket_layouts.count() == 1
bl2.refresh_from_db()
assert bl2.default
def test_set_on_item(self):
self.event1.ticket_layouts.create(name="Layout 1", default=True)
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
with scopes_disabled():
self.event1.ticket_layouts.create(name="Layout 1", default=True)
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
self.client.post('/control/event/%s/%s/items/%d/' % (self.orga1.slug, self.event1.slug, self.item1.id), {
'name_0': 'Standard',
'default_price': '23.00',
@@ -69,7 +76,8 @@ class TicketLayoutFormTest(SoupTest):
'ticketlayoutitem_web-layout': bl2.pk,
'sales_channels': 'web',
})
assert TicketLayoutItem.objects.get(item=self.item1, layout=bl2)
with scopes_disabled():
assert TicketLayoutItem.objects.get(item=self.item1, layout=bl2)
self.client.post('/control/event/%s/%s/items/%d/' % (self.orga1.slug, self.event1.slug, self.item1.id), {
'name_0': 'Standard',
'default_price': '23.00',
@@ -78,11 +86,13 @@ class TicketLayoutFormTest(SoupTest):
'allow_cancel': 'yes',
'sales_channels': 'web',
})
assert not TicketLayoutItem.objects.filter(item=self.item1, layout=bl2).exists()
with scopes_disabled():
assert not TicketLayoutItem.objects.filter(item=self.item1, layout=bl2).exists()
def test_item_copy(self):
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
TicketLayoutItem.objects.create(item=self.item1, layout=bl2)
with scopes_disabled():
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
TicketLayoutItem.objects.create(item=self.item1, layout=bl2)
self.client.post('/control/event/%s/%s/items/add' % (self.orga1.slug, self.event1.slug), {
'name_0': 'Intermediate',
'default_price': '23.00',
@@ -90,13 +100,15 @@ class TicketLayoutFormTest(SoupTest):
'copy_from': str(self.item1.pk),
'has_variations': '1'
})
i_new = Item.objects.get(name__icontains='Intermediate')
assert TicketLayoutItem.objects.get(item=i_new, layout=bl2)
assert TicketLayoutItem.objects.get(item=self.item1, layout=bl2)
with scopes_disabled():
i_new = Item.objects.get(name__icontains='Intermediate')
assert TicketLayoutItem.objects.get(item=i_new, layout=bl2)
assert TicketLayoutItem.objects.get(item=self.item1, layout=bl2)
def test_copy_event(self):
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
TicketLayoutItem.objects.create(item=self.item1, layout=bl2)
with scopes_disabled():
bl2 = self.event1.ticket_layouts.create(name="Layout 2")
TicketLayoutItem.objects.create(item=self.item1, layout=bl2)
self.post_doc('/control/events/add', {
'event_wizard-current_step': 'foundation',
'event_wizard-prefix': 'event_wizard',
@@ -124,7 +136,8 @@ class TicketLayoutFormTest(SoupTest):
'copy-copy_from_event': self.event1.pk
})
ev = Event.objects.get(slug='33c3')
i_new = ev.items.first()
bl_new = ev.ticket_layouts.first()
assert TicketLayoutItem.objects.get(item=i_new, layout=bl_new)
with scopes_disabled():
ev = Event.objects.get(slug='33c3')
i_new = ev.items.first()
bl_new = ev.ticket_layouts.first()
assert TicketLayoutItem.objects.get(item=i_new, layout=bl_new)

View File

@@ -4,6 +4,7 @@ from io import BytesIO
import pytest
from django.utils.timezone import now
from django_scopes import scope
from PyPDF2 import PdfFileReader
from pretix.base.models import (
@@ -41,11 +42,12 @@ def env0():
@pytest.mark.django_db
def test_generate_pdf(env0):
event, order = env0
event.settings.set('ticketoutput_pdf_code_x', 30)
event.settings.set('ticketoutput_pdf_code_y', 50)
event.settings.set('ticketoutput_pdf_code_s', 2)
o = PdfTicketOutput(event)
fname, ftype, buf = o.generate(order.positions.first())
assert ftype == 'application/pdf'
pdf = PdfFileReader(BytesIO(buf))
assert pdf.numPages == 1
with scope(organizer=event.organizer):
event.settings.set('ticketoutput_pdf_code_x', 30)
event.settings.set('ticketoutput_pdf_code_y', 50)
event.settings.set('ticketoutput_pdf_code_s', 2)
o = PdfTicketOutput(event)
fname, ftype, buf = o.generate(order.positions.first())
assert ftype == 'application/pdf'
pdf = PdfFileReader(BytesIO(buf))
assert pdf.numPages == 1