From d36b54d753a1fb79f32f6b7a91d582bccb7ab311 Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Mon, 16 Jun 2014 15:59:24 -0400 Subject: [PATCH] [1.7.x] Added database migration for contrib.auth. refs #22170. Backport of b341f33697 from master --- .../contrib/auth/migrations/0001_initial.py | 66 +++++++++++++++++++ django/contrib/auth/migrations/__init__.py | 0 tests/migrations/test_loader.py | 6 +- tests/runtests.py | 5 +- tests/urlpatterns_reverse/tests.py | 2 +- 5 files changed, 75 insertions(+), 4 deletions(-) create mode 100644 django/contrib/auth/migrations/0001_initial.py create mode 100644 django/contrib/auth/migrations/__init__.py diff --git a/django/contrib/auth/migrations/0001_initial.py b/django/contrib/auth/migrations/0001_initial.py new file mode 100644 index 0000000000..de38c960fb --- /dev/null +++ b/django/contrib/auth/migrations/0001_initial.py @@ -0,0 +1,66 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +from django.core import validators +from django.db import models, migrations +from django.utils import timezone + + +class Migration(migrations.Migration): + + dependencies = [ + ('contenttypes', '__first__'), + ] + + operations = [ + migrations.CreateModel( + name='Permission', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('name', models.CharField(max_length=50, verbose_name='name')), + ('content_type', models.ForeignKey(to='contenttypes.ContentType', to_field='id')), + ('codename', models.CharField(max_length=100, verbose_name='codename')), + ], + options={ + 'ordering': ('content_type__app_label', 'content_type__model', 'codename'), + 'unique_together': set([('content_type', 'codename')]), + 'verbose_name': 'permission', + 'verbose_name_plural': 'permissions', + }, + ), + migrations.CreateModel( + name='Group', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('name', models.CharField(unique=True, max_length=80, verbose_name='name')), + ('permissions', models.ManyToManyField(to='auth.Permission', verbose_name='permissions', blank=True)), + ], + options={ + 'verbose_name': 'group', + 'verbose_name_plural': 'groups', + }, + ), + migrations.CreateModel( + name='User', + fields=[ + ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)), + ('password', models.CharField(max_length=128, verbose_name='password')), + ('last_login', models.DateTimeField(default=timezone.now, verbose_name='last login')), + ('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')), + ('username', models.CharField(help_text='Required. 30 characters or fewer. Letters, digits and @/./+/-/_ only.', unique=True, max_length=30, verbose_name='username', validators=[validators.RegexValidator('^[\\w.@+-]+$', 'Enter a valid username.', 'invalid')])), + ('first_name', models.CharField(max_length=30, verbose_name='first name', blank=True)), + ('last_name', models.CharField(max_length=30, verbose_name='last name', blank=True)), + ('email', models.EmailField(max_length=75, verbose_name='email address', blank=True)), + ('is_staff', models.BooleanField(default=False, help_text='Designates whether the user can log into this admin site.', verbose_name='staff status')), + ('is_active', models.BooleanField(default=True, help_text='Designates whether this user should be treated as active. Unselect this instead of deleting accounts.', verbose_name='active')), + ('date_joined', models.DateTimeField(default=timezone.now, verbose_name='date joined')), + ('groups', models.ManyToManyField(to='auth.Group', verbose_name='groups', blank=True)), + ('user_permissions', models.ManyToManyField(to='auth.Permission', verbose_name='user permissions', blank=True)), + ], + options={ + 'swappable': 'AUTH_USER_MODEL', + 'verbose_name': 'user', + 'verbose_name_plural': 'users', + }, + ), + ] diff --git a/django/contrib/auth/migrations/__init__.py b/django/contrib/auth/migrations/__init__.py new file mode 100644 index 0000000000..e69de29bb2 diff --git a/tests/migrations/test_loader.py b/tests/migrations/test_loader.py index e03873a1ea..78cde79a31 100644 --- a/tests/migrations/test_loader.py +++ b/tests/migrations/test_loader.py @@ -4,6 +4,7 @@ from django.test import TestCase, override_settings from django.db import connection, connections from django.db.migrations.loader import MigrationLoader, AmbiguityError from django.db.migrations.recorder import MigrationRecorder +from django.test import modify_settings from django.utils import six @@ -46,6 +47,7 @@ class LoaderTests(TestCase): """ @override_settings(MIGRATION_MODULES={"migrations": "migrations.test_migrations"}) + @modify_settings(INSTALLED_APPS={'append': 'basic'}) def test_load(self): """ Makes sure the loader can load the migrations for the test apps, @@ -77,7 +79,7 @@ class LoaderTests(TestCase): ) # Ensure we've included unmigrated apps in there too - self.assertIn("auth", project_state.real_apps) + self.assertIn("basic", project_state.real_apps) @override_settings(MIGRATION_MODULES={"migrations": "migrations.test_migrations_unmigdep"}) def test_load_unmigrated_dependency(self): @@ -89,6 +91,8 @@ class LoaderTests(TestCase): self.assertEqual( migration_loader.graph.forwards_plan(("migrations", "0001_initial")), [ + ('contenttypes', u'0001_initial'), + ('auth', u'0001_initial'), ("migrations", "0001_initial"), ], ) diff --git a/tests/runtests.py b/tests/runtests.py index c1772ca69b..87b7c3ea65 100755 --- a/tests/runtests.py +++ b/tests/runtests.py @@ -130,8 +130,9 @@ def setup(verbosity, test_labels): # Ensure the middleware classes are seen as overridden otherwise we get a compatibility warning. settings._explicit_settings.add('MIDDLEWARE_CLASSES') settings.MIGRATION_MODULES = { - # this module doesn't actually exist, but this lets us skip creating - # migrations for the test modules for some reason. + # these 'tests.migrations' modules don't actually exist, but this lets + # us skip creating migrations for the test models. + 'auth': 'django.contrib.auth.tests.migrations', 'contenttypes': 'django.contrib.contenttypes.tests.migrations', } diff --git a/tests/urlpatterns_reverse/tests.py b/tests/urlpatterns_reverse/tests.py index 512f551a1d..6d197534e4 100644 --- a/tests/urlpatterns_reverse/tests.py +++ b/tests/urlpatterns_reverse/tests.py @@ -322,7 +322,7 @@ LOGIN_URL = reverse_lazy('login')""") self.remove_settings('settings.py') def test_lazy_in_settings(self): - out, err = self.run_manage(['sqlall', 'auth']) + out, err = self.run_manage(['validate']) self.assertNoOutput(err)