summaryrefslogtreecommitdiff
path: root/tests/sitemaps_tests/test_http.py
diff options
context:
space:
mode:
authorTim Graham <timograham@gmail.com>2015-02-10 08:11:25 -0500
committerTim Graham <timograham@gmail.com>2015-02-11 10:19:22 -0500
commitfbc467c26bc0adb9867b97d0bb5642b2a85eb357 (patch)
treec8185ba55a2790f0a9ce16cd2d2c30938b05f312 /tests/sitemaps_tests/test_http.py
parentd8341bf02444e58ff62afe04f15d9679a1b5b8f8 (diff)
Moved contrib.sitemaps tests out of contrib.
Diffstat (limited to 'tests/sitemaps_tests/test_http.py')
-rw-r--r--tests/sitemaps_tests/test_http.py224
1 files changed, 224 insertions, 0 deletions
diff --git a/tests/sitemaps_tests/test_http.py b/tests/sitemaps_tests/test_http.py
new file mode 100644
index 0000000000..2817f844d6
--- /dev/null
+++ b/tests/sitemaps_tests/test_http.py
@@ -0,0 +1,224 @@
+from __future__ import unicode_literals
+
+import os
+from datetime import date
+from unittest import skipUnless
+
+from django.apps import apps
+from django.conf import settings
+from django.contrib.sitemaps import GenericSitemap, Sitemap
+from django.contrib.sites.models import Site
+from django.core.exceptions import ImproperlyConfigured
+from django.test import ignore_warnings, modify_settings, override_settings
+from django.utils._os import upath
+from django.utils.deprecation import RemovedInDjango20Warning
+from django.utils.formats import localize
+from django.utils.translation import activate, deactivate
+
+from .base import SitemapTestsBase
+from .models import TestModel
+
+
+class HTTPSitemapTests(SitemapTestsBase):
+
+ @ignore_warnings(category=RemovedInDjango20Warning)
+ def test_simple_sitemap_index(self):
+ "A simple sitemap index can be rendered"
+ # The URL for views.sitemap in tests/urls/http.py has been updated
+ # with a name but since reversing by Python path is tried first
+ # before reversing by name and works since we're giving
+ # name='django.contrib.sitemaps.views.sitemap', we need to silence
+ # the erroneous warning until reversing by dotted path is removed.
+ # The test will work without modification when it's removed.
+ response = self.client.get('/simple/index.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<sitemap><loc>%s/simple/sitemap-simple.xml</loc></sitemap>
+</sitemapindex>
+""" % self.base_url
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ @ignore_warnings(category=RemovedInDjango20Warning)
+ @override_settings(TEMPLATES=[{
+ 'BACKEND': 'django.template.backends.django.DjangoTemplates',
+ 'DIRS': [os.path.join(os.path.dirname(upath(__file__)), 'templates')],
+ }])
+ def test_simple_sitemap_custom_index(self):
+ "A simple sitemap index can be rendered with a custom template"
+ # The URL for views.sitemap in tests/urls/http.py has been updated
+ # with a name but since reversing by Python path is tried first
+ # before reversing by name and works since we're giving
+ # name='django.contrib.sitemaps.views.sitemap', we need to silence
+ # the erroneous warning until reversing by dotted path is removed.
+ # The test will work without modification when it's removed.
+ response = self.client.get('/simple/custom-index.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<!-- This is a customised template -->
+<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<sitemap><loc>%s/simple/sitemap-simple.xml</loc></sitemap>
+</sitemapindex>
+""" % self.base_url
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ def test_simple_sitemap_section(self):
+ "A simple sitemap section can be rendered"
+ response = self.client.get('/simple/sitemap-simple.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<url><loc>%s/location/</loc><lastmod>%s</lastmod><changefreq>never</changefreq><priority>0.5</priority></url>
+</urlset>
+""" % (self.base_url, date.today())
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ def test_simple_sitemap(self):
+ "A simple sitemap can be rendered"
+ response = self.client.get('/simple/sitemap.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<url><loc>%s/location/</loc><lastmod>%s</lastmod><changefreq>never</changefreq><priority>0.5</priority></url>
+</urlset>
+""" % (self.base_url, date.today())
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ @override_settings(TEMPLATES=[{
+ 'BACKEND': 'django.template.backends.django.DjangoTemplates',
+ 'DIRS': [os.path.join(os.path.dirname(upath(__file__)), 'templates')],
+ }])
+ def test_simple_custom_sitemap(self):
+ "A simple sitemap can be rendered with a custom template"
+ response = self.client.get('/simple/custom-sitemap.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<!-- This is a customised template -->
+<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<url><loc>%s/location/</loc><lastmod>%s</lastmod><changefreq>never</changefreq><priority>0.5</priority></url>
+</urlset>
+""" % (self.base_url, date.today())
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ def test_sitemap_last_modified(self):
+ "Tests that Last-Modified header is set correctly"
+ response = self.client.get('/lastmod/sitemap.xml')
+ self.assertEqual(response['Last-Modified'], 'Wed, 13 Mar 2013 10:00:00 GMT')
+
+ def test_sitemap_last_modified_date(self):
+ """
+ The Last-Modified header should be support dates (without time).
+ """
+ response = self.client.get('/lastmod/date-sitemap.xml')
+ self.assertEqual(response['Last-Modified'], 'Wed, 13 Mar 2013 00:00:00 GMT')
+
+ def test_sitemap_last_modified_tz(self):
+ """
+ The Last-Modified header should be converted from timezone aware dates
+ to GMT.
+ """
+ response = self.client.get('/lastmod/tz-sitemap.xml')
+ self.assertEqual(response['Last-Modified'], 'Wed, 13 Mar 2013 15:00:00 GMT')
+
+ def test_sitemap_last_modified_missing(self):
+ "Tests that Last-Modified header is missing when sitemap has no lastmod"
+ response = self.client.get('/generic/sitemap.xml')
+ self.assertFalse(response.has_header('Last-Modified'))
+
+ def test_sitemap_last_modified_mixed(self):
+ "Tests that Last-Modified header is omitted when lastmod not on all items"
+ response = self.client.get('/lastmod-mixed/sitemap.xml')
+ self.assertFalse(response.has_header('Last-Modified'))
+
+ @skipUnless(settings.USE_I18N, "Internationalization is not enabled")
+ @override_settings(USE_L10N=True)
+ def test_localized_priority(self):
+ "The priority value should not be localized (Refs #14164)"
+ activate('fr')
+ self.assertEqual('0,3', localize(0.3))
+
+ # Retrieve the sitemap. Check that priorities
+ # haven't been rendered in localized format
+ response = self.client.get('/simple/sitemap.xml')
+ self.assertContains(response, '<priority>0.5</priority>')
+ self.assertContains(response, '<lastmod>%s</lastmod>' % date.today())
+ deactivate()
+
+ @modify_settings(INSTALLED_APPS={'remove': 'django.contrib.sites'})
+ def test_requestsite_sitemap(self):
+ # Make sure hitting the flatpages sitemap without the sites framework
+ # installed doesn't raise an exception.
+ response = self.client.get('/simple/sitemap.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<url><loc>http://testserver/location/</loc><lastmod>%s</lastmod><changefreq>never</changefreq><priority>0.5</priority></url>
+</urlset>
+""" % date.today()
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ @skipUnless(apps.is_installed('django.contrib.sites'),
+ "django.contrib.sites app not installed.")
+ def test_sitemap_get_urls_no_site_1(self):
+ """
+ Check we get ImproperlyConfigured if we don't pass a site object to
+ Sitemap.get_urls and no Site objects exist
+ """
+ Site.objects.all().delete()
+ self.assertRaises(ImproperlyConfigured, Sitemap().get_urls)
+
+ @modify_settings(INSTALLED_APPS={'remove': 'django.contrib.sites'})
+ def test_sitemap_get_urls_no_site_2(self):
+ """
+ Check we get ImproperlyConfigured when we don't pass a site object to
+ Sitemap.get_urls if Site objects exists, but the sites framework is not
+ actually installed.
+ """
+ self.assertRaises(ImproperlyConfigured, Sitemap().get_urls)
+
+ def test_sitemap_item(self):
+ """
+ Check to make sure that the raw item is included with each
+ Sitemap.get_url() url result.
+ """
+ test_sitemap = GenericSitemap({'queryset': TestModel.objects.all()})
+
+ def is_testmodel(url):
+ return isinstance(url['item'], TestModel)
+ item_in_url_info = all(map(is_testmodel, test_sitemap.get_urls()))
+ self.assertTrue(item_in_url_info)
+
+ def test_cached_sitemap_index(self):
+ """
+ Check that a cached sitemap index can be rendered (#2713).
+ """
+ response = self.client.get('/cached/index.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<sitemap><loc>%s/cached/sitemap-simple.xml</loc></sitemap>
+</sitemapindex>
+""" % self.base_url
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)
+
+ @ignore_warnings(category=RemovedInDjango20Warning)
+ def test_x_robots_sitemap(self):
+ # The URL for views.sitemap in tests/urls/http.py has been updated
+ # with a name but since reversing by Python path is tried first
+ # before reversing by name and works since we're giving
+ # name='django.contrib.sitemaps.views.sitemap', we need to silence
+ # the erroneous warning until reversing by dotted path is removed.
+ # The test will work without modification when it's removed.
+ response = self.client.get('/simple/index.xml')
+ self.assertEqual(response['X-Robots-Tag'], 'noindex, noodp, noarchive')
+
+ response = self.client.get('/simple/sitemap.xml')
+ self.assertEqual(response['X-Robots-Tag'], 'noindex, noodp, noarchive')
+
+ def test_empty_sitemap(self):
+ response = self.client.get('/empty/sitemap.xml')
+ self.assertEqual(response.status_code, 200)
+
+ @override_settings(LANGUAGES=(('en', 'English'), ('pt', 'Portuguese')))
+ def test_simple_i18nsitemap_index(self):
+ "A simple i18n sitemap index can be rendered"
+ response = self.client.get('/simple/i18n.xml')
+ expected_content = """<?xml version="1.0" encoding="UTF-8"?>
+<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
+<url><loc>{0}/en/i18n/testmodel/{1}/</loc><changefreq>never</changefreq><priority>0.5</priority></url><url><loc>{0}/pt/i18n/testmodel/{1}/</loc><changefreq>never</changefreq><priority>0.5</priority></url>
+</urlset>
+""".format(self.base_url, self.i18n_model.pk)
+ self.assertXMLEqual(response.content.decode('utf-8'), expected_content)