Merge pull request #8742 from edx/aj/tnl2551-randomized-problems-failing
[NEW] - Fixed randomized problems which were not appearing to work.
This commit is contained in:
@@ -41,9 +41,7 @@ class RandomizeModule(RandomizeFields, XModule):
|
||||
def __init__(self, *args, **kwargs):
|
||||
super(RandomizeModule, self).__init__(*args, **kwargs)
|
||||
|
||||
# NOTE: calling self.get_children() creates a circular reference--
|
||||
# it calls get_child_descriptors() internally, but that doesn't work until
|
||||
# we've picked a choice
|
||||
# NOTE: calling self.get_children() doesn't work until we've picked a choice
|
||||
num_choices = len(self.descriptor.get_children())
|
||||
|
||||
if self.choice > num_choices:
|
||||
@@ -59,14 +57,23 @@ class RandomizeModule(RandomizeFields, XModule):
|
||||
self.choice = random.randrange(0, num_choices)
|
||||
|
||||
if self.choice is not None:
|
||||
self.child_descriptor = self.descriptor.get_children()[self.choice]
|
||||
# Now get_children() should return a list with one element
|
||||
log.debug("children of randomize module (should be only 1): %s",
|
||||
self.get_children())
|
||||
self.child = self.get_children()[0]
|
||||
else:
|
||||
self.child_descriptor = None
|
||||
self.child = None
|
||||
log.debug("children of randomize module (should be only 1): %s", self.child)
|
||||
|
||||
@property
|
||||
def child_descriptor(self):
|
||||
""" Return descriptor of selected choice """
|
||||
if self.choice is None:
|
||||
return None
|
||||
return self.descriptor.get_children()[self.choice]
|
||||
|
||||
@property
|
||||
def child(self):
|
||||
""" Return module instance of selected choice """
|
||||
child_descriptor = self.child_descriptor
|
||||
if child_descriptor is None:
|
||||
return None
|
||||
return self.system.get_module(child_descriptor)
|
||||
|
||||
def get_child_descriptors(self):
|
||||
"""
|
||||
|
||||
@@ -1,36 +1,55 @@
|
||||
import unittest
|
||||
from datetime import datetime, timedelta
|
||||
|
||||
from django.utils.timezone import UTC
|
||||
from opaque_keys.edx.locator import BlockUsageLocator
|
||||
from xblock.fields import ScopeIds
|
||||
from xmodule.randomize_module import RandomizeModule
|
||||
|
||||
from .test_course_module import DummySystem as DummyImportSystem
|
||||
|
||||
|
||||
ORG = 'test_org'
|
||||
COURSE = 'test_course'
|
||||
|
||||
START = '2013-01-01T01:00:00'
|
||||
_TODAY = datetime.now(UTC())
|
||||
_LAST_WEEK = _TODAY - timedelta(days=7)
|
||||
_NEXT_WEEK = _TODAY + timedelta(days=7)
|
||||
|
||||
|
||||
class RandomizeModuleTestCase(unittest.TestCase):
|
||||
"""Make sure the randomize module works"""
|
||||
@staticmethod
|
||||
def get_dummy_course(start):
|
||||
|
||||
def setUp(self):
|
||||
"""
|
||||
Initialize dummy testing course.
|
||||
"""
|
||||
super(RandomizeModuleTestCase, self).setUp()
|
||||
self.system = DummyImportSystem(load_error_modules=True)
|
||||
self.system.seed = None
|
||||
self.course = self.get_dummy_course()
|
||||
self.modulestore = self.system.modulestore
|
||||
|
||||
def get_dummy_course(self, start=_TODAY):
|
||||
"""Get a dummy course"""
|
||||
|
||||
system = DummyImportSystem(load_error_modules=True)
|
||||
|
||||
start_xml = '''
|
||||
self.start_xml = '''
|
||||
<course org="{org}" course="{course}"
|
||||
graceperiod="1 day" url_name="test"
|
||||
start="{start}"
|
||||
>
|
||||
<chapter url="hi" url_name="ch" display_name="CH">
|
||||
start="{start}">
|
||||
<chapter url="ch1" url_name="chapter1" display_name="CH1">
|
||||
<randomize url_name="my_randomize">
|
||||
<html url_name="a" display_name="A">Two houses, ...</html>
|
||||
<html url_name="b" display_name="B">Three houses, ...</html>
|
||||
</randomize>
|
||||
</chapter>
|
||||
<chapter url="ch2" url_name="chapter2" display_name="CH2">
|
||||
</chapter>
|
||||
</course>
|
||||
'''.format(org=ORG, course=COURSE, start=start)
|
||||
|
||||
return system.process_xml(start_xml)
|
||||
return self.system.process_xml(self.start_xml)
|
||||
|
||||
def test_import(self):
|
||||
"""
|
||||
@@ -38,5 +57,48 @@ class RandomizeModuleTestCase(unittest.TestCase):
|
||||
"""
|
||||
self.get_dummy_course(START)
|
||||
|
||||
# TODO: add tests that create a module and check. Passing state is a good way to
|
||||
# check that child access works...
|
||||
def test_course_has_started(self):
|
||||
"""
|
||||
Test CourseDescriptor.has_started.
|
||||
"""
|
||||
self.course.start = _LAST_WEEK
|
||||
self.assertTrue(self.course.has_started())
|
||||
self.course.start = _NEXT_WEEK
|
||||
self.assertFalse(self.course.has_started())
|
||||
|
||||
def test_children(self):
|
||||
""" Check course/randomize module works fine """
|
||||
|
||||
self.assertTrue(self.course.has_children)
|
||||
self.assertEquals(len(self.course.get_children()), 2)
|
||||
|
||||
def inner_get_module(descriptor):
|
||||
"""
|
||||
Override systems.get_module
|
||||
This method will be called when any call is made to self.system.get_module
|
||||
"""
|
||||
if isinstance(descriptor, BlockUsageLocator):
|
||||
location = descriptor
|
||||
descriptor = self.modulestore.get_item(location, depth=None)
|
||||
descriptor.xmodule_runtime = self.get_dummy_course()
|
||||
descriptor.xmodule_runtime.descriptor_runtime = descriptor._runtime # pylint: disable=protected-access
|
||||
descriptor.xmodule_runtime.get_module = inner_get_module
|
||||
return descriptor
|
||||
|
||||
self.system.get_module = inner_get_module
|
||||
|
||||
# Get randomize_descriptor from the course & verify its children
|
||||
randomize_descriptor = inner_get_module(self.course.id.make_usage_key('randomize', 'my_randomize'))
|
||||
self.assertTrue(randomize_descriptor.has_children)
|
||||
self.assertEquals(len(randomize_descriptor.get_children()), 2)
|
||||
|
||||
# Call RandomizeModule which will select an element from the list of available items
|
||||
randomize_module = RandomizeModule(
|
||||
randomize_descriptor,
|
||||
self.system,
|
||||
scope_ids=ScopeIds(None, None, self.course.id, self.course.id)
|
||||
)
|
||||
|
||||
# Verify the selected child
|
||||
self.assertEquals(len(randomize_module.get_child_descriptors()), 1, "No child is chosen")
|
||||
self.assertIn(randomize_module.child.display_name, ['A', 'B'], "Unwanted child selected")
|
||||
|
||||
Reference in New Issue
Block a user