Merge pull request #13491 from edx/saleem-latif/SOL-2076

SOL-2076: check settings.DEFAULT_SITE_THEME to be not None before applying default theme
This commit is contained in:
Saleem Latif
2016-09-20 10:41:07 +05:00
committed by GitHub
2 changed files with 46 additions and 1 deletions

View File

@@ -18,5 +18,7 @@ class CurrentSiteThemeMiddleware(object):
"""
fetch Site Theme for the current site and add it to the request object.
"""
default_theme = SiteTheme(site=request.site, theme_dir_name=settings.DEFAULT_SITE_THEME)
default_theme = None
if settings.DEFAULT_SITE_THEME:
default_theme = SiteTheme(site=request.site, theme_dir_name=settings.DEFAULT_SITE_THEME)
request.site_theme = SiteTheme.get_theme(request.site, default=default_theme)

View File

@@ -0,0 +1,43 @@
"""
Tests for middleware for comprehensive themes.
"""
from mock import Mock
from django.test import TestCase, override_settings
from django.contrib.sites.models import Site
from openedx.core.djangoapps.theming.middleware import CurrentSiteThemeMiddleware
class TestCurrentSiteThemeMiddlewareLMS(TestCase):
"""
Test theming middleware.
"""
def setUp(self):
"""
Initialize middleware and related objects
"""
super(TestCurrentSiteThemeMiddlewareLMS, self).setUp()
self.site_theme_middleware = CurrentSiteThemeMiddleware()
self.request = Mock()
self.request.site, __ = Site.objects.get_or_create(domain="test", name="test")
self.request.session = {}
@override_settings(DEFAULT_SITE_THEME="test-theme")
def test_default_site_theme(self):
"""
Test that request.site_theme returns theme defined by DEFAULT_SITE_THEME setting
when there is no theme associated with the current site.
"""
self.assertEqual(self.site_theme_middleware.process_request(self.request), None)
self.assertIsNotNone(self.request.site_theme)
self.assertEqual(self.request.site_theme.theme_dir_name, "test-theme")
@override_settings(DEFAULT_SITE_THEME=None)
def test_default_site_theme_2(self):
"""
Test that request.site_theme returns None when there is no theme associated with
the current site and DEFAULT_SITE_THEME is also None.
"""
self.assertEqual(self.site_theme_middleware.process_request(self.request), None)
self.assertIsNone(self.request.site_theme)