Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
edx-platform
Commits
3a8f591f
Commit
3a8f591f
authored
Jun 24, 2013
by
Peter Baratta
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add tests for the diff coverage; fix one hidden unicode bug
parent
7db93976
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
83 additions
and
4 deletions
+83
-4
common/lib/xmodule/xmodule/capa_module.py
+1
-1
common/lib/xmodule/xmodule/tests/test_capa_module.py
+82
-3
No files found.
common/lib/xmodule/xmodule/capa_module.py
View file @
3a8f591f
...
...
@@ -412,7 +412,7 @@ class CapaModule(CapaFields, XModule):
`err` is the Exception encountered while rendering the problem HTML.
"""
log
.
exception
(
err
)
log
.
exception
(
err
.
message
)
# TODO (vshnayder): another switch on DEBUG.
if
self
.
system
.
DEBUG
:
...
...
common/lib/xmodule/xmodule/tests/test_capa_module.py
View file @
3a8f591f
...
...
@@ -11,11 +11,12 @@ import datetime
from
mock
import
Mock
,
patch
import
unittest
import
random
import
json
import
xmodule
from
capa.responsetypes
import
StudentInputError
,
\
LoncapaProblemError
,
ResponseError
from
xmodule.capa_module
import
CapaModule
from
capa.responsetypes
import
(
StudentInputError
,
LoncapaProblemError
,
ResponseError
)
from
xmodule.capa_module
import
CapaModule
,
ComplexEncoder
from
xmodule.modulestore
import
Location
from
django.http
import
QueryDict
...
...
@@ -530,6 +531,32 @@ class CapaModuleTest(unittest.TestCase):
# Expect that the number of attempts is NOT incremented
self
.
assertEqual
(
module
.
attempts
,
1
)
def
test_check_problem_other_errors
(
self
):
"""
Test that errors other than the expected kinds give an appropriate message.
See also `test_check_problem_error` for the "expected kinds" or errors.
"""
# Create the module
module
=
CapaFactory
.
create
(
attempts
=
1
)
# Ensure that the user is NOT staff
module
.
system
.
user_is_staff
=
False
# Ensure that DEBUG is on
module
.
system
.
DEBUG
=
True
# Simulate answering a problem that raises the exception
with
patch
(
'capa.capa_problem.LoncapaProblem.grade_answers'
)
as
mock_grade
:
error_msg
=
u"Superterrible error happened: ☠"
mock_grade
.
side_effect
=
Exception
(
error_msg
)
get_request_dict
=
{
CapaFactory
.
input_key
():
'3.14'
}
result
=
module
.
check_problem
(
get_request_dict
)
# Expect an AJAX alert message in 'success'
self
.
assertTrue
(
error_msg
in
result
[
'success'
])
def
test_check_problem_error_nonascii
(
self
):
# Try each exception that capa_module should handle
...
...
@@ -1059,6 +1086,33 @@ class CapaModuleTest(unittest.TestCase):
# Expect that the module has created a new dummy problem with the error
self
.
assertNotEqual
(
original_problem
,
module
.
lcp
)
def
test_get_problem_html_error_w_debug
(
self
):
"""
Test the html response when an error occurs with DEBUG on
"""
module
=
CapaFactory
.
create
()
# Simulate throwing an exception when the capa problem
# is asked to render itself as HTML
error_msg
=
u"Superterrible error happened: ☠"
module
.
lcp
.
get_html
=
Mock
(
side_effect
=
Exception
(
error_msg
))
# Stub out the get_test_system rendering function
module
.
system
.
render_template
=
Mock
(
return_value
=
"<div>Test Template HTML</div>"
)
# Make sure DEBUG is on
module
.
system
.
DEBUG
=
True
# Try to render the module with DEBUG turned on
html
=
module
.
get_problem_html
()
self
.
assertTrue
(
html
is
not
None
)
# Check the rendering context
render_args
,
_
=
module
.
system
.
render_template
.
call_args
context
=
render_args
[
1
]
self
.
assertTrue
(
error_msg
in
context
[
'problem'
][
'html'
])
def
test_random_seed_no_change
(
self
):
# Run the test for each possible rerandomize value
...
...
@@ -1164,3 +1218,28 @@ class CapaModuleTest(unittest.TestCase):
for
i
in
range
(
200
):
module
=
CapaFactory
.
create
(
rerandomize
=
rerandomize
)
assert
0
<=
module
.
seed
<
1000
@patch
(
'xmodule.capa_module.log'
)
@patch
(
'xmodule.capa_module.Progress'
)
def
test_get_progress_error
(
self
,
mock_progress
,
mock_log
):
"""
Check that an exception given in `Progress` produces a `log.exception` call.
"""
error_types
=
[
TypeError
,
ValueError
]
for
error_type
in
error_types
:
mock_progress
.
side_effect
=
error_type
module
=
CapaFactory
.
create
()
self
.
assertIsNone
(
module
.
get_progress
())
mock_log
.
exception
.
assert_called_once_with
(
'Got bad progress'
)
mock_log
.
reset_mock
()
class
ComplexEncoderTest
(
unittest
.
TestCase
):
def
test_default
(
self
):
"""
Check that complex numbers can be encoded into JSON.
"""
complex_num
=
1
-
1
j
expected_str
=
'1-1*j'
json_str
=
json
.
dumps
(
complex_num
,
cls
=
ComplexEncoder
)
self
.
assertEqual
(
expected_str
,
json_str
[
1
:
-
1
])
# ignore quotes
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment