Commit f33832a6 by J. Cliff Dyer Committed by J. Cliff Dyer

scoutrule: dedupe skip_unless_lms

parent 0d2ae5d4
#pylint: disable=missing-docstring #pylint: disable=missing-docstring
import unittest
import ddt import ddt
from django.conf import settings
from django.test import TestCase from django.test import TestCase
from openedx.core.djangoapps.api_admin.forms import ApiAccessRequestForm from openedx.core.djangoapps.api_admin.forms import ApiAccessRequestForm
from openedx.core.djangoapps.api_admin.tests.utils import VALID_DATA from openedx.core.djangoapps.api_admin.tests.utils import VALID_DATA
from openedx.core.djangolib.testing.utils import skip_unless_lms
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@ddt.ddt @ddt.ddt
class ApiAccessFormTest(TestCase): class ApiAccessFormTest(TestCase):
......
...@@ -2,21 +2,20 @@ ...@@ -2,21 +2,20 @@
from smtplib import SMTPException from smtplib import SMTPException
import ddt import ddt
from django.conf import settings
from django.db import IntegrityError from django.db import IntegrityError
from django.test import TestCase from django.test import TestCase
import mock import mock
import unittest
from microsite_configuration.tests.factories import SiteFactory from microsite_configuration.tests.factories import SiteFactory
from openedx.core.djangoapps.api_admin.models import ApiAccessRequest, ApiAccessConfig from openedx.core.djangoapps.api_admin.models import ApiAccessRequest, ApiAccessConfig
from openedx.core.djangoapps.api_admin.models import log as model_log from openedx.core.djangoapps.api_admin.models import log as model_log
from openedx.core.djangoapps.api_admin.tests.factories import ApiAccessRequestFactory from openedx.core.djangoapps.api_admin.tests.factories import ApiAccessRequestFactory
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class ApiAccessRequestTests(TestCase): class ApiAccessRequestTests(TestCase):
def setUp(self): def setUp(self):
...@@ -79,7 +78,7 @@ class ApiAccessConfigTests(TestCase): ...@@ -79,7 +78,7 @@ class ApiAccessConfigTests(TestCase):
) )
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class ApiAccessRequestSignalTests(TestCase): class ApiAccessRequestSignalTests(TestCase):
def setUp(self): def setUp(self):
super(ApiAccessRequestSignalTests, self).setUp() super(ApiAccessRequestSignalTests, self).setUp()
......
""" Tests for the api_admin app's views. """ """ Tests for the api_admin app's views. """
import json import json
import unittest
import ddt import ddt
import httpretty import httpretty
...@@ -16,19 +15,26 @@ from openedx.core.djangoapps.api_admin.tests.factories import ( ...@@ -16,19 +15,26 @@ from openedx.core.djangoapps.api_admin.tests.factories import (
ApiAccessRequestFactory, ApplicationFactory, CatalogFactory ApiAccessRequestFactory, ApplicationFactory, CatalogFactory
) )
from openedx.core.djangoapps.api_admin.tests.utils import VALID_DATA from openedx.core.djangoapps.api_admin.tests.utils import VALID_DATA
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
Application = get_application_model() # pylint: disable=invalid-name Application = get_application_model() # pylint: disable=invalid-name
class ApiAdminTest(TestCase): class ApiAdminTest(TestCase):
"""
Base class to allow API admin access to tests.
"""
def setUp(self): def setUp(self):
super(ApiAdminTest, self).setUp() super(ApiAdminTest, self).setUp()
ApiAccessConfig(enabled=True).save() ApiAccessConfig(enabled=True).save()
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class ApiRequestViewTest(ApiAdminTest): class ApiRequestViewTest(ApiAdminTest):
"""
Test the API Request View.
"""
def setUp(self): def setUp(self):
super(ApiRequestViewTest, self).setUp() super(ApiRequestViewTest, self).setUp()
self.url = reverse('api_admin:api-request') self.url = reverse('api_admin:api-request')
...@@ -93,10 +99,13 @@ class ApiRequestViewTest(ApiAdminTest): ...@@ -93,10 +99,13 @@ class ApiRequestViewTest(ApiAdminTest):
self.assertEqual(response.status_code, 404) self.assertEqual(response.status_code, 404)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(PLATFORM_NAME='edX') @override_settings(PLATFORM_NAME='edX')
@ddt.ddt @ddt.ddt
class ApiRequestStatusViewTest(ApiAdminTest): class ApiRequestStatusViewTest(ApiAdminTest):
"""
Tests of the API Status endpoint.
"""
def setUp(self): def setUp(self):
super(ApiRequestStatusViewTest, self).setUp() super(ApiRequestStatusViewTest, self).setUp()
password = 'abc123' password = 'abc123'
...@@ -198,10 +207,15 @@ class ApiRequestStatusViewTest(ApiAdminTest): ...@@ -198,10 +207,15 @@ class ApiRequestStatusViewTest(ApiAdminTest):
self.assertIn('Enter a valid URL.', response.content) self.assertIn('Enter a valid URL.', response.content)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class ApiTosViewTest(ApiAdminTest): class ApiTosViewTest(ApiAdminTest):
"""
Tests of the API terms of service endpoint.
"""
def test_get_api_tos(self): def test_get_api_tos(self):
"""Verify that the terms of service can be read.""" """
Verify that the terms of service can be read.
"""
url = reverse('api_admin:api-tos') url = reverse('api_admin:api-tos')
response = self.client.get(url) response = self.client.get(url)
self.assertEqual(response.status_code, 200) self.assertEqual(response.status_code, 200)
...@@ -209,6 +223,9 @@ class ApiTosViewTest(ApiAdminTest): ...@@ -209,6 +223,9 @@ class ApiTosViewTest(ApiAdminTest):
class CatalogTest(ApiAdminTest): class CatalogTest(ApiAdminTest):
"""
Test the catalog API.
"""
def setUp(self): def setUp(self):
super(CatalogTest, self).setUp() super(CatalogTest, self).setUp()
password = 'abc123' password = 'abc123'
...@@ -232,8 +249,11 @@ class CatalogTest(ApiAdminTest): ...@@ -232,8 +249,11 @@ class CatalogTest(ApiAdminTest):
) )
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CatalogSearchViewTest(CatalogTest): class CatalogSearchViewTest(CatalogTest):
"""
Test the catalog search endpoint.
"""
def setUp(self): def setUp(self):
super(CatalogSearchViewTest, self).setUp() super(CatalogSearchViewTest, self).setUp()
self.url = reverse('api_admin:catalog-search') self.url = reverse('api_admin:catalog-search')
...@@ -254,8 +274,11 @@ class CatalogSearchViewTest(CatalogTest): ...@@ -254,8 +274,11 @@ class CatalogSearchViewTest(CatalogTest):
self.assertRedirects(response, reverse('api_admin:catalog-search')) self.assertRedirects(response, reverse('api_admin:catalog-search'))
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CatalogListViewTest(CatalogTest): class CatalogListViewTest(CatalogTest):
"""
Test the catalog list endpoint.
"""
def setUp(self): def setUp(self):
super(CatalogListViewTest, self).setUp() super(CatalogListViewTest, self).setUp()
self.catalog_user = UserFactory() self.catalog_user = UserFactory()
...@@ -304,8 +327,11 @@ class CatalogListViewTest(CatalogTest): ...@@ -304,8 +327,11 @@ class CatalogListViewTest(CatalogTest):
self.assertEqual(len([r for r in httpretty.httpretty.latest_requests if r.method == 'POST']), 0) self.assertEqual(len([r for r in httpretty.httpretty.latest_requests if r.method == 'POST']), 0)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CatalogEditViewTest(CatalogTest): class CatalogEditViewTest(CatalogTest):
"""
Test edits to the catalog endpoint.
"""
def setUp(self): def setUp(self):
super(CatalogEditViewTest, self).setUp() super(CatalogEditViewTest, self).setUp()
self.catalog_user = UserFactory() self.catalog_user = UserFactory()
...@@ -353,8 +379,11 @@ class CatalogEditViewTest(CatalogTest): ...@@ -353,8 +379,11 @@ class CatalogEditViewTest(CatalogTest):
self.assertEqual(len([r for r in httpretty.httpretty.latest_requests if r.method == 'PATCH']), 0) self.assertEqual(len([r for r in httpretty.httpretty.latest_requests if r.method == 'PATCH']), 0)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CatalogPreviewViewTest(CatalogTest): class CatalogPreviewViewTest(CatalogTest):
"""
Test the catalog preview endpoint.
"""
def setUp(self): def setUp(self):
super(CatalogPreviewViewTest, self).setUp() super(CatalogPreviewViewTest, self).setUp()
self.url = reverse('api_admin:catalog-preview') self.url = reverse('api_admin:catalog-preview')
......
...@@ -4,13 +4,13 @@ Tests for bookmarks api. ...@@ -4,13 +4,13 @@ Tests for bookmarks api.
import ddt import ddt
from mock import patch from mock import patch
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from unittest import skipUnless
from django.conf import settings from django.conf import settings
from django.core.exceptions import ObjectDoesNotExist from django.core.exceptions import ObjectDoesNotExist
from opaque_keys.edx.keys import UsageKey from opaque_keys.edx.keys import UsageKey
from openedx.core.djangolib.testing.utils import skip_unless_lms
from xmodule.modulestore.exceptions import ItemNotFoundError from xmodule.modulestore.exceptions import ItemNotFoundError
from .. import api from .. import api
...@@ -38,7 +38,7 @@ class BookmarkApiEventTestMixin(object): ...@@ -38,7 +38,7 @@ class BookmarkApiEventTestMixin(object):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class BookmarksAPITests(BookmarkApiEventTestMixin, BookmarksTestsBase): class BookmarksAPITests(BookmarkApiEventTestMixin, BookmarksTestsBase):
""" """
These tests cover the parts of the API methods. These tests cover the parts of the API methods.
......
...@@ -8,9 +8,6 @@ from freezegun import freeze_time ...@@ -8,9 +8,6 @@ from freezegun import freeze_time
import mock import mock
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
import pytz import pytz
from unittest import skipUnless
from django.conf import settings
from opaque_keys.edx.keys import UsageKey from opaque_keys.edx.keys import UsageKey
from opaque_keys.edx.locator import CourseLocator, BlockUsageLocator from opaque_keys.edx.locator import CourseLocator, BlockUsageLocator
...@@ -19,6 +16,7 @@ from xmodule.modulestore.django import modulestore ...@@ -19,6 +16,7 @@ from xmodule.modulestore.django import modulestore
from xmodule.modulestore.tests.factories import check_mongo_calls, CourseFactory, ItemFactory from xmodule.modulestore.tests.factories import check_mongo_calls, CourseFactory, ItemFactory
from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.tests.factories import AdminFactory, UserFactory from student.tests.factories import AdminFactory, UserFactory
from .. import DEFAULT_FIELDS, OPTIONAL_FIELDS, PathItem from .. import DEFAULT_FIELDS, OPTIONAL_FIELDS, PathItem
...@@ -228,7 +226,7 @@ class BookmarksTestsBase(ModuleStoreTestCase): ...@@ -228,7 +226,7 @@ class BookmarksTestsBase(ModuleStoreTestCase):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class BookmarkModelTests(BookmarksTestsBase): class BookmarkModelTests(BookmarksTestsBase):
""" """
Test the Bookmark model. Test the Bookmark model.
......
...@@ -2,18 +2,16 @@ ...@@ -2,18 +2,16 @@
Tests for bookmark services. Tests for bookmark services.
""" """
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from unittest import skipUnless
from django.conf import settings
from opaque_keys.edx.keys import UsageKey from opaque_keys.edx.keys import UsageKey
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ..services import BookmarksService from ..services import BookmarksService
from .test_models import BookmarksTestsBase from .test_models import BookmarksTestsBase
@attr(shard=2) @attr(shard=2)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class BookmarksServiceTests(BookmarksTestsBase): class BookmarksServiceTests(BookmarksTestsBase):
""" """
Tests the Bookmarks service. Tests the Bookmarks service.
......
...@@ -5,7 +5,6 @@ Tests for bookmark views. ...@@ -5,7 +5,6 @@ Tests for bookmark views.
import ddt import ddt
import json import json
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from unittest import skipUnless
import urllib import urllib
from django.conf import settings from django.conf import settings
...@@ -13,6 +12,7 @@ from django.core.urlresolvers import reverse ...@@ -13,6 +12,7 @@ from django.core.urlresolvers import reverse
from mock import patch from mock import patch
from rest_framework.test import APIClient from rest_framework.test import APIClient
from openedx.core.djangolib.testing.utils import skip_unless_lms
from xmodule.modulestore import ModuleStoreEnum from xmodule.modulestore import ModuleStoreEnum
from .test_models import BookmarksTestsBase from .test_models import BookmarksTestsBase
...@@ -66,7 +66,7 @@ class BookmarksViewsTestsBase(BookmarksTestsBase, BookmarkApiEventTestMixin): ...@@ -66,7 +66,7 @@ class BookmarksViewsTestsBase(BookmarksTestsBase, BookmarkApiEventTestMixin):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class BookmarksListViewTests(BookmarksViewsTestsBase): class BookmarksListViewTests(BookmarksViewsTestsBase):
""" """
This contains the tests for GET & POST methods of bookmark.views.BookmarksListView class This contains the tests for GET & POST methods of bookmark.views.BookmarksListView class
...@@ -371,7 +371,7 @@ class BookmarksListViewTests(BookmarksViewsTestsBase): ...@@ -371,7 +371,7 @@ class BookmarksListViewTests(BookmarksViewsTestsBase):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class BookmarksDetailViewTests(BookmarksViewsTestsBase): class BookmarksDetailViewTests(BookmarksViewsTestsBase):
""" """
This contains the tests for GET & DELETE methods of bookmark.views.BookmarksDetailView class This contains the tests for GET & DELETE methods of bookmark.views.BookmarksDetailView class
......
"""Tests for cached authentication middleware.""" """Tests for cached authentication middleware."""
import unittest
from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.test import TestCase from django.test import TestCase
from mock import patch from mock import patch
from openedx.core.djangolib.testing.utils import skip_unless_cms, skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
...@@ -33,13 +31,13 @@ class CachedAuthMiddlewareTestCase(TestCase): ...@@ -33,13 +31,13 @@ class CachedAuthMiddlewareTestCase(TestCase):
response = self.client.get(test_url) response = self.client.get(test_url)
self.assertRedirects(response, redirect_url) self.assertRedirects(response, redirect_url)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
def test_session_change_lms(self): def test_session_change_lms(self):
"""Test session verification with LMS-specific URLs.""" """Test session verification with LMS-specific URLs."""
dashboard_url = reverse('dashboard') dashboard_url = reverse('dashboard')
self._test_change_session_hash(dashboard_url, reverse('signin_user') + '?next=' + dashboard_url) self._test_change_session_hash(dashboard_url, reverse('signin_user') + '?next=' + dashboard_url)
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
def test_session_change_cms(self): def test_session_change_cms(self):
"""Test session verification with CMS-specific URLs.""" """Test session verification with CMS-specific URLs."""
home_url = reverse('home') home_url = reverse('home')
......
...@@ -5,15 +5,15 @@ Testing persistent tasks ...@@ -5,15 +5,15 @@ Testing persistent tasks
from __future__ import print_function from __future__ import print_function
from celery import task from celery import task
from django.conf import settings
from django.test import TestCase from django.test import TestCase
from unittest import skipUnless
import six import six
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ..models import FailedTask from ..models import FailedTask
from ..task import PersistOnFailureTask from ..task import PersistOnFailureTask
@skip_unless_lms
class PersistOnFailureTaskTestCase(TestCase): class PersistOnFailureTaskTestCase(TestCase):
""" """
Test that persistent tasks save the appropriate values when needed. Test that persistent tasks save the appropriate values when needed.
...@@ -32,15 +32,12 @@ class PersistOnFailureTaskTestCase(TestCase): ...@@ -32,15 +32,12 @@ class PersistOnFailureTaskTestCase(TestCase):
cls.exampletask = exampletask cls.exampletask = exampletask
super(PersistOnFailureTaskTestCase, cls).setUpClass() super(PersistOnFailureTaskTestCase, cls).setUpClass()
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms')
def test_exampletask_without_failure(self): def test_exampletask_without_failure(self):
result = self.exampletask.delay() result = self.exampletask.delay()
result.wait() result.wait()
self.assertEqual(result.status, u'SUCCESS') self.assertEqual(result.status, u'SUCCESS')
self.assertFalse(FailedTask.objects.exists()) self.assertFalse(FailedTask.objects.exists())
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms')
def test_exampletask_with_failure(self): def test_exampletask_with_failure(self):
result = self.exampletask.delay(message=u'The example task failed') result = self.exampletask.delay(message=u'The example task failed')
with self.assertRaises(ValueError): with self.assertRaises(ValueError):
...@@ -57,7 +54,6 @@ class PersistOnFailureTaskTestCase(TestCase): ...@@ -57,7 +54,6 @@ class PersistOnFailureTaskTestCase(TestCase):
self.assertEqual(failed_task_object.exc, u"ValueError(u'The example task failed',)") self.assertEqual(failed_task_object.exc, u"ValueError(u'The example task failed',)")
self.assertIsNone(failed_task_object.datetime_resolved) self.assertIsNone(failed_task_object.datetime_resolved)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms')
def test_persists_when_called_with_wrong_args(self): def test_persists_when_called_with_wrong_args(self):
result = self.exampletask.delay(15, u'2001-03-04', err=True) result = self.exampletask.delay(15, u'2001-03-04', err=True)
with self.assertRaises(TypeError): with self.assertRaises(TypeError):
...@@ -67,7 +63,6 @@ class PersistOnFailureTaskTestCase(TestCase): ...@@ -67,7 +63,6 @@ class PersistOnFailureTaskTestCase(TestCase):
self.assertEqual(failed_task_object.args, [15, u'2001-03-04']) self.assertEqual(failed_task_object.args, [15, u'2001-03-04'])
self.assertEqual(failed_task_object.kwargs, {u'err': True}) self.assertEqual(failed_task_object.kwargs, {u'err': True})
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms')
def test_persists_with_overlength_field(self): def test_persists_with_overlength_field(self):
overlong_message = u''.join(u'%03d' % x for x in six.moves.range(100)) overlong_message = u''.join(u'%03d' % x for x in six.moves.range(100))
result = self.exampletask.delay(message=overlong_message) result = self.exampletask.delay(message=overlong_message)
......
...@@ -2,13 +2,9 @@ ...@@ -2,13 +2,9 @@
Test the partitions and partitions service Test the partitions and partitions service
""" """
import json
from django.conf import settings
import django.test import django.test
from mock import patch from mock import patch
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from unittest import skipUnless
from courseware.masquerade import handle_ajax, setup_masquerade from courseware.masquerade import handle_ajax, setup_masquerade
from courseware.tests.test_masquerade import StaffMasqueradeTestCase from courseware.tests.test_masquerade import StaffMasqueradeTestCase
...@@ -19,6 +15,7 @@ from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase, TEST_DAT ...@@ -19,6 +15,7 @@ from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase, TEST_DAT
from xmodule.modulestore.tests.factories import ToyCourseFactory from xmodule.modulestore.tests.factories import ToyCourseFactory
from openedx.core.djangoapps.user_api.partition_schemes import RandomUserPartitionScheme from openedx.core.djangoapps.user_api.partition_schemes import RandomUserPartitionScheme
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ..partition_scheme import CohortPartitionScheme, get_cohorted_user_partition from ..partition_scheme import CohortPartitionScheme, get_cohorted_user_partition
from ..models import CourseUserGroupPartitionGroup from ..models import CourseUserGroupPartitionGroup
from ..views import link_cohort_to_partition_group, unlink_cohort_partition_group from ..views import link_cohort_to_partition_group, unlink_cohort_partition_group
...@@ -383,7 +380,7 @@ class TestMasqueradedGroup(StaffMasqueradeTestCase): ...@@ -383,7 +380,7 @@ class TestMasqueradedGroup(StaffMasqueradeTestCase):
self._verify_masquerade_for_group(self.user_partition.groups[1]) self._verify_masquerade_for_group(self.user_partition.groups[1])
self._verify_masquerade_for_group(None) self._verify_masquerade_for_group(None)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
@patch.dict('django.conf.settings.FEATURES', {'DISABLE_START_DATES': False}) @patch.dict('django.conf.settings.FEATURES', {'DISABLE_START_DATES': False})
def test_group_masquerade(self): def test_group_masquerade(self):
""" """
...@@ -391,7 +388,7 @@ class TestMasqueradedGroup(StaffMasqueradeTestCase): ...@@ -391,7 +388,7 @@ class TestMasqueradedGroup(StaffMasqueradeTestCase):
""" """
self._verify_masquerade_for_all_groups() self._verify_masquerade_for_all_groups()
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
@patch.dict('django.conf.settings.FEATURES', {'DISABLE_START_DATES': False}) @patch.dict('django.conf.settings.FEATURES', {'DISABLE_START_DATES': False})
def test_group_masquerade_with_cohort(self): def test_group_masquerade_with_cohort(self):
""" """
......
...@@ -8,9 +8,7 @@ import json ...@@ -8,9 +8,7 @@ import json
from collections import namedtuple from collections import namedtuple
from datetime import datetime from datetime import datetime
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from unittest import skipUnless
from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.http import Http404 from django.http import Http404
from django.test.client import RequestFactory from django.test.client import RequestFactory
...@@ -22,6 +20,8 @@ from xmodule.modulestore.tests.factories import CourseFactory ...@@ -22,6 +20,8 @@ from xmodule.modulestore.tests.factories import CourseFactory
from opaque_keys.edx.locations import SlashSeparatedCourseKey from opaque_keys.edx.locations import SlashSeparatedCourseKey
from xmodule.modulestore.tests.factories import ItemFactory from xmodule.modulestore.tests.factories import ItemFactory
from lms.djangoapps.django_comment_client.constants import TYPE_ENTRY, TYPE_SUBCATEGORY from lms.djangoapps.django_comment_client.constants import TYPE_ENTRY, TYPE_SUBCATEGORY
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ..models import CourseUserGroup, CourseCohort from ..models import CourseUserGroup, CourseCohort
from ..views import ( from ..views import (
...@@ -1207,7 +1207,7 @@ class RemoveUserFromCohortTestCase(CohortViewsTestCase): ...@@ -1207,7 +1207,7 @@ class RemoveUserFromCohortTestCase(CohortViewsTestCase):
@attr(shard=2) @attr(shard=2)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class CourseCohortDiscussionTopicsTestCase(CohortViewsTestCase): class CourseCohortDiscussionTopicsTestCase(CohortViewsTestCase):
""" """
Tests the `cohort_discussion_topics` view. Tests the `cohort_discussion_topics` view.
......
""" CourseTalk widget helpers tests """ """ CourseTalk widget helpers tests """
from __future__ import unicode_literals from __future__ import unicode_literals
from unittest import skipUnless
from django import test from django import test
from django.conf import settings
from opaque_keys.edx.locations import SlashSeparatedCourseKey from opaque_keys.edx.locations import SlashSeparatedCourseKey
from openedx.core.djangoapps.coursetalk import helpers from openedx.core.djangoapps.coursetalk import helpers
from openedx.core.djangoapps.coursetalk import models from openedx.core.djangoapps.coursetalk import models
from openedx.core.djangolib.testing.utils import skip_unless_lms
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Tests only valid in LMS') @skip_unless_lms
class CourseTalkKeyTests(test.TestCase): class CourseTalkKeyTests(test.TestCase):
""" """
CourseTalkKeyTests: CourseTalkKeyTests:
......
"""Tests for models supporting Credentials-related functionality.""" """Tests for models supporting Credentials-related functionality."""
import unittest
from django.conf import settings
from django.test import TestCase from django.test import TestCase
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from openedx.core.djangoapps.credentials.tests.mixins import CredentialsApiConfigMixin from openedx.core.djangoapps.credentials.tests.mixins import CredentialsApiConfigMixin
from openedx.core.djangolib.testing.utils import skip_unless_lms
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@attr(shard=2) @attr(shard=2)
class TestCredentialsApiConfig(CredentialsApiConfigMixin, TestCase): class TestCredentialsApiConfig(CredentialsApiConfigMixin, TestCase):
"""Tests covering the CredentialsApiConfig model.""" """Tests covering the CredentialsApiConfig model."""
......
"""Tests covering Credentials utilities.""" """Tests covering Credentials utilities."""
import unittest
from django.conf import settings
from django.core.cache import cache from django.core.cache import cache
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
import httpretty import httpretty
...@@ -18,11 +15,11 @@ from openedx.core.djangoapps.credentials.utils import ( ...@@ -18,11 +15,11 @@ from openedx.core.djangoapps.credentials.utils import (
from openedx.core.djangoapps.credentials.tests import factories from openedx.core.djangoapps.credentials.tests import factories
from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin, ProgramsDataMixin from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin, ProgramsDataMixin
from openedx.core.djangoapps.programs.models import ProgramsApiConfig from openedx.core.djangoapps.programs.models import ProgramsApiConfig
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@attr(shard=2) @attr(shard=2)
class TestCredentialsRetrieval(ProgramsApiConfigMixin, CredentialsApiConfigMixin, CredentialsDataMixin, class TestCredentialsRetrieval(ProgramsApiConfigMixin, CredentialsApiConfigMixin, CredentialsDataMixin,
ProgramsDataMixin, CacheIsolationTestCase): ProgramsDataMixin, CacheIsolationTestCase):
......
...@@ -3,10 +3,8 @@ Tests for the API functions in the credit app. ...@@ -3,10 +3,8 @@ Tests for the API functions in the credit app.
""" """
import datetime import datetime
import json import json
import unittest
import ddt import ddt
from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.core import mail from django.core import mail
from django.test.utils import override_settings from django.test.utils import override_settings
...@@ -36,6 +34,7 @@ from openedx.core.djangoapps.credit.models import ( ...@@ -36,6 +34,7 @@ from openedx.core.djangoapps.credit.models import (
CreditEligibility, CreditEligibility,
CreditRequest CreditRequest
) )
from openedx.core.djangolib.testing.utils import skip_unless_lms
from course_modes.models import CourseMode from course_modes.models import CourseMode
from student.models import CourseEnrollment from student.models import CourseEnrollment
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
...@@ -203,7 +202,7 @@ class CreditApiTestBase(ModuleStoreTestCase): ...@@ -203,7 +202,7 @@ class CreditApiTestBase(ModuleStoreTestCase):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
@ddt.ddt @ddt.ddt
class CreditRequirementApiTests(CreditApiTestBase): class CreditRequirementApiTests(CreditApiTestBase):
""" """
...@@ -1165,7 +1164,7 @@ class CreditProviderIntegrationApiTests(CreditApiTestBase): ...@@ -1165,7 +1164,7 @@ class CreditProviderIntegrationApiTests(CreditApiTestBase):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
@override_settings( @override_settings(
ECOMMERCE_API_URL=TEST_API_URL, ECOMMERCE_API_URL=TEST_API_URL,
ECOMMERCE_API_SIGNING_KEY=TEST_API_SIGNING_KEY, ECOMMERCE_API_SIGNING_KEY=TEST_API_SIGNING_KEY,
......
...@@ -5,9 +5,6 @@ Tests for In-Course Reverification Access Control Partition scheme ...@@ -5,9 +5,6 @@ Tests for In-Course Reverification Access Control Partition scheme
import ddt import ddt
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
import unittest
from django.conf import settings
from lms.djangoapps.verify_student.models import ( from lms.djangoapps.verify_student.models import (
VerificationCheckpoint, VerificationCheckpoint,
...@@ -15,6 +12,7 @@ from lms.djangoapps.verify_student.models import ( ...@@ -15,6 +12,7 @@ from lms.djangoapps.verify_student.models import (
SkippedReverification, SkippedReverification,
) )
from openedx.core.djangoapps.credit.partition_schemes import VerificationPartitionScheme from openedx.core.djangoapps.credit.partition_schemes import VerificationPartitionScheme
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.models import CourseEnrollment from student.models import CourseEnrollment
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
from xmodule.partitions.partitions import UserPartition, Group from xmodule.partitions.partitions import UserPartition, Group
...@@ -24,7 +22,7 @@ from xmodule.modulestore.tests.factories import CourseFactory ...@@ -24,7 +22,7 @@ from xmodule.modulestore.tests.factories import CourseFactory
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class ReverificationPartitionTest(ModuleStoreTestCase): class ReverificationPartitionTest(ModuleStoreTestCase):
"""Tests for the Reverification Partition Scheme. """ """Tests for the Reverification Partition Scheme. """
......
...@@ -6,9 +6,7 @@ import ddt ...@@ -6,9 +6,7 @@ import ddt
import pytz import pytz
from datetime import timedelta, datetime from datetime import timedelta, datetime
from mock import MagicMock from mock import MagicMock
from unittest import skipUnless
from django.conf import settings
from django.test.client import RequestFactory from django.test.client import RequestFactory
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from course_modes.models import CourseMode from course_modes.models import CourseMode
...@@ -22,10 +20,11 @@ from openedx.core.djangoapps.credit.api import ( ...@@ -22,10 +20,11 @@ from openedx.core.djangoapps.credit.api import (
) )
from openedx.core.djangoapps.credit.models import CreditCourse, CreditProvider from openedx.core.djangoapps.credit.models import CreditCourse, CreditProvider
from openedx.core.djangoapps.credit.signals import listen_for_grade_calculation from openedx.core.djangoapps.credit.signals import listen_for_grade_calculation
from openedx.core.djangolib.testing.utils import skip_unless_lms
@attr(shard=2) @attr(shard=2)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
@ddt.ddt @ddt.ddt
class TestMinGradedRequirementStatus(ModuleStoreTestCase): class TestMinGradedRequirementStatus(ModuleStoreTestCase):
"""Test cases to check the minimum grade requirement status updated. """Test cases to check the minimum grade requirement status updated.
......
...@@ -8,7 +8,6 @@ from __future__ import unicode_literals ...@@ -8,7 +8,6 @@ from __future__ import unicode_literals
import datetime import datetime
import json import json
import unittest
import ddt import ddt
import pytz import pytz
...@@ -28,6 +27,7 @@ from openedx.core.djangoapps.credit.signature import signature ...@@ -28,6 +27,7 @@ from openedx.core.djangoapps.credit.signature import signature
from openedx.core.djangoapps.credit.tests.factories import ( from openedx.core.djangoapps.credit.tests.factories import (
CreditProviderFactory, CreditEligibilityFactory, CreditCourseFactory, CreditRequestFactory, CreditProviderFactory, CreditEligibilityFactory, CreditCourseFactory, CreditRequestFactory,
) )
from openedx.core.djangolib.testing.utils import skip_unless_lms
from openedx.core.lib.token_utils import JwtBuilder from openedx.core.lib.token_utils import JwtBuilder
from student.tests.factories import UserFactory, AdminFactory from student.tests.factories import UserFactory, AdminFactory
from util.date_utils import to_timestamp from util.date_utils import to_timestamp
...@@ -113,7 +113,7 @@ class ReadOnlyMixin(object): ...@@ -113,7 +113,7 @@ class ReadOnlyMixin(object):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CreditCourseViewSetTests(AuthMixin, UserMixin, TestCase): class CreditCourseViewSetTests(AuthMixin, UserMixin, TestCase):
""" Tests for the CreditCourse endpoints. """ Tests for the CreditCourse endpoints.
...@@ -276,7 +276,7 @@ class CreditCourseViewSetTests(AuthMixin, UserMixin, TestCase): ...@@ -276,7 +276,7 @@ class CreditCourseViewSetTests(AuthMixin, UserMixin, TestCase):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CreditProviderViewSetTests(ApiTestCaseMixin, ReadOnlyMixin, AuthMixin, UserMixin, TestCase): class CreditProviderViewSetTests(ApiTestCaseMixin, ReadOnlyMixin, AuthMixin, UserMixin, TestCase):
""" Tests for CreditProviderViewSet. """ """ Tests for CreditProviderViewSet. """
list_path = 'credit:creditprovider-list' list_path = 'credit:creditprovider-list'
...@@ -320,7 +320,7 @@ class CreditProviderViewSetTests(ApiTestCaseMixin, ReadOnlyMixin, AuthMixin, Use ...@@ -320,7 +320,7 @@ class CreditProviderViewSetTests(ApiTestCaseMixin, ReadOnlyMixin, AuthMixin, Use
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CreditProviderRequestCreateViewTests(ApiTestCaseMixin, UserMixin, TestCase): class CreditProviderRequestCreateViewTests(ApiTestCaseMixin, UserMixin, TestCase):
""" Tests for CreditProviderRequestCreateView. """ """ Tests for CreditProviderRequestCreateView. """
...@@ -470,7 +470,7 @@ class CreditProviderRequestCreateViewTests(ApiTestCaseMixin, UserMixin, TestCase ...@@ -470,7 +470,7 @@ class CreditProviderRequestCreateViewTests(ApiTestCaseMixin, UserMixin, TestCase
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CreditProviderCallbackViewTests(UserMixin, TestCase): class CreditProviderCallbackViewTests(UserMixin, TestCase):
""" Tests for CreditProviderCallbackView. """ """ Tests for CreditProviderCallbackView. """
...@@ -624,7 +624,7 @@ class CreditProviderCallbackViewTests(UserMixin, TestCase): ...@@ -624,7 +624,7 @@ class CreditProviderCallbackViewTests(UserMixin, TestCase):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class CreditEligibilityViewTests(AuthMixin, UserMixin, ReadOnlyMixin, TestCase): class CreditEligibilityViewTests(AuthMixin, UserMixin, ReadOnlyMixin, TestCase):
""" Tests for CreditEligibilityView. """ """ Tests for CreditEligibilityView. """
view_name = 'credit:eligibility_details' view_name = 'credit:eligibility_details'
......
...@@ -5,7 +5,6 @@ Tests for EmbargoMiddleware ...@@ -5,7 +5,6 @@ Tests for EmbargoMiddleware
from contextlib import contextmanager from contextlib import contextmanager
import mock import mock
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
import unittest
import pygeoip import pygeoip
import ddt import ddt
...@@ -14,6 +13,7 @@ from django.test.utils import override_settings ...@@ -14,6 +13,7 @@ from django.test.utils import override_settings
from django.core.cache import cache from django.core.cache import cache
from django.db import connection from django.db import connection
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
from xmodule.modulestore.tests.factories import CourseFactory from xmodule.modulestore.tests.factories import CourseFactory
from xmodule.modulestore.tests.django_utils import ( from xmodule.modulestore.tests.django_utils import (
...@@ -41,7 +41,7 @@ MODULESTORE_CONFIG = mixed_store_config(settings.COMMON_TEST_DATA_ROOT, {}) ...@@ -41,7 +41,7 @@ MODULESTORE_CONFIG = mixed_store_config(settings.COMMON_TEST_DATA_ROOT, {})
@attr(shard=3) @attr(shard=3)
@ddt.ddt @ddt.ddt
@override_settings(MODULESTORE=MODULESTORE_CONFIG) @override_settings(MODULESTORE=MODULESTORE_CONFIG)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@mock.patch.dict(settings.FEATURES, {'EMBARGO': True}) @mock.patch.dict(settings.FEATURES, {'EMBARGO': True})
class EmbargoCheckAccessApiTests(ModuleStoreTestCase): class EmbargoCheckAccessApiTests(ModuleStoreTestCase):
"""Test the embargo API calls to determine whether a user has access. """ """Test the embargo API calls to determine whether a user has access. """
...@@ -239,7 +239,7 @@ class EmbargoCheckAccessApiTests(ModuleStoreTestCase): ...@@ -239,7 +239,7 @@ class EmbargoCheckAccessApiTests(ModuleStoreTestCase):
@ddt.ddt @ddt.ddt
@override_settings(MODULESTORE=MODULESTORE_CONFIG) @override_settings(MODULESTORE=MODULESTORE_CONFIG)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class EmbargoMessageUrlApiTests(UrlResetMixin, ModuleStoreTestCase): class EmbargoMessageUrlApiTests(UrlResetMixin, ModuleStoreTestCase):
"""Test the embargo API calls for retrieving the blocking message URLs. """ """Test the embargo API calls for retrieving the blocking message URLs. """
......
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
Tests for EmbargoMiddleware with CountryAccessRules Tests for EmbargoMiddleware with CountryAccessRules
""" """
import unittest
from mock import patch from mock import patch
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
import ddt import ddt
...@@ -11,11 +10,12 @@ from django.core.urlresolvers import reverse ...@@ -11,11 +10,12 @@ from django.core.urlresolvers import reverse
from django.conf import settings from django.conf import settings
from django.core.cache import cache as django_cache from django.core.cache import cache as django_cache
from config_models.models import cache as config_cache
from openedx.core.djangolib.testing.utils import skip_unless_lms
from util.testing import UrlResetMixin from util.testing import UrlResetMixin
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
from xmodule.modulestore.tests.factories import CourseFactory from xmodule.modulestore.tests.factories import CourseFactory
from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase
from config_models.models import cache as config_cache
from ..models import RestrictedCourse, IPFilter from ..models import RestrictedCourse, IPFilter
from ..test_utils import restrict_course from ..test_utils import restrict_course
...@@ -23,7 +23,7 @@ from ..test_utils import restrict_course ...@@ -23,7 +23,7 @@ from ..test_utils import restrict_course
@attr(shard=3) @attr(shard=3)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class EmbargoMiddlewareAccessTests(UrlResetMixin, ModuleStoreTestCase): class EmbargoMiddlewareAccessTests(UrlResetMixin, ModuleStoreTestCase):
"""Tests of embargo middleware country access rules. """Tests of embargo middleware country access rules.
......
"""Tests for embargo app views. """ """Tests for embargo app views. """
import unittest
from mock import patch from mock import patch
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.conf import settings from django.conf import settings
...@@ -8,11 +7,11 @@ import ddt ...@@ -8,11 +7,11 @@ import ddt
from util.testing import UrlResetMixin from util.testing import UrlResetMixin
from .. import messages from .. import messages
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from openedx.core.djangoapps.theming.tests.test_util import with_comprehensive_theme from openedx.core.djangoapps.theming.tests.test_util import with_comprehensive_theme
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@ddt.ddt @ddt.ddt
class CourseAccessMessageViewTest(CacheIsolationTestCase, UrlResetMixin): class CourseAccessMessageViewTest(CacheIsolationTestCase, UrlResetMixin):
"""Tests for the courseware access message view. """Tests for the courseware access message view.
......
...@@ -3,10 +3,10 @@ Provides unit tests for SSL based authentication portions ...@@ -3,10 +3,10 @@ Provides unit tests for SSL based authentication portions
of the external_auth app. of the external_auth app.
""" """
# pylint: disable=no-member # pylint: disable=no-member
from contextlib import contextmanager
import copy import copy
import unittest from mock import Mock, patch
from contextlib import contextmanager
from django.conf import settings from django.conf import settings
from django.contrib.auth import SESSION_KEY from django.contrib.auth import SESSION_KEY
from django.contrib.auth.models import AnonymousUser, User from django.contrib.auth.models import AnonymousUser, User
...@@ -15,10 +15,10 @@ from django.core.urlresolvers import reverse ...@@ -15,10 +15,10 @@ from django.core.urlresolvers import reverse
from django.test.client import Client from django.test.client import Client
from django.test.client import RequestFactory from django.test.client import RequestFactory
from django.test.utils import override_settings from django.test.utils import override_settings
from mock import Mock, patch
from openedx.core.djangoapps.external_auth.models import ExternalAuthMap from openedx.core.djangoapps.external_auth.models import ExternalAuthMap
import openedx.core.djangoapps.external_auth.views as external_auth_views import openedx.core.djangoapps.external_auth.views as external_auth_views
from openedx.core.djangolib.testing.utils import skip_unless_cms, skip_unless_lms
from student.models import CourseEnrollment from student.models import CourseEnrollment
from student.roles import CourseStaffRole from student.roles import CourseStaffRole
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
...@@ -81,7 +81,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -81,7 +81,7 @@ class SSLClientTest(ModuleStoreTestCase):
self.factory = RequestFactory() self.factory = RequestFactory()
self.mock = Mock() self.mock = Mock()
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
def test_ssl_login_with_signup_lms(self): def test_ssl_login_with_signup_lms(self):
""" """
Validate that an SSL login creates an eamap user and Validate that an SSL login creates an eamap user and
...@@ -101,7 +101,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -101,7 +101,7 @@ class SSLClientTest(ModuleStoreTestCase):
with self.assertRaises(User.DoesNotExist): with self.assertRaises(User.DoesNotExist):
User.objects.get(email=self.USER_EMAIL) User.objects.get(email=self.USER_EMAIL)
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
def test_ssl_login_with_signup_cms(self): def test_ssl_login_with_signup_cms(self):
""" """
Validate that an SSL login creates an eamap user and Validate that an SSL login creates an eamap user and
...@@ -120,7 +120,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -120,7 +120,7 @@ class SSLClientTest(ModuleStoreTestCase):
with self.assertRaises(User.DoesNotExist): with self.assertRaises(User.DoesNotExist):
User.objects.get(email=self.USER_EMAIL) User.objects.get(email=self.USER_EMAIL)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_ssl_login_without_signup_lms(self): def test_ssl_login_without_signup_lms(self):
""" """
...@@ -140,7 +140,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -140,7 +140,7 @@ class SSLClientTest(ModuleStoreTestCase):
except ExternalAuthMap.DoesNotExist, ex: except ExternalAuthMap.DoesNotExist, ex:
self.fail('User did not get properly added to internal users, exception was {0}'.format(str(ex))) self.fail('User did not get properly added to internal users, exception was {0}'.format(str(ex)))
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_ssl_login_without_signup_cms(self): def test_ssl_login_without_signup_cms(self):
""" """
...@@ -166,7 +166,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -166,7 +166,7 @@ class SSLClientTest(ModuleStoreTestCase):
except ExternalAuthMap.DoesNotExist, ex: except ExternalAuthMap.DoesNotExist, ex:
self.fail('User did not get properly added to internal users, exception was {0}'.format(str(ex))) self.fail('User did not get properly added to internal users, exception was {0}'.format(str(ex)))
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_default_login_decorator_ssl(self): def test_default_login_decorator_ssl(self):
""" """
...@@ -184,7 +184,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -184,7 +184,7 @@ class SSLClientTest(ModuleStoreTestCase):
response.redirect_chain[-1]) response.redirect_chain[-1])
self.assertIn(SESSION_KEY, self.client.session) self.assertIn(SESSION_KEY, self.client.session)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_registration_page_bypass(self): def test_registration_page_bypass(self):
""" """
...@@ -198,7 +198,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -198,7 +198,7 @@ class SSLClientTest(ModuleStoreTestCase):
response.redirect_chain[-1]) response.redirect_chain[-1])
self.assertIn(SESSION_KEY, self.client.session) self.assertIn(SESSION_KEY, self.client.session)
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_cms_registration_page_bypass(self): def test_cms_registration_page_bypass(self):
""" """
...@@ -217,7 +217,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -217,7 +217,7 @@ class SSLClientTest(ModuleStoreTestCase):
response = self.client.get(reverse('signup'), follow=True) response = self.client.get(reverse('signup'), follow=True)
self.assertEqual(response.status_code, 404) self.assertEqual(response.status_code, 404)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_signin_page_bypass(self): def test_signin_page_bypass(self):
""" """
...@@ -238,7 +238,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -238,7 +238,7 @@ class SSLClientTest(ModuleStoreTestCase):
response.redirect_chain[-1]) response.redirect_chain[-1])
self.assertIn(SESSION_KEY, self.client.session) self.assertIn(SESSION_KEY, self.client.session)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_ssl_bad_eamap(self): def test_ssl_bad_eamap(self):
""" """
...@@ -263,7 +263,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -263,7 +263,7 @@ class SSLClientTest(ModuleStoreTestCase):
SSL_CLIENT_S_DN=self.AUTH_DN.format(self.USER_NAME, self.USER_EMAIL)) SSL_CLIENT_S_DN=self.AUTH_DN.format(self.USER_NAME, self.USER_EMAIL))
self.assertIn(SESSION_KEY, self.client.session) self.assertIn(SESSION_KEY, self.client.session)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITHOUT_SSL_AUTH) @override_settings(FEATURES=FEATURES_WITHOUT_SSL_AUTH)
def test_ssl_decorator_no_certs(self): def test_ssl_decorator_no_certs(self):
"""Make sure no external auth happens without SSL enabled""" """Make sure no external auth happens without SSL enabled"""
...@@ -279,7 +279,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -279,7 +279,7 @@ class SSLClientTest(ModuleStoreTestCase):
self.assertTrue(self.mock.called) self.assertTrue(self.mock.called)
self.assertEqual(0, len(ExternalAuthMap.objects.all())) self.assertEqual(0, len(ExternalAuthMap.objects.all()))
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
def test_ssl_login_decorator(self): def test_ssl_login_decorator(self):
"""Create mock function to test ssl login decorator""" """Create mock function to test ssl login decorator"""
...@@ -305,7 +305,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -305,7 +305,7 @@ class SSLClientTest(ModuleStoreTestCase):
dec_mock(request) dec_mock(request)
self.assertTrue(self.mock.called) self.assertTrue(self.mock.called)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_IMMEDIATE_SIGNUP)
def test_ssl_decorator_auto_signup(self): def test_ssl_decorator_auto_signup(self):
""" """
...@@ -330,7 +330,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -330,7 +330,7 @@ class SSLClientTest(ModuleStoreTestCase):
self.assertTrue(self.mock.called) self.assertTrue(self.mock.called)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_AUTO_ACTIVATE) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_AUTO_ACTIVATE)
def test_ssl_lms_redirection(self): def test_ssl_lms_redirection(self):
""" """
...@@ -361,7 +361,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -361,7 +361,7 @@ class SSLClientTest(ModuleStoreTestCase):
response.redirect_chain[-1]) response.redirect_chain[-1])
self.assertIn(SESSION_KEY, self.client.session) self.assertIn(SESSION_KEY, self.client.session)
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_AUTO_ACTIVATE) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_AUTO_ACTIVATE)
def test_ssl_cms_redirection(self): def test_ssl_cms_redirection(self):
""" """
...@@ -393,7 +393,7 @@ class SSLClientTest(ModuleStoreTestCase): ...@@ -393,7 +393,7 @@ class SSLClientTest(ModuleStoreTestCase):
response.redirect_chain[-1]) response.redirect_chain[-1])
self.assertIn(SESSION_KEY, self.client.session) self.assertIn(SESSION_KEY, self.client.session)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_AUTO_ACTIVATE) @override_settings(FEATURES=FEATURES_WITH_SSL_AUTH_AUTO_ACTIVATE)
def test_ssl_logout(self): def test_ssl_logout(self):
""" """
......
...@@ -5,9 +5,7 @@ from contextlib import closing ...@@ -5,9 +5,7 @@ from contextlib import closing
from itertools import product from itertools import product
import os import os
from tempfile import NamedTemporaryFile from tempfile import NamedTemporaryFile
import unittest
from django.conf import settings
from django.core.files.uploadedfile import UploadedFile from django.core.files.uploadedfile import UploadedFile
from django.test import TestCase from django.test import TestCase
from django.test.utils import override_settings from django.test.utils import override_settings
...@@ -17,6 +15,7 @@ from nose.plugins.attrib import attr ...@@ -17,6 +15,7 @@ from nose.plugins.attrib import attr
import piexif import piexif
from PIL import Image from PIL import Image
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ..exceptions import ImageValidationError from ..exceptions import ImageValidationError
from ..images import ( from ..images import (
create_profile_images, create_profile_images,
...@@ -31,7 +30,7 @@ from .helpers import make_image_file, make_uploaded_file ...@@ -31,7 +30,7 @@ from .helpers import make_image_file, make_uploaded_file
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
class TestValidateUploadedImage(TestCase): class TestValidateUploadedImage(TestCase):
""" """
Test validate_uploaded_image Test validate_uploaded_image
...@@ -127,7 +126,7 @@ class TestValidateUploadedImage(TestCase): ...@@ -127,7 +126,7 @@ class TestValidateUploadedImage(TestCase):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
class TestGenerateProfileImages(TestCase): class TestGenerateProfileImages(TestCase):
""" """
Test create_profile_images Test create_profile_images
...@@ -224,7 +223,7 @@ class TestGenerateProfileImages(TestCase): ...@@ -224,7 +223,7 @@ class TestGenerateProfileImages(TestCase):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
class TestRemoveProfileImages(TestCase): class TestRemoveProfileImages(TestCase):
""" """
Test remove_profile_images Test remove_profile_images
......
...@@ -5,9 +5,7 @@ from contextlib import closing ...@@ -5,9 +5,7 @@ from contextlib import closing
import datetime import datetime
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from pytz import UTC from pytz import UTC
import unittest
from django.conf import settings
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.http import HttpResponse from django.http import HttpResponse
...@@ -24,6 +22,7 @@ from openedx.core.djangoapps.user_api.accounts.image_helpers import ( ...@@ -24,6 +22,7 @@ from openedx.core.djangoapps.user_api.accounts.image_helpers import (
get_profile_image_names, get_profile_image_names,
get_profile_image_storage, get_profile_image_storage,
) )
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ..images import create_profile_images, ImageValidationError from ..images import create_profile_images, ImageValidationError
from ..views import LOG_MESSAGE_CREATE, LOG_MESSAGE_DELETE from ..views import LOG_MESSAGE_CREATE, LOG_MESSAGE_DELETE
...@@ -153,7 +152,7 @@ class ProfileImageEndpointMixin(UserSettingsEventTestMixin): ...@@ -153,7 +152,7 @@ class ProfileImageEndpointMixin(UserSettingsEventTestMixin):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
@mock.patch('openedx.core.djangoapps.profile_images.views.log') @mock.patch('openedx.core.djangoapps.profile_images.views.log')
class ProfileImageViewGeneralTestCase(ProfileImageEndpointMixin, APITestCase): class ProfileImageViewGeneralTestCase(ProfileImageEndpointMixin, APITestCase):
""" """
...@@ -174,7 +173,7 @@ class ProfileImageViewGeneralTestCase(ProfileImageEndpointMixin, APITestCase): ...@@ -174,7 +173,7 @@ class ProfileImageViewGeneralTestCase(ProfileImageEndpointMixin, APITestCase):
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
@mock.patch('openedx.core.djangoapps.profile_images.views.log') @mock.patch('openedx.core.djangoapps.profile_images.views.log')
class ProfileImageViewPostTestCase(ProfileImageEndpointMixin, APITestCase): class ProfileImageViewPostTestCase(ProfileImageEndpointMixin, APITestCase):
""" """
...@@ -384,7 +383,7 @@ class ProfileImageViewPostTestCase(ProfileImageEndpointMixin, APITestCase): ...@@ -384,7 +383,7 @@ class ProfileImageViewPostTestCase(ProfileImageEndpointMixin, APITestCase):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
@mock.patch('openedx.core.djangoapps.profile_images.views.log') @mock.patch('openedx.core.djangoapps.profile_images.views.log')
class ProfileImageViewDeleteTestCase(ProfileImageEndpointMixin, APITestCase): class ProfileImageViewDeleteTestCase(ProfileImageEndpointMixin, APITestCase):
""" """
...@@ -515,7 +514,7 @@ class DeprecatedProfileImageTestMixin(ProfileImageEndpointMixin): ...@@ -515,7 +514,7 @@ class DeprecatedProfileImageTestMixin(ProfileImageEndpointMixin):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
@mock.patch('openedx.core.djangoapps.profile_images.views.log') @mock.patch('openedx.core.djangoapps.profile_images.views.log')
class DeprecatedProfileImageUploadTestCase(DeprecatedProfileImageTestMixin, APITestCase): class DeprecatedProfileImageUploadTestCase(DeprecatedProfileImageTestMixin, APITestCase):
""" """
...@@ -528,7 +527,7 @@ class DeprecatedProfileImageUploadTestCase(DeprecatedProfileImageTestMixin, APIT ...@@ -528,7 +527,7 @@ class DeprecatedProfileImageUploadTestCase(DeprecatedProfileImageTestMixin, APIT
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Profile Image API is only supported in LMS') @skip_unless_lms
@mock.patch('openedx.core.djangoapps.profile_images.views.log') @mock.patch('openedx.core.djangoapps.profile_images.views.log')
class DeprecatedProfileImageRemoveTestCase(DeprecatedProfileImageTestMixin, APITestCase): class DeprecatedProfileImageRemoveTestCase(DeprecatedProfileImageTestMixin, APITestCase):
""" """
......
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
Tests for programs celery tasks. Tests for programs celery tasks.
""" """
import json import json
import unittest
from celery.exceptions import MaxRetriesExceededError from celery.exceptions import MaxRetriesExceededError
import ddt import ddt
...@@ -20,7 +19,7 @@ from openedx.core.djangoapps.credentials.tests.mixins import CredentialsApiConfi ...@@ -20,7 +19,7 @@ from openedx.core.djangoapps.credentials.tests.mixins import CredentialsApiConfi
from openedx.core.djangoapps.programs.tests import factories from openedx.core.djangoapps.programs.tests import factories
from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin
from openedx.core.djangoapps.programs.tasks.v1 import tasks from openedx.core.djangoapps.programs.tasks.v1 import tasks
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
...@@ -28,7 +27,7 @@ TASKS_MODULE = 'openedx.core.djangoapps.programs.tasks.v1.tasks' ...@@ -28,7 +27,7 @@ TASKS_MODULE = 'openedx.core.djangoapps.programs.tasks.v1.tasks'
UTILS_MODULE = 'openedx.core.djangoapps.programs.utils' UTILS_MODULE = 'openedx.core.djangoapps.programs.utils'
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class GetApiClientTestCase(TestCase, ProgramsApiConfigMixin): class GetApiClientTestCase(TestCase, ProgramsApiConfigMixin):
""" """
Test the get_api_client function Test the get_api_client function
...@@ -53,7 +52,7 @@ class GetApiClientTestCase(TestCase, ProgramsApiConfigMixin): ...@@ -53,7 +52,7 @@ class GetApiClientTestCase(TestCase, ProgramsApiConfigMixin):
@httpretty.activate @httpretty.activate
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class GetCompletedProgramsTestCase(ProgramsApiConfigMixin, CacheIsolationTestCase): class GetCompletedProgramsTestCase(ProgramsApiConfigMixin, CacheIsolationTestCase):
""" """
Test the get_completed_programs function Test the get_completed_programs function
...@@ -113,7 +112,7 @@ class GetCompletedProgramsTestCase(ProgramsApiConfigMixin, CacheIsolationTestCas ...@@ -113,7 +112,7 @@ class GetCompletedProgramsTestCase(ProgramsApiConfigMixin, CacheIsolationTestCas
self._assert_num_requests(1) self._assert_num_requests(1)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class GetAwardedCertificateProgramsTestCase(TestCase): class GetAwardedCertificateProgramsTestCase(TestCase):
""" """
Test the get_awarded_certificate_programs function Test the get_awarded_certificate_programs function
...@@ -154,7 +153,7 @@ class GetAwardedCertificateProgramsTestCase(TestCase): ...@@ -154,7 +153,7 @@ class GetAwardedCertificateProgramsTestCase(TestCase):
self.assertEqual(result, [1]) self.assertEqual(result, [1])
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class AwardProgramCertificateTestCase(TestCase): class AwardProgramCertificateTestCase(TestCase):
""" """
Test the award_program_certificate function Test the award_program_certificate function
...@@ -183,7 +182,7 @@ class AwardProgramCertificateTestCase(TestCase): ...@@ -183,7 +182,7 @@ class AwardProgramCertificateTestCase(TestCase):
self.assertEqual(json.loads(httpretty.last_request().body), expected_body) self.assertEqual(json.loads(httpretty.last_request().body), expected_body)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@ddt.ddt @ddt.ddt
@mock.patch(TASKS_MODULE + '.award_program_certificate') @mock.patch(TASKS_MODULE + '.award_program_certificate')
@mock.patch(TASKS_MODULE + '.get_awarded_certificate_programs') @mock.patch(TASKS_MODULE + '.get_awarded_certificate_programs')
......
"""Tests for the backpopulate_program_credentials management command.""" """Tests for the backpopulate_program_credentials management command."""
import json import json
from unittest import skipUnless
import ddt import ddt
from django.conf import settings
from django.core.management import call_command, CommandError from django.core.management import call_command, CommandError
from django.test import TestCase from django.test import TestCase
from edx_oauth2_provider.tests.factories import ClientFactory from edx_oauth2_provider.tests.factories import ClientFactory
...@@ -17,6 +15,7 @@ from lms.djangoapps.certificates.tests.factories import GeneratedCertificateFact ...@@ -17,6 +15,7 @@ from lms.djangoapps.certificates.tests.factories import GeneratedCertificateFact
from openedx.core.djangoapps.programs.models import ProgramsApiConfig from openedx.core.djangoapps.programs.models import ProgramsApiConfig
from openedx.core.djangoapps.programs.tests import factories from openedx.core.djangoapps.programs.tests import factories
from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
...@@ -26,7 +25,7 @@ COMMAND_MODULE = 'openedx.core.djangoapps.programs.management.commands.backpopul ...@@ -26,7 +25,7 @@ COMMAND_MODULE = 'openedx.core.djangoapps.programs.management.commands.backpopul
@ddt.ddt @ddt.ddt
@httpretty.activate @httpretty.activate
@mock.patch(COMMAND_MODULE + '.award_program_certificates.delay') @mock.patch(COMMAND_MODULE + '.award_program_certificates.delay')
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class BackpopulateProgramCredentialsTests(ProgramsApiConfigMixin, TestCase): class BackpopulateProgramCredentialsTests(ProgramsApiConfigMixin, TestCase):
"""Tests for the backpopulate_program_credentials management command.""" """Tests for the backpopulate_program_credentials management command."""
course_id, alternate_course_id = 'org/course/run', 'org/alternate/run' course_id, alternate_course_id = 'org/course/run', 'org/alternate/run'
......
...@@ -2,11 +2,9 @@ ...@@ -2,11 +2,9 @@
import copy import copy
import datetime import datetime
import json import json
from unittest import skipUnless
import uuid import uuid
import ddt import ddt
from django.conf import settings
from django.core.cache import cache from django.core.cache import cache
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.test import TestCase from django.test import TestCase
...@@ -29,7 +27,7 @@ from openedx.core.djangoapps.programs import utils ...@@ -29,7 +27,7 @@ from openedx.core.djangoapps.programs import utils
from openedx.core.djangoapps.programs.models import ProgramsApiConfig from openedx.core.djangoapps.programs.models import ProgramsApiConfig
from openedx.core.djangoapps.programs.tests import factories from openedx.core.djangoapps.programs.tests import factories
from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin, ProgramsDataMixin from openedx.core.djangoapps.programs.tests.mixins import ProgramsApiConfigMixin, ProgramsDataMixin
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from student.tests.factories import UserFactory, CourseEnrollmentFactory from student.tests.factories import UserFactory, CourseEnrollmentFactory
from util.date_utils import strftime_localized from util.date_utils import strftime_localized
from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase
...@@ -45,7 +43,7 @@ MARKETING_URL = 'https://www.example.com/marketing/path' ...@@ -45,7 +43,7 @@ MARKETING_URL = 'https://www.example.com/marketing/path'
@ddt.ddt @ddt.ddt
@attr(shard=2) @attr(shard=2)
@httpretty.activate @httpretty.activate
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestProgramRetrieval(ProgramsApiConfigMixin, ProgramsDataMixin, CredentialsDataMixin, class TestProgramRetrieval(ProgramsApiConfigMixin, ProgramsDataMixin, CredentialsDataMixin,
CredentialsApiConfigMixin, CacheIsolationTestCase): CredentialsApiConfigMixin, CacheIsolationTestCase):
"""Tests covering the retrieval of programs from the Programs service.""" """Tests covering the retrieval of programs from the Programs service."""
...@@ -190,7 +188,7 @@ class TestProgramRetrieval(ProgramsApiConfigMixin, ProgramsDataMixin, Credential ...@@ -190,7 +188,7 @@ class TestProgramRetrieval(ProgramsApiConfigMixin, ProgramsDataMixin, Credential
self.assertEqual(actual, []) self.assertEqual(actual, [])
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class GetProgramsByRunTests(TestCase): class GetProgramsByRunTests(TestCase):
"""Tests verifying that programs are inverted correctly.""" """Tests verifying that programs are inverted correctly."""
maxDiff = None maxDiff = None
...@@ -262,7 +260,7 @@ class GetProgramsByRunTests(TestCase): ...@@ -262,7 +260,7 @@ class GetProgramsByRunTests(TestCase):
self.assertEqual(course_ids, []) self.assertEqual(course_ids, [])
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class GetCompletedCoursesTestCase(TestCase): class GetCompletedCoursesTestCase(TestCase):
""" """
Test the get_completed_courses function Test the get_completed_courses function
...@@ -308,7 +306,7 @@ class GetCompletedCoursesTestCase(TestCase): ...@@ -308,7 +306,7 @@ class GetCompletedCoursesTestCase(TestCase):
@attr(shard=2) @attr(shard=2)
@httpretty.activate @httpretty.activate
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestProgramProgressMeter(ProgramsApiConfigMixin, TestCase): class TestProgramProgressMeter(ProgramsApiConfigMixin, TestCase):
"""Tests of the program progress utility class.""" """Tests of the program progress utility class."""
def setUp(self): def setUp(self):
...@@ -700,7 +698,7 @@ class TestProgramProgressMeter(ProgramsApiConfigMixin, TestCase): ...@@ -700,7 +698,7 @@ class TestProgramProgressMeter(ProgramsApiConfigMixin, TestCase):
@ddt.ddt @ddt.ddt
@override_settings(ECOMMERCE_PUBLIC_URL_ROOT=ECOMMERCE_URL_ROOT) @override_settings(ECOMMERCE_PUBLIC_URL_ROOT=ECOMMERCE_URL_ROOT)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@mock.patch(UTILS_MODULE + '.get_run_marketing_url', mock.Mock(return_value=MARKETING_URL)) @mock.patch(UTILS_MODULE + '.get_run_marketing_url', mock.Mock(return_value=MARKETING_URL))
class TestProgramDataExtender(ProgramsApiConfigMixin, ModuleStoreTestCase): class TestProgramDataExtender(ProgramsApiConfigMixin, ModuleStoreTestCase):
"""Tests of the program data extender utility class.""" """Tests of the program data extender utility class."""
......
...@@ -3,7 +3,6 @@ ...@@ -3,7 +3,6 @@
Test site_configuration middleware. Test site_configuration middleware.
""" """
import ddt import ddt
import unittest
from mock import patch from mock import patch
from django.conf import settings from django.conf import settings
...@@ -22,6 +21,7 @@ from microsite_configuration.tests.tests import ( ...@@ -22,6 +21,7 @@ from microsite_configuration.tests.tests import (
MICROSITE_BACKENDS, MICROSITE_BACKENDS,
) )
from openedx.core.djangoapps.site_configuration.tests.factories import SiteConfigurationFactory, SiteFactory from openedx.core.djangoapps.site_configuration.tests.factories import SiteConfigurationFactory, SiteFactory
from openedx.core.djangolib.testing.utils import skip_unless_lms
# NOTE: We set SESSION_SAVE_EVERY_REQUEST to True in order to make sure # NOTE: We set SESSION_SAVE_EVERY_REQUEST to True in order to make sure
...@@ -29,7 +29,7 @@ from openedx.core.djangoapps.site_configuration.tests.factories import SiteConfi ...@@ -29,7 +29,7 @@ from openedx.core.djangoapps.site_configuration.tests.factories import SiteConfi
# pylint: disable=no-member, protected-access # pylint: disable=no-member, protected-access
@ddt.ddt @ddt.ddt
@override_settings(SESSION_SAVE_EVERY_REQUEST=True) @override_settings(SESSION_SAVE_EVERY_REQUEST=True)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class SessionCookieDomainMicrositeOverrideTests(DatabaseMicrositeTestCase): class SessionCookieDomainMicrositeOverrideTests(DatabaseMicrositeTestCase):
""" """
Tests regarding the session cookie management in the middlware for Microsites Tests regarding the session cookie management in the middlware for Microsites
......
""" """
Tests for comprehensive theme static files finders. Tests for comprehensive theme static files finders.
""" """
import unittest
from django.conf import settings from django.conf import settings
from django.test import TestCase from django.test import TestCase
from openedx.core.djangoapps.theming.finders import ThemeFilesFinder from openedx.core.djangoapps.theming.finders import ThemeFilesFinder
from openedx.core.djangolib.testing.utils import skip_unless_lms
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestThemeFinders(TestCase): class TestThemeFinders(TestCase):
""" """
Test comprehensive theming static files finders. Test comprehensive theming static files finders.
......
""" """
Test helpers for Comprehensive Theming. Test helpers for Comprehensive Theming.
""" """
import unittest
from mock import patch, Mock from mock import patch, Mock
from django.test import TestCase, override_settings from django.test import TestCase, override_settings
...@@ -12,6 +11,7 @@ from openedx.core.djangoapps.site_configuration import helpers as configuration_ ...@@ -12,6 +11,7 @@ from openedx.core.djangoapps.site_configuration import helpers as configuration_
from openedx.core.djangoapps.theming import helpers as theming_helpers from openedx.core.djangoapps.theming import helpers as theming_helpers
from openedx.core.djangoapps.theming.helpers import get_template_path_with_theme, strip_site_theme_templates_path, \ from openedx.core.djangoapps.theming.helpers import get_template_path_with_theme, strip_site_theme_templates_path, \
get_themes, Theme, get_theme_base_dir get_themes, Theme, get_theme_base_dir
from openedx.core.djangolib.testing.utils import skip_unless_cms, skip_unless_lms
class TestHelpers(TestCase): class TestHelpers(TestCase):
...@@ -201,7 +201,7 @@ class TestHelpers(TestCase): ...@@ -201,7 +201,7 @@ class TestHelpers(TestCase):
self.assertEqual(theming_helpers.get_template_path("about.html"), "/microsite/about.html") self.assertEqual(theming_helpers.get_template_path("about.html"), "/microsite/about.html")
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestHelpersLMS(TestCase): class TestHelpersLMS(TestCase):
"""Test comprehensive theming helper functions.""" """Test comprehensive theming helper functions."""
...@@ -244,7 +244,7 @@ class TestHelpersLMS(TestCase): ...@@ -244,7 +244,7 @@ class TestHelpersLMS(TestCase):
self.assertEqual(template_path, '/red-theme/lms/templates/header.html') self.assertEqual(template_path, '/red-theme/lms/templates/header.html')
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
class TestHelpersCMS(TestCase): class TestHelpersCMS(TestCase):
"""Test comprehensive theming helper functions.""" """Test comprehensive theming helper functions."""
......
""" """
Tests for microsites and comprehensive themes. Tests for microsites and comprehensive themes.
""" """
import unittest
from django.conf import settings from django.conf import settings
from django.test import TestCase from django.test import TestCase
from django.contrib.sites.models import Site from django.contrib.sites.models import Site
from openedx.core.djangoapps.theming.models import SiteTheme from openedx.core.djangoapps.theming.models import SiteTheme
from openedx.core.djangolib.testing.utils import skip_unless_lms
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestComprehensiveThemeLMS(TestCase): class TestComprehensiveThemeLMS(TestCase):
""" """
Test html, sass and static file overrides for comprehensive themes. Test html, sass and static file overrides for comprehensive themes.
......
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
Tests for comprehensive theme static files storage classes. Tests for comprehensive theme static files storage classes.
""" """
import ddt import ddt
import unittest
import re import re
from mock import patch from mock import patch
...@@ -12,9 +11,10 @@ from django.conf import settings ...@@ -12,9 +11,10 @@ from django.conf import settings
from openedx.core.djangoapps.theming.helpers import get_theme_base_dirs, Theme, get_theme_base_dir from openedx.core.djangoapps.theming.helpers import get_theme_base_dirs, Theme, get_theme_base_dir
from openedx.core.djangoapps.theming.storage import ThemeStorage from openedx.core.djangoapps.theming.storage import ThemeStorage
from openedx.core.djangolib.testing.utils import skip_unless_lms
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
@ddt.ddt @ddt.ddt
class TestStorageLMS(TestCase): class TestStorageLMS(TestCase):
""" """
......
""" """
Tests for Themeing locales Tests for Theming locales
""" """
import os
import unittest
from django.conf import settings from django.conf import settings
from django.test import TestCase from django.test import TestCase
import os
from openedx.core.djangolib.testing.utils import skip_unless_lms
class TestComprehensiveThemeLocale(TestCase): class TestComprehensiveThemeLocale(TestCase):
""" """
Test Comprehensive Theme Locales Test Comprehensive Theme Locales
""" """
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
def test_theme_locale_path_in_settings(self): def test_theme_locale_path_in_settings(self):
""" """
test comprehensive theming paths in settings. test comprehensive theming paths in settings.
......
""" """
Tests for comprehensive themes. Tests for comprehensive themes.
""" """
import unittest
from django.conf import settings from django.conf import settings
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.test import TestCase from django.test import TestCase
from django.contrib import staticfiles from django.contrib import staticfiles
from openedx.core.djangoapps.theming.tests.test_util import with_comprehensive_theme from openedx.core.djangoapps.theming.tests.test_util import with_comprehensive_theme
from openedx.core.djangolib.testing.utils import skip_unless_cms, skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestComprehensiveThemeLMS(TestCase): class TestComprehensiveThemeLMS(TestCase):
""" """
Test html, sass and static file overrides for comprehensive themes. Test html, sass and static file overrides for comprehensive themes.
...@@ -66,7 +65,7 @@ class TestComprehensiveThemeLMS(TestCase): ...@@ -66,7 +65,7 @@ class TestComprehensiveThemeLMS(TestCase):
self.assertEqual(result, settings.TEST_THEME / 'lms/static/images/logo.png') self.assertEqual(result, settings.TEST_THEME / 'lms/static/images/logo.png')
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
class TestComprehensiveThemeCMS(TestCase): class TestComprehensiveThemeCMS(TestCase):
""" """
Test html, sass and static file overrides for comprehensive themes. Test html, sass and static file overrides for comprehensive themes.
...@@ -92,7 +91,7 @@ class TestComprehensiveThemeCMS(TestCase): ...@@ -92,7 +91,7 @@ class TestComprehensiveThemeCMS(TestCase):
self.assertContains(resp, "Login Page override for test-theme.") self.assertContains(resp, "Login Page override for test-theme.")
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestComprehensiveThemeDisabledLMS(TestCase): class TestComprehensiveThemeDisabledLMS(TestCase):
""" """
Test Sass compilation order and sass overrides for comprehensive themes. Test Sass compilation order and sass overrides for comprehensive themes.
...@@ -115,7 +114,7 @@ class TestComprehensiveThemeDisabledLMS(TestCase): ...@@ -115,7 +114,7 @@ class TestComprehensiveThemeDisabledLMS(TestCase):
self.assertEqual(result, settings.REPO_ROOT / 'lms/static/images/logo.png') self.assertEqual(result, settings.REPO_ROOT / 'lms/static/images/logo.png')
@unittest.skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in cms') @skip_unless_cms
class TestComprehensiveThemeDisabledCMS(TestCase): class TestComprehensiveThemeDisabledCMS(TestCase):
""" """
Test default html, sass and static file when no theme is applied. Test default html, sass and static file when no theme is applied.
...@@ -139,7 +138,7 @@ class TestComprehensiveThemeDisabledCMS(TestCase): ...@@ -139,7 +138,7 @@ class TestComprehensiveThemeDisabledCMS(TestCase):
self.assertNotContains(resp, "Login Page override for test-theme.") self.assertNotContains(resp, "Login Page override for test-theme.")
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestStanfordTheme(TestCase): class TestStanfordTheme(TestCase):
""" """
Test html, sass and static file overrides for stanford theme. Test html, sass and static file overrides for stanford theme.
......
...@@ -17,6 +17,7 @@ from django.conf import settings ...@@ -17,6 +17,7 @@ from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.core import mail from django.core import mail
from django.test.client import RequestFactory from django.test.client import RequestFactory
from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.models import PendingEmailChange from student.models import PendingEmailChange
from student.tests.tests import UserSettingsEventTestMixin from student.tests.tests import UserSettingsEventTestMixin
from ...errors import ( from ...errors import (
...@@ -35,7 +36,7 @@ def mock_render_to_string(template_name, context): ...@@ -35,7 +36,7 @@ def mock_render_to_string(template_name, context):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Account APIs are only supported in LMS') @skip_unless_lms
class TestAccountApi(UserSettingsEventTestMixin, TestCase): class TestAccountApi(UserSettingsEventTestMixin, TestCase):
""" """
These tests specifically cover the parts of the API methods that are not covered by test_views.py. These tests specifically cover the parts of the API methods that are not covered by test_views.py.
...@@ -239,7 +240,7 @@ class TestAccountApi(UserSettingsEventTestMixin, TestCase): ...@@ -239,7 +240,7 @@ class TestAccountApi(UserSettingsEventTestMixin, TestCase):
{'full': 50, 'small': 10}, {'full': 50, 'small': 10},
clear=True clear=True
) )
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Account APIs are only supported in LMS') @skip_unless_lms
class AccountSettingsOnCreationTest(TestCase): class AccountSettingsOnCreationTest(TestCase):
# pylint: disable=missing-docstring # pylint: disable=missing-docstring
...@@ -333,7 +334,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase): ...@@ -333,7 +334,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase):
u'a' * (PASSWORD_MAX_LENGTH + 1) u'a' * (PASSWORD_MAX_LENGTH + 1)
] ]
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
def test_activate_account(self): def test_activate_account(self):
# Create the account, which is initially inactive # Create the account, which is initially inactive
activation_key = create_account(self.USERNAME, self.PASSWORD, self.EMAIL) activation_key = create_account(self.USERNAME, self.PASSWORD, self.EMAIL)
...@@ -393,7 +394,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase): ...@@ -393,7 +394,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase):
def test_activate_account_invalid_key(self): def test_activate_account_invalid_key(self):
activate_account(u'invalid') activate_account(u'invalid')
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
def test_request_password_change(self): def test_request_password_change(self):
# Create and activate an account # Create and activate an account
activation_key = create_account(self.USERNAME, self.PASSWORD, self.EMAIL) activation_key = create_account(self.USERNAME, self.PASSWORD, self.EMAIL)
...@@ -411,7 +412,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase): ...@@ -411,7 +412,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase):
result = re.search(r'(?P<url>https?://[^\s]+)', email_body) result = re.search(r'(?P<url>https?://[^\s]+)', email_body)
self.assertIsNot(result, None) self.assertIsNot(result, None)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
def test_request_password_change_invalid_user(self): def test_request_password_change_invalid_user(self):
with self.assertRaises(UserNotFound): with self.assertRaises(UserNotFound):
request_password_change(self.EMAIL, self.ORIG_HOST, self.IS_SECURE) request_password_change(self.EMAIL, self.ORIG_HOST, self.IS_SECURE)
...@@ -419,7 +420,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase): ...@@ -419,7 +420,7 @@ class AccountCreationActivationAndPasswordChangeTest(TestCase):
# Verify that no email messages have been sent # Verify that no email messages have been sent
self.assertEqual(len(mail.outbox), 0) self.assertEqual(len(mail.outbox), 0)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS') @skip_unless_lms
def test_request_password_change_inactive_user(self): def test_request_password_change_inactive_user(self):
# Create an account, but do not activate it # Create an account, but do not activate it
create_account(self.USERNAME, self.PASSWORD, self.EMAIL) create_account(self.USERNAME, self.PASSWORD, self.EMAIL)
......
...@@ -6,13 +6,12 @@ import hashlib ...@@ -6,13 +6,12 @@ import hashlib
from mock import patch from mock import patch
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from pytz import UTC from pytz import UTC
from unittest import skipUnless
from django.conf import settings
from django.test import TestCase from django.test import TestCase
from ..image_helpers import get_profile_image_urls_for_user from openedx.core.djangolib.testing.utils import skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
from ..image_helpers import get_profile_image_urls_for_user
TEST_SIZES = {'full': 50, 'small': 10} TEST_SIZES = {'full': 50, 'small': 10}
TEST_PROFILE_IMAGE_UPLOAD_DT = datetime.datetime(2002, 1, 9, 15, 43, 01, tzinfo=UTC) TEST_PROFILE_IMAGE_UPLOAD_DT = datetime.datetime(2002, 1, 9, 15, 43, 01, tzinfo=UTC)
...@@ -20,7 +19,7 @@ TEST_PROFILE_IMAGE_UPLOAD_DT = datetime.datetime(2002, 1, 9, 15, 43, 01, tzinfo= ...@@ -20,7 +19,7 @@ TEST_PROFILE_IMAGE_UPLOAD_DT = datetime.datetime(2002, 1, 9, 15, 43, 01, tzinfo=
@attr(shard=2) @attr(shard=2)
@patch.dict('openedx.core.djangoapps.user_api.accounts.image_helpers.PROFILE_IMAGE_SIZES_MAP', TEST_SIZES, clear=True) @patch.dict('openedx.core.djangoapps.user_api.accounts.image_helpers.PROFILE_IMAGE_SIZES_MAP', TEST_SIZES, clear=True)
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class ProfileImageUrlTestCase(TestCase): class ProfileImageUrlTestCase(TestCase):
""" """
Tests for profile image URL generation helpers. Tests for profile image URL generation helpers.
......
...@@ -12,7 +12,6 @@ import json ...@@ -12,7 +12,6 @@ import json
from mock import patch from mock import patch
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from pytz import UTC from pytz import UTC
import unittest
from django.conf import settings from django.conf import settings
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
...@@ -25,7 +24,7 @@ from student.tests.factories import UserFactory ...@@ -25,7 +24,7 @@ from student.tests.factories import UserFactory
from student.models import UserProfile, LanguageProficiency, PendingEmailChange from student.models import UserProfile, LanguageProficiency, PendingEmailChange
from openedx.core.djangoapps.user_api.accounts import ACCOUNT_VISIBILITY_PREF_KEY from openedx.core.djangoapps.user_api.accounts import ACCOUNT_VISIBILITY_PREF_KEY
from openedx.core.djangoapps.user_api.preferences.api import set_user_preference from openedx.core.djangoapps.user_api.preferences.api import set_user_preference
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from .. import PRIVATE_VISIBILITY, ALL_USERS_VISIBILITY from .. import PRIVATE_VISIBILITY, ALL_USERS_VISIBILITY
TEST_PROFILE_IMAGE_UPLOADED_AT = datetime.datetime(2002, 1, 9, 15, 43, 01, tzinfo=UTC) TEST_PROFILE_IMAGE_UPLOADED_AT = datetime.datetime(2002, 1, 9, 15, 43, 01, tzinfo=UTC)
...@@ -140,7 +139,7 @@ class UserAPITestCase(APITestCase): ...@@ -140,7 +139,7 @@ class UserAPITestCase(APITestCase):
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Account APIs are only supported in LMS') @skip_unless_lms
@attr(shard=2) @attr(shard=2)
class TestOwnUsernameAPI(CacheIsolationTestCase, UserAPITestCase): class TestOwnUsernameAPI(CacheIsolationTestCase, UserAPITestCase):
""" """
...@@ -193,7 +192,7 @@ class TestOwnUsernameAPI(CacheIsolationTestCase, UserAPITestCase): ...@@ -193,7 +192,7 @@ class TestOwnUsernameAPI(CacheIsolationTestCase, UserAPITestCase):
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Account APIs are only supported in LMS') @skip_unless_lms
@patch('openedx.core.djangoapps.user_api.accounts.image_helpers._PROFILE_IMAGE_SIZES', [50, 10]) @patch('openedx.core.djangoapps.user_api.accounts.image_helpers._PROFILE_IMAGE_SIZES', [50, 10])
@patch.dict( @patch.dict(
'openedx.core.djangoapps.user_api.accounts.image_helpers.PROFILE_IMAGE_SIZES_MAP', 'openedx.core.djangoapps.user_api.accounts.image_helpers.PROFILE_IMAGE_SIZES_MAP',
...@@ -783,7 +782,7 @@ class TestAccountsAPI(CacheIsolationTestCase, UserAPITestCase): ...@@ -783,7 +782,7 @@ class TestAccountsAPI(CacheIsolationTestCase, UserAPITestCase):
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestAccountAPITransactions(TransactionTestCase): class TestAccountAPITransactions(TransactionTestCase):
""" """
Tests the transactional behavior of the account API Tests the transactional behavior of the account API
......
...@@ -6,10 +6,8 @@ import shutil ...@@ -6,10 +6,8 @@ import shutil
import csv import csv
from collections import defaultdict from collections import defaultdict
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from unittest import skipUnless
import ddt import ddt
from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.core.management.base import CommandError from django.core.management.base import CommandError
...@@ -21,11 +19,12 @@ from student.models import CourseEnrollment ...@@ -21,11 +19,12 @@ from student.models import CourseEnrollment
from openedx.core.djangoapps.user_api.preferences.api import update_email_opt_in from openedx.core.djangoapps.user_api.preferences.api import update_email_opt_in
from openedx.core.djangoapps.user_api.models import UserOrgTag from openedx.core.djangoapps.user_api.models import UserOrgTag
from openedx.core.djangoapps.user_api.management.commands import email_opt_in_list from openedx.core.djangoapps.user_api.management.commands import email_opt_in_list
from openedx.core.djangolib.testing.utils import skip_unless_lms
@attr(shard=2) @attr(shard=2)
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class EmailOptInListTest(ModuleStoreTestCase): class EmailOptInListTest(ModuleStoreTestCase):
"""Tests for the email opt-in list management command. """ """Tests for the email opt-in list management command. """
......
...@@ -4,17 +4,15 @@ Unit tests for preference APIs. ...@@ -4,17 +4,15 @@ Unit tests for preference APIs.
""" """
import datetime import datetime
import ddt import ddt
import unittest
from mock import patch from mock import patch
from nose.plugins.attrib import attr from nose.plugins.attrib import attr
from pytz import common_timezones, utc from pytz import common_timezones, utc
from django.conf import settings
from django.contrib.auth.models import User from django.contrib.auth.models import User
from django.test.utils import override_settings from django.test.utils import override_settings
from dateutil.parser import parse as parse_datetime from dateutil.parser import parse as parse_datetime
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from openedx.core.lib.time_zone_utils import get_display_time_zone from openedx.core.lib.time_zone_utils import get_display_time_zone
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
...@@ -42,7 +40,7 @@ from ...preferences.api import ( ...@@ -42,7 +40,7 @@ from ...preferences.api import (
@attr(shard=2) @attr(shard=2)
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Account APIs are only supported in LMS') @skip_unless_lms
class TestPreferenceAPI(CacheIsolationTestCase): class TestPreferenceAPI(CacheIsolationTestCase):
""" """
These tests specifically cover the parts of the API methods that are not covered by test_views.py. These tests specifically cover the parts of the API methods that are not covered by test_views.py.
......
...@@ -3,17 +3,16 @@ ...@@ -3,17 +3,16 @@
Unit tests for preference APIs. Unit tests for preference APIs.
""" """
import unittest
import ddt import ddt
import json import json
from mock import patch from mock import patch
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.conf import settings
from django.test.testcases import TransactionTestCase from django.test.testcases import TransactionTestCase
from rest_framework.test import APIClient from rest_framework.test import APIClient
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
from openedx.core.djangolib.testing.utils import skip_unless_lms
from ...accounts.tests.test_views import UserAPITestCase from ...accounts.tests.test_views import UserAPITestCase
from ..api import set_user_preference from ..api import set_user_preference
from .test_api import get_expected_validation_developer_message, get_expected_key_error_user_message from .test_api import get_expected_validation_developer_message, get_expected_key_error_user_message
...@@ -22,7 +21,7 @@ TOO_LONG_PREFERENCE_KEY = u"x" * 256 ...@@ -22,7 +21,7 @@ TOO_LONG_PREFERENCE_KEY = u"x" * 256
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestPreferencesAPI(UserAPITestCase): class TestPreferencesAPI(UserAPITestCase):
""" """
Unit tests /api/user/v1/accounts/{username}/ Unit tests /api/user/v1/accounts/{username}/
...@@ -316,7 +315,7 @@ class TestPreferencesAPI(UserAPITestCase): ...@@ -316,7 +315,7 @@ class TestPreferencesAPI(UserAPITestCase):
) )
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestPreferencesAPITransactions(TransactionTestCase): class TestPreferencesAPITransactions(TransactionTestCase):
""" """
Tests the transactional behavior of the preferences API Tests the transactional behavior of the preferences API
...@@ -363,7 +362,7 @@ class TestPreferencesAPITransactions(TransactionTestCase): ...@@ -363,7 +362,7 @@ class TestPreferencesAPITransactions(TransactionTestCase):
@ddt.ddt @ddt.ddt
@unittest.skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class TestPreferencesDetailAPI(UserAPITestCase): class TestPreferencesDetailAPI(UserAPITestCase):
""" """
Unit tests /api/user/v1/accounts/{username}/{preference_key} Unit tests /api/user/v1/accounts/{username}/{preference_key}
......
...@@ -21,7 +21,7 @@ from social.apps.django_app.default.models import UserSocialAuth ...@@ -21,7 +21,7 @@ from social.apps.django_app.default.models import UserSocialAuth
from django_comment_common import models from django_comment_common import models
from openedx.core.lib.api.test_utils import ApiTestCase, TEST_API_KEY from openedx.core.lib.api.test_utils import ApiTestCase, TEST_API_KEY
from openedx.core.lib.time_zone_utils import get_display_time_zone from openedx.core.lib.time_zone_utils import get_display_time_zone
from openedx.core.djangolib.testing.utils import CacheIsolationTestCase from openedx.core.djangolib.testing.utils import CacheIsolationTestCase, skip_unless_lms
from student.tests.factories import UserFactory from student.tests.factories import UserFactory
from third_party_auth.tests.testutil import simulate_running_pipeline, ThirdPartyAuthTestMixin from third_party_auth.tests.testutil import simulate_running_pipeline, ThirdPartyAuthTestMixin
from third_party_auth.tests.utils import ( from third_party_auth.tests.utils import (
...@@ -541,7 +541,7 @@ class PreferenceUsersListViewTest(UserApiTestCase): ...@@ -541,7 +541,7 @@ class PreferenceUsersListViewTest(UserApiTestCase):
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class LoginSessionViewTest(UserAPITestCase): class LoginSessionViewTest(UserAPITestCase):
"""Tests for the login end-points of the user API. """ """Tests for the login end-points of the user API. """
...@@ -713,7 +713,7 @@ class LoginSessionViewTest(UserAPITestCase): ...@@ -713,7 +713,7 @@ class LoginSessionViewTest(UserAPITestCase):
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class PasswordResetViewTest(UserAPITestCase): class PasswordResetViewTest(UserAPITestCase):
"""Tests of the user API's password reset endpoint. """ """Tests of the user API's password reset endpoint. """
...@@ -771,7 +771,7 @@ class PasswordResetViewTest(UserAPITestCase): ...@@ -771,7 +771,7 @@ class PasswordResetViewTest(UserAPITestCase):
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class RegistrationViewTest(ThirdPartyAuthTestMixin, UserAPITestCase): class RegistrationViewTest(ThirdPartyAuthTestMixin, UserAPITestCase):
"""Tests for the registration end-points of the User API. """ """Tests for the registration end-points of the User API. """
...@@ -1925,7 +1925,7 @@ class TestGoogleRegistrationView( ...@@ -1925,7 +1925,7 @@ class TestGoogleRegistrationView(
@ddt.ddt @ddt.ddt
@skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in lms') @skip_unless_lms
class UpdateEmailOptInTestCase(UserAPITestCase, SharedModuleStoreTestCase): class UpdateEmailOptInTestCase(UserAPITestCase, SharedModuleStoreTestCase):
"""Tests the UpdateEmailOptInPreference view. """ """Tests the UpdateEmailOptInPreference view. """
......
...@@ -9,6 +9,7 @@ Utility classes for testing django applications. ...@@ -9,6 +9,7 @@ Utility classes for testing django applications.
""" """
import copy import copy
from unittest import skipUnless
import crum import crum
from django import db from django import db
...@@ -175,3 +176,17 @@ def get_mock_request(user=None): ...@@ -175,3 +176,17 @@ def get_mock_request(user=None):
request.get_host = lambda: "edx.org" request.get_host = lambda: "edx.org"
crum.set_current_request(request) crum.set_current_request(request)
return request return request
def skip_unless_cms(func):
"""
Only run the decorated test in the CMS test suite
"""
return skipUnless(settings.ROOT_URLCONF == 'cms.urls', 'Test only valid in CMS')(func)
def skip_unless_lms(func):
"""
Only run the decorated test in the LMS test suite
"""
return skipUnless(settings.ROOT_URLCONF == 'lms.urls', 'Test only valid in LMS')(func)
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment