Skip to content

Commit

Permalink
test: fix failing tests
Browse files Browse the repository at this point in the history
  • Loading branch information
navinkarkera committed Jan 17, 2025
1 parent 14c566a commit 02a8a82
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,19 +10,28 @@
from django.utils import timezone
from freezegun import freeze_time

from openedx.core.djangolib.testing.utils import skip_unless_cms
from xmodule.modulestore.tests.django_utils import ModuleStoreTestCase
from xmodule.modulestore.tests.factories import BlockFactory, CourseFactory

from ..tasks import create_or_update_upstream_links, create_or_update_xblock_upstream_link


@skip_unless_cms
class TestRecreateUpstreamLinks(ModuleStoreTestCase):
"""
Test recreate_upstream_links management command.
"""

ENABLED_SIGNALS = ['course_deleted', 'course_published']

def setUp(self):
super().setUp()
self.now = timezone.now()
freezer = freeze_time(self.now)
freezer.start()
self.addCleanup(freezer.stop)

def call_command(self, *args, **kwargs):
"""
call command with pass args.
Expand All @@ -49,10 +58,10 @@ def test_call_for_single_course(self, mock_task):
Test command with single course argument
"""
self.call_command('--course', 'some-course')
mock_task.delay.assert_called_with('some-course', False)
mock_task.delay.assert_called_with('some-course', False, created=self.now)
# call with --force
self.call_command('--course', 'some-course', '--force')
mock_task.delay.assert_called_with('some-course', True)
mock_task.delay.assert_called_with('some-course', True, created=self.now)

@patch(
'openedx.core.djangoapps.content_libraries.management.commands.recreate_upstream_links.create_or_update_upstream_links' # pylint: disable=line-too-long
Expand All @@ -62,8 +71,8 @@ def test_call_for_multiple_course(self, mock_task):
Test command with multiple course arguments
"""
self.call_command('--course', 'some-course', '--course', 'one-more-course')
mock_task.delay.assert_any_call('some-course', False)
mock_task.delay.assert_any_call('one-more-course', False)
mock_task.delay.assert_any_call('some-course', False, created=self.now)
mock_task.delay.assert_any_call('one-more-course', False, created=self.now)

@patch(
'openedx.core.djangoapps.content_libraries.management.commands.recreate_upstream_links.create_or_update_upstream_links' # pylint: disable=line-too-long
Expand All @@ -75,10 +84,11 @@ def test_call_for_all_courses(self, mock_task):
course_key_1 = CourseFactory.create(emit_signals=True).id
course_key_2 = CourseFactory.create(emit_signals=True).id
self.call_command('--all')
mock_task.delay.assert_any_call(str(course_key_1), False)
mock_task.delay.assert_any_call(str(course_key_2), False)
mock_task.delay.assert_any_call(str(course_key_1), False, created=self.now)
mock_task.delay.assert_any_call(str(course_key_2), False, created=self.now)


@skip_unless_cms
class TestUpstreamLinksTasks(ModuleStoreTestCase):
"""
Test tasks related to managing upstream->downstream links.
Expand All @@ -105,12 +115,14 @@ def setUp(self):
category="html",
display_name="An HTML Block",
upstream=self.upstream_1,
upstream_version=1,
)
self.component_2 = BlockFactory.create(
parent=self.unit,
category="html",
display_name="Another HTML Block",
upstream=self.upstream_2,
upstream_version=1,
)
self.component_3 = BlockFactory.create(
parent=self.unit,
Expand Down
13 changes: 10 additions & 3 deletions xmodule/modulestore/tests/test_mixed_modulestore.py
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,13 @@ def setUp(self):
self.course_locations = {}

self.user_id = ModuleStoreEnum.UserID.test
# mock and ignore create_or_update_xblock_upstream_link task to avoid unnecessary
# errors as it is tested separately
create_or_update_xblock_upstream_link_patch = patch(
'openedx.core.djangoapps.content_libraries.signal_handlers.create_or_update_xblock_upstream_link'
)
create_or_update_xblock_upstream_link_patch.start()
self.addCleanup(create_or_update_xblock_upstream_link_patch.stop)

def _check_connection(self):
"""
Expand Down Expand Up @@ -1099,7 +1106,7 @@ def test_has_changes_missing_child(self, default_ms, default_branch):
# check CONTENT_TAGGING_AUTO CourseWaffleFlag
# Find: active_versions, 2 structures (published & draft), definition (unnecessary)
# Sends: updated draft and published structures and active_versions
@ddt.data((ModuleStoreEnum.Type.split, 5, 2, 3))
@ddt.data((ModuleStoreEnum.Type.split, 6, 2, 3))
@ddt.unpack
def test_delete_item(self, default_ms, num_mysql, max_find, max_send):
"""
Expand All @@ -1122,7 +1129,7 @@ def test_delete_item(self, default_ms, num_mysql, max_find, max_send):
# check CONTENT_TAGGING_AUTO CourseWaffleFlag
# find: draft and published structures, definition (unnecessary)
# sends: update published (why?), draft, and active_versions
@ddt.data((ModuleStoreEnum.Type.split, 5, 3, 3))
@ddt.data((ModuleStoreEnum.Type.split, 6, 3, 3))
@ddt.unpack
def test_delete_private_vertical(self, default_ms, num_mysql, max_find, max_send):
"""
Expand Down Expand Up @@ -1172,7 +1179,7 @@ def test_delete_private_vertical(self, default_ms, num_mysql, max_find, max_send
# check CONTENT_TAGGING_AUTO CourseWaffleFlag
# find: structure (cached)
# send: update structure and active_versions
@ddt.data((ModuleStoreEnum.Type.split, 5, 1, 2))
@ddt.data((ModuleStoreEnum.Type.split, 6, 1, 2))
@ddt.unpack
def test_delete_draft_vertical(self, default_ms, num_mysql, max_find, max_send):
"""
Expand Down

0 comments on commit 02a8a82

Please sign in to comment.