summaryrefslogtreecommitdiff
path: root/tests/sites_framework
diff options
context:
space:
mode:
authorFlorian Apolloner <florian@apolloner.eu>2013-02-26 09:53:47 +0100
committerFlorian Apolloner <florian@apolloner.eu>2013-02-26 14:36:57 +0100
commit89f40e36246100df6a11316c31a76712ebc6c501 (patch)
tree6e65639683ddaf2027908d1ecb1739e0e2ff853b /tests/sites_framework
parentb3d2ccb5bfbaf6e7fe1f98843baaa48c35a70950 (diff)
downloaddjango-89f40e36246100df6a11316c31a76712ebc6c501.tar.gz
Merged regressiontests and modeltests into the test root.
Diffstat (limited to 'tests/sites_framework')
-rw-r--r--tests/sites_framework/__init__.py0
-rw-r--r--tests/sites_framework/models.py38
-rw-r--r--tests/sites_framework/tests.py38
3 files changed, 76 insertions, 0 deletions
diff --git a/tests/sites_framework/__init__.py b/tests/sites_framework/__init__.py
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/tests/sites_framework/__init__.py
diff --git a/tests/sites_framework/models.py b/tests/sites_framework/models.py
new file mode 100644
index 0000000000..55c4f4992e
--- /dev/null
+++ b/tests/sites_framework/models.py
@@ -0,0 +1,38 @@
+from django.contrib.sites.managers import CurrentSiteManager
+from django.contrib.sites.models import Site
+from django.db import models
+from django.utils.encoding import python_2_unicode_compatible
+
+@python_2_unicode_compatible
+class AbstractArticle(models.Model):
+ title = models.CharField(max_length=50)
+
+ objects = models.Manager()
+ on_site = CurrentSiteManager()
+
+ class Meta:
+ abstract = True
+
+ def __str__(self):
+ return self.title
+
+class SyndicatedArticle(AbstractArticle):
+ sites = models.ManyToManyField(Site)
+
+class ExclusiveArticle(AbstractArticle):
+ site = models.ForeignKey(Site)
+
+class CustomArticle(AbstractArticle):
+ places_this_article_should_appear = models.ForeignKey(Site)
+
+ objects = models.Manager()
+ on_site = CurrentSiteManager("places_this_article_should_appear")
+
+class InvalidArticle(AbstractArticle):
+ site = models.ForeignKey(Site)
+
+ objects = models.Manager()
+ on_site = CurrentSiteManager("places_this_article_should_appear")
+
+class ConfusedArticle(AbstractArticle):
+ site = models.IntegerField()
diff --git a/tests/sites_framework/tests.py b/tests/sites_framework/tests.py
new file mode 100644
index 0000000000..8e664fd501
--- /dev/null
+++ b/tests/sites_framework/tests.py
@@ -0,0 +1,38 @@
+from __future__ import absolute_import
+
+from django.conf import settings
+from django.contrib.sites.models import Site
+from django.test import TestCase
+
+from .models import (SyndicatedArticle, ExclusiveArticle, CustomArticle,
+ InvalidArticle, ConfusedArticle)
+
+
+class SitesFrameworkTestCase(TestCase):
+ def setUp(self):
+ Site.objects.get_or_create(id=settings.SITE_ID, domain="example.com", name="example.com")
+ Site.objects.create(id=settings.SITE_ID+1, domain="example2.com", name="example2.com")
+
+ def test_site_fk(self):
+ article = ExclusiveArticle.objects.create(title="Breaking News!", site_id=settings.SITE_ID)
+ self.assertEqual(ExclusiveArticle.on_site.all().get(), article)
+
+ def test_sites_m2m(self):
+ article = SyndicatedArticle.objects.create(title="Fresh News!")
+ article.sites.add(Site.objects.get(id=settings.SITE_ID))
+ article.sites.add(Site.objects.get(id=settings.SITE_ID+1))
+ article2 = SyndicatedArticle.objects.create(title="More News!")
+ article2.sites.add(Site.objects.get(id=settings.SITE_ID+1))
+ self.assertEqual(SyndicatedArticle.on_site.all().get(), article)
+
+ def test_custom_named_field(self):
+ article = CustomArticle.objects.create(title="Tantalizing News!", places_this_article_should_appear_id=settings.SITE_ID)
+ self.assertEqual(CustomArticle.on_site.all().get(), article)
+
+ def test_invalid_name(self):
+ article = InvalidArticle.objects.create(title="Bad News!", site_id=settings.SITE_ID)
+ self.assertRaises(ValueError, InvalidArticle.on_site.all)
+
+ def test_invalid_field_type(self):
+ article = ConfusedArticle.objects.create(title="More Bad News!", site=settings.SITE_ID)
+ self.assertRaises(TypeError, ConfusedArticle.on_site.all)