From 95206001b76275951026a3d628f7c581fc53bc98 Mon Sep 17 00:00:00 2001 From: Sher Ali Date: Tue, 2 Mar 2021 14:57:15 +0500 Subject: [PATCH 1/2] redirect anonymous user to courses page on root --- lms/djangoapps/branding/tests/test_views.py | 24 +++++++++++++++++++ lms/djangoapps/branding/views.py | 7 ++++++ .../site_configuration/tests/mixins.py | 12 ++++++++++ 3 files changed, 43 insertions(+) diff --git a/lms/djangoapps/branding/tests/test_views.py b/lms/djangoapps/branding/tests/test_views.py index 74b6a06f5955..b6bc930ca5e7 100644 --- a/lms/djangoapps/branding/tests/test_views.py +++ b/lms/djangoapps/branding/tests/test_views.py @@ -1,5 +1,6 @@ # encoding: utf-8 """Tests of Branding API views. """ +from copy import deepcopy import json import urllib @@ -315,3 +316,26 @@ def test_header_logo_links_to_marketing_site_with_site_override(self): self.client.login(username=self.user.username, password="password") response = self.client.get(reverse("dashboard")) self.assertIn(self.site_configuration_other.values["MKTG_URLS"]["ROOT"], response.content) + + def test_index_redirects_to_courses_with_site_override(self): + """ Test index view redirects if ALWAYS_REDIRECT_HOMEPAGE_TO_COURSES_FOR_ANONYMOUS_USER is set in SiteConfiguration """ + self.use_site(self.site_for_courses_redirection) + response = self.client.get(reverse("root")) + self.assertRedirects( + response, + reverse('courses'), + fetch_redirect_response=False + ) + + def test_index_redirects_to_courses_with_feature_flag(self): + """ Test index view redirects if ALWAYS_REDIRECT_HOMEPAGE_TO_COURSES_FOR_ANONYMOUS_USER feature flag is set """ + self.use_site(self.site_for_courses_redirection) + feature_flags = deepcopy(settings.FEATURES) + feature_flags['ALWAYS_REDIRECT_HOMEPAGE_TO_COURSES_FOR_ANONYMOUS_USER'] = True + with self.settings(FEATURES=feature_flags): + response = self.client.get(reverse("root")) + self.assertRedirects( + response, + reverse('courses'), + fetch_redirect_response=False + ) diff --git a/lms/djangoapps/branding/views.py b/lms/djangoapps/branding/views.py index 35553b175be2..637ddb292c37 100644 --- a/lms/djangoapps/branding/views.py +++ b/lms/djangoapps/branding/views.py @@ -43,6 +43,13 @@ def index(request): settings.FEATURES.get('ALWAYS_REDIRECT_HOMEPAGE_TO_DASHBOARD_FOR_AUTHENTICATED_USER', True)): return redirect(reverse('dashboard')) + # Redirect to courses if user is anonymous + if request.user.is_anonymous: + if configuration_helpers.get_value( + 'ALWAYS_REDIRECT_HOMEPAGE_TO_COURSES_FOR_ANONYMOUS_USER', + settings.FEATURES.get('ALWAYS_REDIRECT_HOMEPAGE_TO_COURSES_FOR_ANONYMOUS_USER', False)): + return redirect(reverse('courses')) + if settings.FEATURES.get('AUTH_USE_CERTIFICATES'): from openedx.core.djangoapps.external_auth.views import ssl_login # Set next URL to dashboard if it isn't set to avoid diff --git a/openedx/core/djangoapps/site_configuration/tests/mixins.py b/openedx/core/djangoapps/site_configuration/tests/mixins.py index 3883546c745a..85b43383e9a3 100644 --- a/openedx/core/djangoapps/site_configuration/tests/mixins.py +++ b/openedx/core/djangoapps/site_configuration/tests/mixins.py @@ -41,6 +41,18 @@ def setUp(self): } ) + self.site_for_courses_redirection = SiteFactory.create( + domain='fake.site.domain', + name='fake.site.name' + ) + self.site_configuration_for_courses_redirection = SiteConfigurationFactory.create( + site=self.site_for_courses_redirection, + values={ + "SITE_NAME": self.site_for_courses_redirection.domain, + "ALWAYS_REDIRECT_HOMEPAGE_TO_COURSES_FOR_ANONYMOUS_USER": True, + } + ) + # Initialize client with default site domain self.use_site(self.site) From df7a330427ef405c69d37e33cf30446bcd1a8cda Mon Sep 17 00:00:00 2001 From: Sher Ali Date: Tue, 2 Mar 2021 16:05:44 +0500 Subject: [PATCH 2/2] fixed failing test case for commerce api --- lms/djangoapps/commerce/api/v1/tests/test_views.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lms/djangoapps/commerce/api/v1/tests/test_views.py b/lms/djangoapps/commerce/api/v1/tests/test_views.py index af36ca8ec534..06696af2f871 100644 --- a/lms/djangoapps/commerce/api/v1/tests/test_views.py +++ b/lms/djangoapps/commerce/api/v1/tests/test_views.py @@ -172,8 +172,9 @@ def test_update(self): self.assertIsNone(VerificationDeadline.deadline_for_course(self.course.id)) # Generate the expected data - verification_deadline = datetime(year=2020, month=12, day=31, tzinfo=pytz.utc) - expiration_datetime = datetime.now(pytz.utc) + now = datetime.now(pytz.utc) + verification_deadline = now + timedelta(days=1) + expiration_datetime = now response, expected = self._get_update_response_and_expected_data(expiration_datetime, verification_deadline) # Sanity check: The API should return HTTP status 200 for updates