Skip to content

Commit

Permalink
fix: shuffled-index in nested shuffle-contents
Browse files Browse the repository at this point in the history
  • Loading branch information
janbritz committed Nov 28, 2024
1 parent 3e228ed commit 3d2b904
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 0 deletions.
15 changes: 15 additions & 0 deletions questionpy_sdk/webserver/question_ui/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,10 +76,25 @@ def _set_element_value(element: etree._Element, value: str, name: str, xpath: et
element.set("value", value)


def _check_shuffled_index_is_in_nested_shuffle_contents(index_element: etree._Element) -> bool:
ancestor = index_element.getparent()
while ancestor is not None and ancestor != index_element:
if f"{{{_QPY_NAMESPACE}}}shuffle-contents" in ancestor.attrib:
# The index element is in a nested shuffle-contents.
# We want it to be replaced with the index of the inner shuffle, so we ignore it for now.
return True

ancestor = ancestor.getparent()
return False


def _replace_shuffled_indices(element: etree._Element, index: int) -> None:
for index_element in _assert_element_list(
element.xpath(".//qpy:shuffled-index", namespaces={"qpy": _QPY_NAMESPACE})
):
if _check_shuffled_index_is_in_nested_shuffle_contents(index_element):
continue

format_style = index_element.get("format", "123")

if format_style == "123":
Expand Down
18 changes: 18 additions & 0 deletions tests/questionpy_sdk/webserver/test_question_ui.py
Original file line number Diff line number Diff line change
Expand Up @@ -319,6 +319,24 @@ def test_should_replace_shuffled_index(renderer: QuestionUIRenderer) -> None:
assert_html_is_equal(html, expected)


@pytest.mark.ui_file("shuffled-index-nested")
@pytest.mark.render_params(seed=42)
def test_should_replace_shuffled_index_in_nested(renderer: QuestionUIRenderer) -> None:
expected = """
<div>
<p><span>i</span>. B</p>
<p><span>ii</span>. A</p>
<div>
<p><span>i</span>. D</p>
<p><span>ii</span>. C</p>
</div>
</div>
"""
html, errors = renderer.render()
assert len(errors) == 0
assert_html_is_equal(html, expected)


@pytest.mark.render_params(
xml="""
<div xmlns:qpy="http://questionpy.org/ns/question">
Expand Down

0 comments on commit 3d2b904

Please sign in to comment.