mirror of
https://github.com/pretix/pretix.git
synced 2026-05-04 15:04:03 +00:00
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:
@@ -1,5 +1,6 @@
|
||||
import pytest
|
||||
from django.utils.timezone import now
|
||||
from django_scopes import scopes_disabled
|
||||
|
||||
from pretix.api.models import WebHook
|
||||
from pretix.base.models import Event, Organizer, Team, User
|
||||
@@ -48,7 +49,7 @@ def admin_team(organizer):
|
||||
def test_list_of_webhooks(event, admin_user, client, webhook):
|
||||
client.login(email='dummy@dummy.dummy', password='dummy')
|
||||
resp = client.get('/control/organizer/dummy/webhooks')
|
||||
assert 'https://google.com' in resp.rendered_content
|
||||
assert 'https://google.com' in resp.content.decode()
|
||||
|
||||
|
||||
@pytest.mark.django_db
|
||||
@@ -60,11 +61,12 @@ def test_create_webhook(event, admin_user, admin_team, client):
|
||||
'events': 'pretix.event.order.paid',
|
||||
'limit_events': str(event.pk),
|
||||
}, follow=True)
|
||||
w = WebHook.objects.last()
|
||||
assert w.target_url == "https://google.com"
|
||||
assert w.limit_events.count() == 1
|
||||
assert list(w.listeners.values_list('action_type', flat=True)) == ['pretix.event.order.paid']
|
||||
assert not w.all_events
|
||||
with scopes_disabled():
|
||||
w = WebHook.objects.last()
|
||||
assert w.target_url == "https://google.com"
|
||||
assert w.limit_events.count() == 1
|
||||
assert list(w.listeners.values_list('action_type', flat=True)) == ['pretix.event.order.paid']
|
||||
assert not w.all_events
|
||||
|
||||
|
||||
@pytest.mark.django_db
|
||||
@@ -78,10 +80,11 @@ def test_update_webhook(event, admin_user, admin_team, webhook, client):
|
||||
}, follow=True)
|
||||
webhook.refresh_from_db()
|
||||
assert webhook.target_url == "https://google.com"
|
||||
assert webhook.limit_events.count() == 1
|
||||
assert list(webhook.listeners.values_list('action_type', flat=True)) == ['pretix.event.order.canceled',
|
||||
'pretix.event.order.paid']
|
||||
assert not webhook.all_events
|
||||
with scopes_disabled():
|
||||
assert webhook.limit_events.count() == 1
|
||||
assert list(webhook.listeners.values_list('action_type', flat=True)) == ['pretix.event.order.canceled',
|
||||
'pretix.event.order.paid']
|
||||
assert not webhook.all_events
|
||||
|
||||
|
||||
@pytest.mark.django_db
|
||||
@@ -98,4 +101,4 @@ def test_webhook_logs(event, admin_user, admin_team, webhook, client):
|
||||
response_body='bar'
|
||||
)
|
||||
resp = client.get('/control/organizer/dummy/webhook/{}/logs'.format(webhook.pk))
|
||||
assert 'pretix.event.order.paid' in resp.rendered_content
|
||||
assert 'pretix.event.order.paid' in resp.content.decode()
|
||||
|
||||
Reference in New Issue
Block a user