From 70e3e2e08ee1d07343d48b1db9df838db3efb0e2 Mon Sep 17 00:00:00 2001 From: Piotr Jakimiak Date: Thu, 14 May 2015 19:59:36 +0200 Subject: [PATCH] Fixed #24774 -- Made contrib.site's Site.domain field unique --- AUTHORS | 1 + .../migrations/0002_alter_domain_unique.py | 20 +++++++++++++++++++ django/contrib/sites/models.py | 2 +- docs/ref/contrib/sites.txt | 5 +++++ docs/releases/1.9.txt | 3 +++ tests/sites_tests/tests.py | 6 ++++++ 6 files changed, 36 insertions(+), 1 deletion(-) create mode 100644 django/contrib/sites/migrations/0002_alter_domain_unique.py diff --git a/AUTHORS b/AUTHORS index f6f32a0db3f..4fdfda9a940 100644 --- a/AUTHORS +++ b/AUTHORS @@ -565,6 +565,7 @@ answer newbie questions, and generally made Django that much better: Philip Lindborg Philippe Raoult phil@produxion.net + Piotr Jakimiak Piotr Lewandowski plisk polpak@yahoo.com diff --git a/django/contrib/sites/migrations/0002_alter_domain_unique.py b/django/contrib/sites/migrations/0002_alter_domain_unique.py new file mode 100644 index 00000000000..e7f414fb5c0 --- /dev/null +++ b/django/contrib/sites/migrations/0002_alter_domain_unique.py @@ -0,0 +1,20 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +import django.contrib.sites.models +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('sites', '0001_initial'), + ] + + operations = [ + migrations.AlterField( + model_name='site', + name='domain', + field=models.CharField(max_length=100, unique=True, validators=[django.contrib.sites.models._simple_domain_name_validator], verbose_name='domain name'), + ), + ] diff --git a/django/contrib/sites/models.py b/django/contrib/sites/models.py index d7026d03559..6471dca136a 100644 --- a/django/contrib/sites/models.py +++ b/django/contrib/sites/models.py @@ -73,7 +73,7 @@ class SiteManager(models.Manager): class Site(models.Model): domain = models.CharField(_('domain name'), max_length=100, - validators=[_simple_domain_name_validator]) + validators=[_simple_domain_name_validator], unique=True) name = models.CharField(_('display name'), max_length=50) objects = SiteManager() diff --git a/docs/ref/contrib/sites.txt b/docs/ref/contrib/sites.txt index 8c71ca05726..4928c921196 100644 --- a/docs/ref/contrib/sites.txt +++ b/docs/ref/contrib/sites.txt @@ -23,6 +23,11 @@ The sites framework is mainly based on a simple model: The domain name associated with the Web site. + .. versionchanged:: 1.9 + + The ``domain`` field was set to be + :attr:`~django.db.models.Field.unique`. + .. attribute:: name A human-readable "verbose" name for the Web site. diff --git a/docs/releases/1.9.txt b/docs/releases/1.9.txt index 473e64f95dd..c2ceb5f5db2 100644 --- a/docs/releases/1.9.txt +++ b/docs/releases/1.9.txt @@ -447,6 +447,9 @@ Miscellaneous * Support for PostGIS 1.5 has been dropped. +* The ``django.contrib.sites.models.Site.domain`` field was changed to be + :attr:`~django.db.models.Field.unique`. + .. _deprecated-features-1.9: Features deprecated in 1.9 diff --git a/tests/sites_tests/tests.py b/tests/sites_tests/tests.py index 128420a17b0..563ee6a6811 100644 --- a/tests/sites_tests/tests.py +++ b/tests/sites_tests/tests.py @@ -135,6 +135,12 @@ class SitesFrameworkTests(TestCase): clear_site_cache(Site, instance=site, using='default') self.assertEqual(models.SITE_CACHE, {}) + def test_unique_domain(self): + site = Site(domain=self.site.domain) + msg = 'Site with this Domain name already exists.' + with self.assertRaisesMessage(ValidationError, msg): + site.validate_unique() + class JustOtherRouter(object): def allow_migrate(self, db, app_label, **hints):