From 966849ba373c14b12effbda624a4982d9813e434 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rapha=C3=ABl=20Barrois?= Date: Tue, 22 May 2012 15:59:09 +0200 Subject: [PATCH] Add introspection rules for south MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Raphaƫl Barrois --- src/semantic_version/django_fields.py | 21 +++++++++++ tests/test_django.py | 51 +++++++++++++++++++++++++++ 2 files changed, 72 insertions(+) diff --git a/src/semantic_version/django_fields.py b/src/semantic_version/django_fields.py index c6ef688..0e1b083 100644 --- a/src/semantic_version/django_fields.py +++ b/src/semantic_version/django_fields.py @@ -59,3 +59,24 @@ class SpecField(BaseSemVerField): if isinstance(value, base.Spec): return value return base.Spec(value) + + +def add_south_rules(): + from south.modelsinspector import add_introspection_rules + + add_introspection_rules([ + ( + (VersionField,), + [], + {'partial': ('partial', {'default': False})}, + ), + ], ["semantic_version\.django_fields"]) + + +try: # pragma: no cover + import south +except ImportError: # pragma: no cover + south = None + +if south: # pragma: no cover + add_south_rules() diff --git a/tests/test_django.py b/tests/test_django.py index b4a3c29..52d419c 100644 --- a/tests/test_django.py +++ b/tests/test_django.py @@ -31,6 +31,13 @@ if django_loaded: # pragma: no cover from django_test_app import models from django.core import serializers +try: # pragma: no cover + import south + import south.creator.freezer + import south.modelsinspector +except ImportError: # pragma: no cover + south = None + @unittest.skipIf(not django_loaded, "Django not installed") class DjangoFieldTestCase(unittest.TestCase): @@ -98,6 +105,50 @@ class DjangoFieldTestCase(unittest.TestCase): self.assertEqual(o2, obj2.object) +@unittest.skipIf(not django_loaded or south is None, "Couldn't import south and django") +class SouthTestCase(unittest.TestCase): + def test_freezing_version_model(self): + frozen = south.modelsinspector.get_model_fields(models.VersionModel) + + self.assertEqual(frozen['version'], + ('semantic_version.django_fields.VersionField', [], {'max_length': '200'})) + + self.assertEqual(frozen['spec'], + ('semantic_version.django_fields.SpecField', [], {'max_length': '200'})) + + def test_freezing_partial_version_model(self): + frozen = south.modelsinspector.get_model_fields(models.PartialVersionModel) + + self.assertEqual(frozen['partial'], + ('semantic_version.django_fields.VersionField', [], {'max_length': '200', 'partial': 'True'})) + + self.assertEqual(frozen['optional'], + ('semantic_version.django_fields.VersionField', [], {'max_length': '200', 'blank': 'True', 'null': 'True'})) + + self.assertEqual(frozen['optional_spec'], + ('semantic_version.django_fields.SpecField', [], {'max_length': '200', 'blank': 'True', 'null': 'True'})) + + def test_freezing_app(self): + frozen = south.creator.freezer.freeze_apps('django_test_app') + + # Test VersionModel + self.assertEqual(frozen['django_test_app.versionmodel']['version'], + ('semantic_version.django_fields.VersionField', [], {'max_length': '200'})) + + self.assertEqual(frozen['django_test_app.versionmodel']['spec'], + ('semantic_version.django_fields.SpecField', [], {'max_length': '200'})) + + # Test PartialVersionModel + self.assertEqual(frozen['django_test_app.partialversionmodel']['partial'], + ('semantic_version.django_fields.VersionField', [], {'max_length': '200', 'partial': 'True'})) + + self.assertEqual(frozen['django_test_app.partialversionmodel']['optional'], + ('semantic_version.django_fields.VersionField', [], {'max_length': '200', 'blank': 'True', 'null': 'True'})) + + self.assertEqual(frozen['django_test_app.partialversionmodel']['optional_spec'], + ('semantic_version.django_fields.SpecField', [], {'max_length': '200', 'blank': 'True', 'null': 'True'})) + + if django_loaded: from django.test import TestCase from django.test.simple import DjangoTestSuiteRunner