Split up test and make the State classes a bit better.
This commit is contained in:
parent
028bbd15ca
commit
7d041b9394
|
@ -1,5 +1,6 @@
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.db.models.loading import BaseAppCache
|
from django.db.models.loading import BaseAppCache
|
||||||
|
from django.utils.module_loading import import_by_path
|
||||||
|
|
||||||
|
|
||||||
class ProjectState(object):
|
class ProjectState(object):
|
||||||
|
@ -15,12 +16,9 @@ class ProjectState(object):
|
||||||
|
|
||||||
def clone(self):
|
def clone(self):
|
||||||
"Returns an exact copy of this ProjectState"
|
"Returns an exact copy of this ProjectState"
|
||||||
ps = ProjectState(
|
return ProjectState(
|
||||||
models = dict((k, v.copy()) for k, v in self.models.items())
|
models = dict((k, v.copy()) for k, v in self.models.items())
|
||||||
)
|
)
|
||||||
for model in ps.models.values():
|
|
||||||
model.project_state = ps
|
|
||||||
return ps
|
|
||||||
|
|
||||||
def render(self):
|
def render(self):
|
||||||
"Turns the project state into actual models in a new AppCache"
|
"Turns the project state into actual models in a new AppCache"
|
||||||
|
@ -33,8 +31,11 @@ class ProjectState(object):
|
||||||
@classmethod
|
@classmethod
|
||||||
def from_app_cache(cls, app_cache):
|
def from_app_cache(cls, app_cache):
|
||||||
"Takes in an AppCache and returns a ProjectState matching it"
|
"Takes in an AppCache and returns a ProjectState matching it"
|
||||||
|
models = {}
|
||||||
for model in app_cache.get_models():
|
for model in app_cache.get_models():
|
||||||
print model
|
model_state = ModelState.from_model(model)
|
||||||
|
models[(model_state.app_label, model_state.name.lower())] = model_state
|
||||||
|
return cls(models)
|
||||||
|
|
||||||
|
|
||||||
class ModelState(object):
|
class ModelState(object):
|
||||||
|
@ -44,18 +45,36 @@ class ModelState(object):
|
||||||
mutate this one and then render it into a Model as required.
|
mutate this one and then render it into a Model as required.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, project_state, app_label, name, fields=None, options=None, bases=None):
|
def __init__(self, app_label, name, fields=None, options=None, bases=None):
|
||||||
self.project_state = project_state
|
|
||||||
self.app_label = app_label
|
self.app_label = app_label
|
||||||
self.name = name
|
self.name = name
|
||||||
self.fields = fields or []
|
self.fields = fields or []
|
||||||
self.options = options or {}
|
self.options = options or {}
|
||||||
self.bases = bases or None
|
self.bases = bases or (models.Model, )
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def from_model(cls, model):
|
||||||
|
"""
|
||||||
|
Feed me a model, get a ModelState representing it out.
|
||||||
|
"""
|
||||||
|
# Deconstruct the fields
|
||||||
|
fields = []
|
||||||
|
for field in model._meta.local_fields:
|
||||||
|
name, path, args, kwargs = field.deconstruct()
|
||||||
|
field_class = import_by_path(path)
|
||||||
|
fields.append((name, field_class(*args, **kwargs)))
|
||||||
|
# Make our record
|
||||||
|
return cls(
|
||||||
|
model._meta.app_label,
|
||||||
|
model._meta.object_name,
|
||||||
|
fields,
|
||||||
|
{},
|
||||||
|
None,
|
||||||
|
)
|
||||||
|
|
||||||
def clone(self):
|
def clone(self):
|
||||||
"Returns an exact copy of this ModelState"
|
"Returns an exact copy of this ModelState"
|
||||||
return self.__class__(
|
return self.__class__(
|
||||||
project_state = self.project_state,
|
|
||||||
app_label = self.app_label,
|
app_label = self.app_label,
|
||||||
name = self.name,
|
name = self.name,
|
||||||
fields = self.fields,
|
fields = self.fields,
|
||||||
|
|
|
@ -134,29 +134,3 @@ class LoaderTests(TransactionTestCase):
|
||||||
graph.forwards_plan(("migrations", "0002_second")),
|
graph.forwards_plan(("migrations", "0002_second")),
|
||||||
[("migrations", "0001_initial"), ("migrations", "0002_second")],
|
[("migrations", "0001_initial"), ("migrations", "0002_second")],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class RecorderTests(TestCase):
|
|
||||||
"""
|
|
||||||
Tests the disk and database loader.
|
|
||||||
"""
|
|
||||||
|
|
||||||
def test_apply(self):
|
|
||||||
"""
|
|
||||||
Tests marking migrations as applied/unapplied.
|
|
||||||
"""
|
|
||||||
recorder = MigrationRecorder(connection)
|
|
||||||
self.assertEqual(
|
|
||||||
recorder.applied_migrations(),
|
|
||||||
set(),
|
|
||||||
)
|
|
||||||
recorder.record_applied("myapp", "0432_ponies")
|
|
||||||
self.assertEqual(
|
|
||||||
recorder.applied_migrations(),
|
|
||||||
set([("myapp", "0432_ponies")]),
|
|
||||||
)
|
|
||||||
recorder.record_unapplied("myapp", "0432_ponies")
|
|
||||||
self.assertEqual(
|
|
||||||
recorder.applied_migrations(),
|
|
||||||
set(),
|
|
||||||
)
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
from django.test import TestCase
|
||||||
|
from django.db import connection
|
||||||
|
from django.db.migrations.recorder import MigrationRecorder
|
||||||
|
|
||||||
|
|
||||||
|
class RecorderTests(TestCase):
|
||||||
|
"""
|
||||||
|
Tests the disk and database loader.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test_apply(self):
|
||||||
|
"""
|
||||||
|
Tests marking migrations as applied/unapplied.
|
||||||
|
"""
|
||||||
|
recorder = MigrationRecorder(connection)
|
||||||
|
self.assertEqual(
|
||||||
|
recorder.applied_migrations(),
|
||||||
|
set(),
|
||||||
|
)
|
||||||
|
recorder.record_applied("myapp", "0432_ponies")
|
||||||
|
self.assertEqual(
|
||||||
|
recorder.applied_migrations(),
|
||||||
|
set([("myapp", "0432_ponies")]),
|
||||||
|
)
|
||||||
|
recorder.record_unapplied("myapp", "0432_ponies")
|
||||||
|
self.assertEqual(
|
||||||
|
recorder.applied_migrations(),
|
||||||
|
set(),
|
||||||
|
)
|
|
@ -0,0 +1,43 @@
|
||||||
|
from django.test import TestCase
|
||||||
|
from django.db import models
|
||||||
|
from django.db.models.loading import BaseAppCache
|
||||||
|
from django.db.migrations.state import ProjectState
|
||||||
|
|
||||||
|
|
||||||
|
class StateTests(TestCase):
|
||||||
|
"""
|
||||||
|
Tests state construction, rendering and modification by operations.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def test_create(self):
|
||||||
|
"""
|
||||||
|
Tests making a ProjectState from an AppCache
|
||||||
|
"""
|
||||||
|
new_app_cache = BaseAppCache()
|
||||||
|
|
||||||
|
class Author(models.Model):
|
||||||
|
name = models.CharField(max_length=255)
|
||||||
|
bio = models.TextField()
|
||||||
|
age = models.IntegerField(blank=True, null=True)
|
||||||
|
class Meta:
|
||||||
|
app_label = "migrations"
|
||||||
|
app_cache = new_app_cache
|
||||||
|
|
||||||
|
class Book(models.Model):
|
||||||
|
title = models.CharField(max_length=1000)
|
||||||
|
author = models.ForeignKey(Author)
|
||||||
|
class Meta:
|
||||||
|
app_label = "migrations"
|
||||||
|
app_cache = new_app_cache
|
||||||
|
|
||||||
|
project_state = ProjectState.from_app_cache(new_app_cache)
|
||||||
|
author_state = project_state.models['migrations', 'author']
|
||||||
|
book_state = project_state.models['migrations', 'book']
|
||||||
|
|
||||||
|
self.assertEqual(author_state.app_label, "migrations")
|
||||||
|
self.assertEqual(author_state.name, "Author")
|
||||||
|
self.assertEqual([x for x, y in author_state.fields], ["id", "name", "bio", "age"])
|
||||||
|
self.assertEqual(author_state.fields[1][1].max_length, 255)
|
||||||
|
self.assertEqual(author_state.fields[2][1].null, False)
|
||||||
|
self.assertEqual(author_state.fields[3][1].null, True)
|
||||||
|
self.assertEqual(author_state.bases, (models.Model, ))
|
Loading…
Reference in New Issue