1
0
mirror of https://github.com/django/django.git synced 2025-10-25 06:36:07 +00:00

[1.7.x] Fixed #23405 -- Fixed makemigrations prompt when adding Text/CharField.

A default is no longer required.

Backport of d8f3b86a76 from master
This commit is contained in:
Andriy Sokolovskiy
2014-12-06 22:43:19 +02:00
committed by Tim Graham
parent 4cc646bb56
commit fdf4dc6cea
3 changed files with 59 additions and 2 deletions

View File

@@ -54,6 +54,16 @@ class AutodetectorTests(TestCase):
("name", models.CharField(max_length=200, default=DeconstructableObject())),
])
author_custom_pk = ModelState("testapp", "Author", [("pk_field", models.IntegerField(primary_key=True))])
author_with_biography_non_blank = ModelState("testapp", "Author", [
("id", models.AutoField(primary_key=True)),
("name", models.CharField()),
("biography", models.TextField()),
])
author_with_biography_blank = ModelState("testapp", "Author", [
("id", models.AutoField(primary_key=True)),
("name", models.CharField(blank=True)),
("biography", models.TextField(blank=True)),
])
author_with_book = ModelState("testapp", "Author", [
("id", models.AutoField(primary_key=True)),
("name", models.CharField(max_length=200)),
@@ -1641,3 +1651,44 @@ class AutodetectorTests(TestCase):
self.assertNumberMigrations(changes, 'a', 1)
self.assertOperationTypes(changes, 'a', 0, ["CreateModel"])
self.assertMigrationDependencies(changes, 'a', 0, [])
def test_add_blank_textfield_and_charfield(self):
"""
#23405 - Adding a NOT NULL and blank `CharField` or `TextField`
without default should not prompt for a default.
"""
class CustomQuestioner(MigrationQuestioner):
def ask_not_null_addition(self, field_name, model_name):
raise Exception("Should not have prompted for not null addition")
before = self.make_project_state([self.author_empty])
after = self.make_project_state([self.author_with_biography_blank])
autodetector = MigrationAutodetector(before, after, CustomQuestioner())
changes = autodetector._detect_changes()
self.assertNumberMigrations(changes, 'testapp', 1)
self.assertOperationTypes(changes, 'testapp', 0, ["AddField", "AddField"])
self.assertOperationAttributes(changes, 'testapp', 0, 0)
def test_add_non_blank_textfield_and_charfield(self):
"""
#23405 - Adding a NOT NULL and non-blank `CharField` or `TextField`
without default should prompt for a default.
"""
class CustomQuestioner(MigrationQuestioner):
def __init__(self):
super(CustomQuestioner, self).__init__()
self.ask_method_call_count = 0
def ask_not_null_addition(self, field_name, model_name):
self.ask_method_call_count += 1
before = self.make_project_state([self.author_empty])
after = self.make_project_state([self.author_with_biography_non_blank])
questioner_instance = CustomQuestioner()
autodetector = MigrationAutodetector(before, after, questioner_instance)
changes = autodetector._detect_changes()
# need to check for questioner call count
self.assertEqual(questioner_instance.ask_method_call_count, 2)
self.assertNumberMigrations(changes, 'testapp', 1)
self.assertOperationTypes(changes, 'testapp', 0, ["AddField", "AddField"])
self.assertOperationAttributes(changes, 'testapp', 0, 0)