Added idempotent deploy support.
parent
aef2d56fba
commit
9b56343a81
|
|
@ -0,0 +1,20 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('admin_interface', '0013_add_related_modal_close_button'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AlterField(
|
||||
model_name='theme',
|
||||
name='name',
|
||||
field=models.CharField(default='Django', max_length=50, unique=True, verbose_name='name'),
|
||||
),
|
||||
]
|
||||
|
|
@ -3,7 +3,7 @@
|
|||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import models
|
||||
from django.db.models.signals import post_delete, post_save
|
||||
from django.db.models.signals import post_delete, post_save, pre_save
|
||||
from django.utils.encoding import python_2_unicode_compatible, force_text
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
|
||||
|
|
@ -27,6 +27,16 @@ class Theme(models.Model):
|
|||
Theme.objects.exclude(pk=instance.pk).update(active=False)
|
||||
Theme.get_active_theme()
|
||||
|
||||
@staticmethod
|
||||
def pre_save_handler(instance, **kwargs):
|
||||
if instance.pk is None:
|
||||
try:
|
||||
obj = Theme.objects.get(name=instance.name)
|
||||
if obj:
|
||||
instance.pk = obj.pk
|
||||
except Theme.DoesNotExist:
|
||||
pass
|
||||
|
||||
@staticmethod
|
||||
def get_active_theme():
|
||||
objs_manager = Theme.objects
|
||||
|
|
@ -51,6 +61,7 @@ class Theme(models.Model):
|
|||
return obj
|
||||
|
||||
name = models.CharField(
|
||||
unique=True,
|
||||
max_length=50,
|
||||
default='Django',
|
||||
verbose_name=_('name'))
|
||||
|
|
@ -275,3 +286,4 @@ class Theme(models.Model):
|
|||
|
||||
post_delete.connect(Theme.post_delete_handler, sender=Theme)
|
||||
post_save.connect(Theme.post_save_handler, sender=Theme)
|
||||
pre_save.connect(Theme.pre_save_handler, sender=Theme)
|
||||
|
|
|
|||
|
|
@ -0,0 +1,46 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
from django.core.management import call_command
|
||||
from django.test import TestCase
|
||||
|
||||
from admin_interface.models import Theme
|
||||
|
||||
|
||||
class AdminInterfaceFixturesTestCase(TestCase):
|
||||
|
||||
def setUp(self):
|
||||
pass
|
||||
|
||||
def tearDown(self):
|
||||
pass
|
||||
|
||||
def __load_theme(self, theme_name):
|
||||
call_command('loaddata', 'admin_interface_theme_%s.json' % (theme_name, ))
|
||||
|
||||
def test_import_all(self):
|
||||
self.__load_theme('django')
|
||||
self.__load_theme('bootstrap')
|
||||
self.__load_theme('foundation')
|
||||
self.__load_theme('uswds')
|
||||
self.assertEqual(Theme.objects.count(), 4);
|
||||
|
||||
def test_import_idempotency(self):
|
||||
self.__load_theme('django')
|
||||
self.__load_theme('django')
|
||||
self.__load_theme('django')
|
||||
self.__load_theme('django')
|
||||
self.__load_theme('django')
|
||||
self.assertEqual(Theme.objects.count(), 1);
|
||||
self.__load_theme('bootstrap')
|
||||
self.__load_theme('bootstrap')
|
||||
self.__load_theme('bootstrap')
|
||||
self.assertEqual(Theme.objects.count(), 2);
|
||||
|
||||
def test_import_override(self):
|
||||
obj1 = Theme.get_active_theme()
|
||||
obj1.title = 'Custom 1'
|
||||
obj1.save()
|
||||
self.__load_theme('django')
|
||||
obj2 = Theme.get_active_theme()
|
||||
self.assertEqual(obj1.pk, obj2.pk)
|
||||
self.assertTrue(obj1.title != obj2.title)
|
||||
Loading…
Reference in New Issue