summaryrefslogtreecommitdiff
path: root/tests/auth_tests/test_migrations.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auth_tests/test_migrations.py')
-rw-r--r--tests/auth_tests/test_migrations.py138
1 files changed, 82 insertions, 56 deletions
diff --git a/tests/auth_tests/test_migrations.py b/tests/auth_tests/test_migrations.py
index a91b9a9146..7fa0487029 100644
--- a/tests/auth_tests/test_migrations.py
+++ b/tests/auth_tests/test_migrations.py
@@ -9,14 +9,16 @@ from django.test.utils import captured_stdout
from .models import Proxy, UserProxy
-update_proxy_permissions = import_module('django.contrib.auth.migrations.0011_update_proxy_permissions')
+update_proxy_permissions = import_module(
+ "django.contrib.auth.migrations.0011_update_proxy_permissions"
+)
class ProxyModelWithDifferentAppLabelTests(TransactionTestCase):
available_apps = [
- 'auth_tests',
- 'django.contrib.auth',
- 'django.contrib.contenttypes',
+ "auth_tests",
+ "django.contrib.auth",
+ "django.contrib.contenttypes",
]
def setUp(self):
@@ -29,19 +31,25 @@ class ProxyModelWithDifferentAppLabelTests(TransactionTestCase):
self.concrete_content_type = ContentType.objects.get_for_model(UserProxy)
self.default_permission = Permission.objects.create(
content_type=self.concrete_content_type,
- codename='add_userproxy',
- name='Can add userproxy',
+ codename="add_userproxy",
+ name="Can add userproxy",
)
self.custom_permission = Permission.objects.create(
content_type=self.concrete_content_type,
- codename='use_different_app_label',
- name='May use a different app label',
+ codename="use_different_app_label",
+ name="May use a different app label",
)
def test_proxy_model_permissions_contenttype(self):
- proxy_model_content_type = ContentType.objects.get_for_model(UserProxy, for_concrete_model=False)
- self.assertEqual(self.default_permission.content_type, self.concrete_content_type)
- self.assertEqual(self.custom_permission.content_type, self.concrete_content_type)
+ proxy_model_content_type = ContentType.objects.get_for_model(
+ UserProxy, for_concrete_model=False
+ )
+ self.assertEqual(
+ self.default_permission.content_type, self.concrete_content_type
+ )
+ self.assertEqual(
+ self.custom_permission.content_type, self.concrete_content_type
+ )
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
self.default_permission.refresh_from_db()
@@ -54,47 +62,51 @@ class ProxyModelWithDifferentAppLabelTests(TransactionTestCase):
user.user_permissions.add(self.default_permission)
user.user_permissions.add(self.custom_permission)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth.' + permission.codename))
- self.assertFalse(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth." + permission.codename))
+ self.assertFalse(user.has_perm("auth_tests." + permission.codename))
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
# Reload user to purge the _perm_cache.
user = User._default_manager.get(pk=user.pk)
for permission in [self.default_permission, self.custom_permission]:
- self.assertFalse(user.has_perm('auth.' + permission.codename))
- self.assertTrue(user.has_perm('auth_tests.' + permission.codename))
+ self.assertFalse(user.has_perm("auth." + permission.codename))
+ self.assertTrue(user.has_perm("auth_tests." + permission.codename))
def test_migrate_backwards(self):
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
update_proxy_permissions.revert_proxy_model_permissions(apps, editor)
self.default_permission.refresh_from_db()
- self.assertEqual(self.default_permission.content_type, self.concrete_content_type)
+ self.assertEqual(
+ self.default_permission.content_type, self.concrete_content_type
+ )
self.custom_permission.refresh_from_db()
- self.assertEqual(self.custom_permission.content_type, self.concrete_content_type)
+ self.assertEqual(
+ self.custom_permission.content_type, self.concrete_content_type
+ )
def test_user_keeps_same_permissions_after_migrating_backward(self):
user = User.objects.create()
user.user_permissions.add(self.default_permission)
user.user_permissions.add(self.custom_permission)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth.' + permission.codename))
- self.assertFalse(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth." + permission.codename))
+ self.assertFalse(user.has_perm("auth_tests." + permission.codename))
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
update_proxy_permissions.revert_proxy_model_permissions(apps, editor)
# Reload user to purge the _perm_cache.
user = User._default_manager.get(pk=user.pk)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth.' + permission.codename))
- self.assertFalse(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth." + permission.codename))
+ self.assertFalse(user.has_perm("auth_tests." + permission.codename))
class ProxyModelWithSameAppLabelTests(TransactionTestCase):
available_apps = [
- 'auth_tests',
- 'django.contrib.auth',
- 'django.contrib.contenttypes',
+ "auth_tests",
+ "django.contrib.auth",
+ "django.contrib.contenttypes",
]
def setUp(self):
@@ -107,19 +119,25 @@ class ProxyModelWithSameAppLabelTests(TransactionTestCase):
self.concrete_content_type = ContentType.objects.get_for_model(Proxy)
self.default_permission = Permission.objects.create(
content_type=self.concrete_content_type,
- codename='add_proxy',
- name='Can add proxy',
+ codename="add_proxy",
+ name="Can add proxy",
)
self.custom_permission = Permission.objects.create(
content_type=self.concrete_content_type,
- codename='display_proxys',
- name='May display proxys information',
+ codename="display_proxys",
+ name="May display proxys information",
)
def test_proxy_model_permissions_contenttype(self):
- proxy_model_content_type = ContentType.objects.get_for_model(Proxy, for_concrete_model=False)
- self.assertEqual(self.default_permission.content_type, self.concrete_content_type)
- self.assertEqual(self.custom_permission.content_type, self.concrete_content_type)
+ proxy_model_content_type = ContentType.objects.get_for_model(
+ Proxy, for_concrete_model=False
+ )
+ self.assertEqual(
+ self.default_permission.content_type, self.concrete_content_type
+ )
+ self.assertEqual(
+ self.custom_permission.content_type, self.concrete_content_type
+ )
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
self.default_permission.refresh_from_db()
@@ -132,36 +150,40 @@ class ProxyModelWithSameAppLabelTests(TransactionTestCase):
user.user_permissions.add(self.default_permission)
user.user_permissions.add(self.custom_permission)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth_tests." + permission.codename))
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
# Reload user to purge the _perm_cache.
user = User._default_manager.get(pk=user.pk)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth_tests." + permission.codename))
def test_migrate_backwards(self):
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
update_proxy_permissions.revert_proxy_model_permissions(apps, editor)
self.default_permission.refresh_from_db()
- self.assertEqual(self.default_permission.content_type, self.concrete_content_type)
+ self.assertEqual(
+ self.default_permission.content_type, self.concrete_content_type
+ )
self.custom_permission.refresh_from_db()
- self.assertEqual(self.custom_permission.content_type, self.concrete_content_type)
+ self.assertEqual(
+ self.custom_permission.content_type, self.concrete_content_type
+ )
def test_user_keeps_same_permissions_after_migrating_backward(self):
user = User.objects.create()
user.user_permissions.add(self.default_permission)
user.user_permissions.add(self.custom_permission)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth_tests." + permission.codename))
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
update_proxy_permissions.revert_proxy_model_permissions(apps, editor)
# Reload user to purge the _perm_cache.
user = User._default_manager.get(pk=user.pk)
for permission in [self.default_permission, self.custom_permission]:
- self.assertTrue(user.has_perm('auth_tests.' + permission.codename))
+ self.assertTrue(user.has_perm("auth_tests." + permission.codename))
def test_migrate_with_existing_target_permission(self):
"""
@@ -172,48 +194,52 @@ class ProxyModelWithSameAppLabelTests(TransactionTestCase):
Output a reminder to audit relevant permissions.
"""
- proxy_model_content_type = ContentType.objects.get_for_model(Proxy, for_concrete_model=False)
+ proxy_model_content_type = ContentType.objects.get_for_model(
+ Proxy, for_concrete_model=False
+ )
Permission.objects.create(
content_type=proxy_model_content_type,
- codename='add_proxy',
- name='Can add proxy',
+ codename="add_proxy",
+ name="Can add proxy",
)
Permission.objects.create(
content_type=proxy_model_content_type,
- codename='display_proxys',
- name='May display proxys information',
+ codename="display_proxys",
+ name="May display proxys information",
)
with captured_stdout() as stdout:
with connection.schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
- self.assertIn('A problem arose migrating proxy model permissions', stdout.getvalue())
+ self.assertIn(
+ "A problem arose migrating proxy model permissions", stdout.getvalue()
+ )
class MultiDBProxyModelAppLabelTests(TransactionTestCase):
- databases = {'default', 'other'}
+ databases = {"default", "other"}
available_apps = [
- 'auth_tests',
- 'django.contrib.auth',
- 'django.contrib.contenttypes',
+ "auth_tests",
+ "django.contrib.auth",
+ "django.contrib.contenttypes",
]
def setUp(self):
ContentType.objects.all().delete()
- Permission.objects.using('other').delete()
- concrete_content_type = ContentType.objects.db_manager(
- 'other'
- ).get_for_model(Proxy)
- self.permission = Permission.objects.using('other').create(
+ Permission.objects.using("other").delete()
+ concrete_content_type = ContentType.objects.db_manager("other").get_for_model(
+ Proxy
+ )
+ self.permission = Permission.objects.using("other").create(
content_type=concrete_content_type,
- codename='add_proxy',
- name='Can add proxy',
+ codename="add_proxy",
+ name="Can add proxy",
)
def test_migrate_other_database(self):
proxy_model_content_type = ContentType.objects.db_manager(
- 'other'
+ "other"
).get_for_model(Proxy, for_concrete_model=False)
- with connections['other'].schema_editor() as editor:
+ with connections["other"].schema_editor() as editor:
update_proxy_permissions.update_proxy_model_permissions(apps, editor)
self.permission.refresh_from_db()
self.assertEqual(self.permission.content_type, proxy_model_content_type)