Merge pull request #12670 from cpennington/reset-urls-favicon-tests

Reset urls favicon tests
This commit is contained in:
Calen Pennington
2016-06-07 12:02:45 -04:00
2 changed files with 19 additions and 21 deletions

View File

@@ -31,8 +31,14 @@ class UrlResetMixin(object):
URLCONF_MODULES = None
def _reset_urls(self, urlconf_modules):
def reset_urls(self, urlconf_modules=None):
"""Reset `urls.py` for a set of Django apps."""
if urlconf_modules is None:
urlconf_modules = [settings.ROOT_URLCONF]
if self.URLCONF_MODULES is not None:
urlconf_modules.extend(self.URLCONF_MODULES)
for urlconf in urlconf_modules:
if urlconf in sys.modules:
reload(sys.modules[urlconf])
@@ -61,12 +67,8 @@ class UrlResetMixin(object):
"""
super(UrlResetMixin, self).setUp()
urlconf_modules = [settings.ROOT_URLCONF]
if self.URLCONF_MODULES is not None:
urlconf_modules.extend(self.URLCONF_MODULES)
self._reset_urls(urlconf_modules)
self.addCleanup(lambda: self._reset_urls(urlconf_modules))
self.reset_urls()
self.addCleanup(self.reset_urls)
class EventTestMixin(object):

View File

@@ -9,12 +9,14 @@ from nose.plugins.attrib import attr
import sys
from util.testing import UrlResetMixin
@attr('shard_1')
class FaviconTestCase(TestCase):
def setUp(self):
super(FaviconTestCase, self).setUp()
class FaviconTestCase(UrlResetMixin, TestCase):
"""
Tests of the courseware favicon.
"""
def test_favicon_redirect(self):
resp = self.client.get("/favicon.ico")
@@ -27,15 +29,7 @@ class FaviconTestCase(TestCase):
@override_settings(FAVICON_PATH="images/foo.ico")
def test_favicon_redirect_with_favicon_path_setting(self):
# for some reason I had to put this inline rather than just using
# the UrlResetMixin
urlconf = settings.ROOT_URLCONF
if urlconf in sys.modules:
reload(sys.modules[urlconf])
clear_url_caches()
resolve("/")
self.reset_urls()
resp = self.client.get("/favicon.ico")
self.assertEqual(resp.status_code, 301)
@@ -46,14 +40,16 @@ class FaviconTestCase(TestCase):
)
@patch.dict("django.conf.settings.FEATURES", {"USE_CUSTOM_THEME": True})
@override_settings(FAVICON_PATH="images/bar_fav.ico")
@override_settings(THEME_NAME="bar")
def test_favicon_redirect_with_theme(self):
self.assertEqual(settings.FEATURES["USE_CUSTOM_THEME"], True)
self.reset_urls()
resp = self.client.get("/favicon.ico")
self.assertEqual(resp.status_code, 301)
self.assertRedirects(
resp,
"/static/images/foo.ico",
"/static/images/bar_fav.ico",
status_code=301, target_status_code=404 # @@@ how to avoid 404?
)