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
3bd2b082
Commit
3bd2b082
authored
Jun 12, 2013
by
Brian Wilson
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
factor out InstructorTaskTestCase base class, for reuse in test_tasks.
parent
a0dcc97e
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
199 additions
and
175 deletions
+199
-175
lms/djangoapps/instructor_task/tests/test_api.py
+1
-1
lms/djangoapps/instructor_task/tests/test_base.py
+142
-0
lms/djangoapps/instructor_task/tests/test_integration.py
+56
-174
No files found.
lms/djangoapps/instructor_task/tests/test_api.py
View file @
3bd2b082
"""
"""
Test for LMS
courseware
background task queue management
Test for LMS
instructor
background task queue management
"""
"""
import
logging
import
logging
import
json
import
json
...
...
lms/djangoapps/instructor_task/tests/test_base.py
0 → 100644
View file @
3bd2b082
"""
Integration Test for LMS instructor-initiated background tasks
Runs tasks on answers to course problems to validate that code
paths actually work.
"""
import
logging
import
json
from
mock
import
Mock
from
django.contrib.auth.models
import
User
from
django.test.utils
import
override_settings
from
capa.tests.response_xml_factory
import
OptionResponseXMLFactory
from
xmodule.modulestore.django
import
modulestore
from
xmodule.modulestore.tests.factories
import
CourseFactory
,
ItemFactory
from
xmodule.modulestore.tests.django_utils
import
ModuleStoreTestCase
from
student.tests.factories
import
CourseEnrollmentFactory
,
UserFactory
,
AdminFactory
from
courseware.model_data
import
StudentModule
from
courseware.tests.tests
import
LoginEnrollmentTestCase
,
TEST_DATA_MONGO_MODULESTORE
from
instructor_task.views
import
instructor_task_status
log
=
logging
.
getLogger
(
__name__
)
TEST_COURSE_ORG
=
'edx'
TEST_COURSE_NAME
=
'Test Course'
TEST_COURSE_NUMBER
=
'1.23x'
TEST_SECTION_NAME
=
"Problem"
@override_settings
(
MODULESTORE
=
TEST_DATA_MONGO_MODULESTORE
)
class
InstructorTaskTestCase
(
LoginEnrollmentTestCase
,
ModuleStoreTestCase
):
"""
Test that all students' answers to a problem can be rescored after the
definition of the problem has been redefined.
"""
course
=
None
current_user
=
None
def
initialize_course
(
self
):
"""Create a course in the store, with a chapter and section."""
self
.
module_store
=
modulestore
()
# Create the course
self
.
course
=
CourseFactory
.
create
(
org
=
TEST_COURSE_ORG
,
number
=
TEST_COURSE_NUMBER
,
display_name
=
TEST_COURSE_NAME
)
# Add a chapter to the course
chapter
=
ItemFactory
.
create
(
parent_location
=
self
.
course
.
location
,
display_name
=
TEST_SECTION_NAME
)
# add a sequence to the course to which the problems can be added
self
.
problem_section
=
ItemFactory
.
create
(
parent_location
=
chapter
.
location
,
template
=
'i4x://edx/templates/sequential/Empty'
,
display_name
=
TEST_SECTION_NAME
)
@staticmethod
def
get_user_email
(
username
):
"""Generate email address based on username"""
return
'{0}@test.com'
.
format
(
username
)
def
login_username
(
self
,
username
):
"""Login the user, given the `username`."""
self
.
login
(
InstructorTaskTestCase
.
get_user_email
(
username
),
"test"
)
self
.
current_user
=
username
def
_create_user
(
self
,
username
,
is_staff
=
False
):
"""Creates a user and enrolls them in the test course."""
email
=
InstructorTaskTestCase
.
get_user_email
(
username
)
if
(
is_staff
):
AdminFactory
.
create
(
username
=
username
,
email
=
email
)
else
:
UserFactory
.
create
(
username
=
username
,
email
=
email
)
thisuser
=
User
.
objects
.
get
(
username
=
username
)
CourseEnrollmentFactory
.
create
(
user
=
thisuser
,
course_id
=
self
.
course
.
id
)
return
thisuser
def
create_instructor
(
self
,
username
):
"""Creates an instructor for the test course."""
return
self
.
_create_user
(
username
,
is_staff
=
True
)
def
create_student
(
self
,
username
):
"""Creates a student for the test course."""
return
self
.
_create_user
(
username
,
is_staff
=
False
)
@staticmethod
def
problem_location
(
problem_url_name
):
"""
Create an internal location for a test problem.
"""
if
"i4x:"
in
problem_url_name
:
return
problem_url_name
else
:
return
"i4x://{org}/{number}/problem/{problem_url_name}"
.
format
(
org
=
TEST_COURSE_ORG
,
number
=
TEST_COURSE_NUMBER
,
problem_url_name
=
problem_url_name
)
def
define_option_problem
(
self
,
problem_url_name
):
"""Create the problem definition so the answer is Option 1"""
factory
=
OptionResponseXMLFactory
()
factory_args
=
{
'question_text'
:
'The correct answer is Option 1'
,
'options'
:
[
'Option 1'
,
'Option 2'
],
'correct_option'
:
'Option 1'
,
'num_responses'
:
2
}
problem_xml
=
factory
.
build_xml
(
**
factory_args
)
ItemFactory
.
create
(
parent_location
=
self
.
problem_section
.
location
,
template
=
"i4x://edx/templates/problem/Blank_Common_Problem"
,
display_name
=
str
(
problem_url_name
),
data
=
problem_xml
)
def
redefine_option_problem
(
self
,
problem_url_name
):
"""Change the problem definition so the answer is Option 2"""
factory
=
OptionResponseXMLFactory
()
factory_args
=
{
'question_text'
:
'The correct answer is Option 2'
,
'options'
:
[
'Option 1'
,
'Option 2'
],
'correct_option'
:
'Option 2'
,
'num_responses'
:
2
}
problem_xml
=
factory
.
build_xml
(
**
factory_args
)
location
=
InstructorTaskTestCase
.
problem_location
(
problem_url_name
)
self
.
module_store
.
update_item
(
location
,
problem_xml
)
def
get_student_module
(
self
,
username
,
descriptor
):
"""Get StudentModule object for test course, given the `username` and the problem's `descriptor`."""
return
StudentModule
.
objects
.
get
(
course_id
=
self
.
course
.
id
,
student
=
User
.
objects
.
get
(
username
=
username
),
module_type
=
descriptor
.
location
.
category
,
module_state_key
=
descriptor
.
location
.
url
(),
)
def
get_task_status
(
self
,
task_id
):
"""Use api method to fetch task status, using mock request."""
mock_request
=
Mock
()
mock_request
.
REQUEST
=
{
'task_id'
:
task_id
}
response
=
instructor_task_status
(
mock_request
)
status
=
json
.
loads
(
response
.
content
)
return
status
lms/djangoapps/instructor_task/tests/test_integration.py
View file @
3bd2b082
"""
"""
Integration Test for LMS instructor-initiated background tasks
Integration Test
s
for LMS instructor-initiated background tasks
Runs tasks on answers to course problems to validate that code
Runs tasks on answers to course problems to validate that code
paths actually work.
paths actually work.
...
@@ -13,144 +13,26 @@ import textwrap
...
@@ -13,144 +13,26 @@ import textwrap
from
celery.states
import
SUCCESS
,
FAILURE
from
celery.states
import
SUCCESS
,
FAILURE
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.utils
import
override_settings
from
capa.tests.response_xml_factory
import
(
OptionResponseXMLFactory
,
from
capa.tests.response_xml_factory
import
(
CodeResponseXMLFactory
,
CodeResponseXMLFactory
,
CustomResponseXMLFactory
)
CustomResponseXMLFactory
)
from
xmodule.modulestore.django
import
modulestore
from
xmodule.modulestore.tests.factories
import
ItemFactory
from
xmodule.modulestore.tests.factories
import
CourseFactory
,
ItemFactory
from
xmodule.modulestore.tests.django_utils
import
ModuleStoreTestCase
from
xmodule.modulestore.exceptions
import
ItemNotFoundError
from
xmodule.modulestore.exceptions
import
ItemNotFoundError
from
student.tests.factories
import
CourseEnrollmentFactory
,
UserFactory
,
AdminFactory
from
courseware.model_data
import
StudentModule
from
courseware.model_data
import
StudentModule
from
courseware.tests.tests
import
LoginEnrollmentTestCase
,
TEST_DATA_MONGO_MODULESTORE
from
instructor_task.api
import
(
submit_rescore_problem_for_all_students
,
from
instructor_task.api
import
(
submit_rescore_problem_for_all_students
,
submit_rescore_problem_for_student
,
submit_rescore_problem_for_student
,
submit_reset_problem_attempts_for_all_students
,
submit_reset_problem_attempts_for_all_students
,
submit_delete_problem_state_for_all_students
)
submit_delete_problem_state_for_all_students
)
from
instructor_task.models
import
InstructorTask
from
instructor_task.models
import
InstructorTask
from
instructor_task.
views
import
instructor_task_status
from
instructor_task.
tests.test_base
import
InstructorTaskTestCase
,
TEST_COURSE_ORG
,
TEST_COURSE_NUMBER
log
=
logging
.
getLogger
(
__name__
)
log
=
logging
.
getLogger
(
__name__
)
TEST_COURSE_ORG
=
'edx'
class
TestIntegrationTask
(
InstructorTaskTestCase
):
TEST_COURSE_NAME
=
'Test Course'
TEST_COURSE_NUMBER
=
'1.23x'
TEST_SECTION_NAME
=
"Problem"
@override_settings
(
MODULESTORE
=
TEST_DATA_MONGO_MODULESTORE
)
class
TestRescoringBase
(
LoginEnrollmentTestCase
,
ModuleStoreTestCase
):
"""
Test that all students' answers to a problem can be rescored after the
definition of the problem has been redefined.
"""
course
=
None
current_user
=
None
def
initialize_course
(
self
):
"""Create a course in the store, with a chapter and section."""
self
.
module_store
=
modulestore
()
# Create the course
self
.
course
=
CourseFactory
.
create
(
org
=
TEST_COURSE_ORG
,
number
=
TEST_COURSE_NUMBER
,
display_name
=
TEST_COURSE_NAME
)
# Add a chapter to the course
chapter
=
ItemFactory
.
create
(
parent_location
=
self
.
course
.
location
,
display_name
=
TEST_SECTION_NAME
)
# add a sequence to the course to which the problems can be added
self
.
problem_section
=
ItemFactory
.
create
(
parent_location
=
chapter
.
location
,
template
=
'i4x://edx/templates/sequential/Empty'
,
display_name
=
TEST_SECTION_NAME
)
@staticmethod
def
get_user_email
(
username
):
"""Generate email address based on username"""
return
'{0}@test.com'
.
format
(
username
)
def
login_username
(
self
,
username
):
"""Login the user, given the `username`."""
self
.
login
(
TestRescoringBase
.
get_user_email
(
username
),
"test"
)
self
.
current_user
=
username
def
_create_user
(
self
,
username
,
is_staff
=
False
):
"""Creates a user and enrolls them in the test course."""
email
=
TestRescoringBase
.
get_user_email
(
username
)
if
(
is_staff
):
AdminFactory
.
create
(
username
=
username
,
email
=
email
)
else
:
UserFactory
.
create
(
username
=
username
,
email
=
email
)
thisuser
=
User
.
objects
.
get
(
username
=
username
)
CourseEnrollmentFactory
.
create
(
user
=
thisuser
,
course_id
=
self
.
course
.
id
)
return
thisuser
def
create_instructor
(
self
,
username
):
"""Creates an instructor for the test course."""
return
self
.
_create_user
(
username
,
is_staff
=
True
)
def
create_student
(
self
,
username
):
"""Creates a student for the test course."""
return
self
.
_create_user
(
username
,
is_staff
=
False
)
@staticmethod
def
problem_location
(
problem_url_name
):
"""
Create an internal location for a test problem.
"""
if
"i4x:"
in
problem_url_name
:
return
problem_url_name
else
:
return
"i4x://{org}/{number}/problem/{problem_url_name}"
.
format
(
org
=
TEST_COURSE_ORG
,
number
=
TEST_COURSE_NUMBER
,
problem_url_name
=
problem_url_name
)
def
define_option_problem
(
self
,
problem_url_name
):
"""Create the problem definition so the answer is Option 1"""
factory
=
OptionResponseXMLFactory
()
factory_args
=
{
'question_text'
:
'The correct answer is Option 1'
,
'options'
:
[
'Option 1'
,
'Option 2'
],
'correct_option'
:
'Option 1'
,
'num_responses'
:
2
}
problem_xml
=
factory
.
build_xml
(
**
factory_args
)
ItemFactory
.
create
(
parent_location
=
self
.
problem_section
.
location
,
template
=
"i4x://edx/templates/problem/Blank_Common_Problem"
,
display_name
=
str
(
problem_url_name
),
data
=
problem_xml
)
def
redefine_option_problem
(
self
,
problem_url_name
):
"""Change the problem definition so the answer is Option 2"""
factory
=
OptionResponseXMLFactory
()
factory_args
=
{
'question_text'
:
'The correct answer is Option 2'
,
'options'
:
[
'Option 1'
,
'Option 2'
],
'correct_option'
:
'Option 2'
,
'num_responses'
:
2
}
problem_xml
=
factory
.
build_xml
(
**
factory_args
)
location
=
TestRescoring
.
problem_location
(
problem_url_name
)
self
.
module_store
.
update_item
(
location
,
problem_xml
)
def
render_problem
(
self
,
username
,
problem_url_name
):
"""
Use ajax interface to request html for a problem.
"""
# make sure that the requested user is logged in, so that the ajax call works
# on the right problem:
if
self
.
current_user
!=
username
:
self
.
login_username
(
username
)
# make ajax call:
modx_url
=
reverse
(
'modx_dispatch'
,
kwargs
=
{
'course_id'
:
self
.
course
.
id
,
'location'
:
TestRescoring
.
problem_location
(
problem_url_name
),
'dispatch'
:
'problem_get'
,
})
resp
=
self
.
client
.
post
(
modx_url
,
{})
return
resp
def
submit_student_answer
(
self
,
username
,
problem_url_name
,
responses
):
def
submit_student_answer
(
self
,
username
,
problem_url_name
,
responses
):
"""
"""
...
@@ -171,7 +53,7 @@ class TestRescoringBase(LoginEnrollmentTestCase, ModuleStoreTestCase):
...
@@ -171,7 +53,7 @@ class TestRescoringBase(LoginEnrollmentTestCase, ModuleStoreTestCase):
# make ajax call:
# make ajax call:
modx_url
=
reverse
(
'modx_dispatch'
,
modx_url
=
reverse
(
'modx_dispatch'
,
kwargs
=
{
'course_id'
:
self
.
course
.
id
,
kwargs
=
{
'course_id'
:
self
.
course
.
id
,
'location'
:
TestRescoring
.
problem_location
(
problem_url_name
),
'location'
:
InstructorTaskTestCase
.
problem_location
(
problem_url_name
),
'dispatch'
:
'problem_check'
,
})
'dispatch'
:
'problem_check'
,
})
resp
=
self
.
client
.
post
(
modx_url
,
{
resp
=
self
.
client
.
post
(
modx_url
,
{
...
@@ -189,29 +71,34 @@ class TestRescoringBase(LoginEnrollmentTestCase, ModuleStoreTestCase):
...
@@ -189,29 +71,34 @@ class TestRescoringBase(LoginEnrollmentTestCase, ModuleStoreTestCase):
request
.
is_secure
=
Mock
(
return_value
=
False
)
request
.
is_secure
=
Mock
(
return_value
=
False
)
return
request
return
request
def
submit_rescore_all_student_answers
(
self
,
instructor
,
problem_url_name
):
"""Submits the particular problem for rescoring"""
return
submit_rescore_problem_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
TestRescoringBase
.
problem_location
(
problem_url_name
))
def
submit_rescore_one_student_answer
(
self
,
instructor
,
problem_url_name
,
student
):
class
TestRescoringTask
(
TestIntegrationTask
):
"""Submits the particular problem for rescoring for a particular student"""
"""Test rescoring problems in a background task."""
return
submit_rescore_problem_for_student
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
TestRescoringBase
.
problem_location
(
problem_url_name
),
student
)
def
rescore_all_student_answers
(
self
,
instructor
,
problem_url_name
):
def
setUp
(
self
):
"""Runs the task to rescore the current problem"""
self
.
initialize_course
()
return
submit_rescore_problem_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
self
.
create_instructor
(
'instructor'
)
TestRescoringBase
.
problem_location
(
problem_url_name
))
self
.
create_student
(
'u1'
)
self
.
create_student
(
'u2'
)
self
.
create_student
(
'u3'
)
self
.
create_student
(
'u4'
)
self
.
logout
()
def
get_student_module
(
self
,
username
,
descriptor
):
def
render_problem
(
self
,
username
,
problem_url_name
):
"""Get StudentModule object for test course, given the `username` and the problem's `descriptor`."""
"""
return
StudentModule
.
objects
.
get
(
course_id
=
self
.
course
.
id
,
Use ajax interface to request html for a problem.
student
=
User
.
objects
.
get
(
username
=
username
),
"""
module_type
=
descriptor
.
location
.
category
,
# make sure that the requested user is logged in, so that the ajax call works
module_state_key
=
descriptor
.
location
.
url
(),
# on the right problem:
)
if
self
.
current_user
!=
username
:
self
.
login_username
(
username
)
# make ajax call:
modx_url
=
reverse
(
'modx_dispatch'
,
kwargs
=
{
'course_id'
:
self
.
course
.
id
,
'location'
:
InstructorTaskTestCase
.
problem_location
(
problem_url_name
),
'dispatch'
:
'problem_get'
,
})
resp
=
self
.
client
.
post
(
modx_url
,
{})
return
resp
def
check_state
(
self
,
username
,
descriptor
,
expected_score
,
expected_max_score
,
expected_attempts
):
def
check_state
(
self
,
username
,
descriptor
,
expected_score
,
expected_max_score
,
expected_attempts
):
"""
"""
...
@@ -233,33 +120,28 @@ class TestRescoringBase(LoginEnrollmentTestCase, ModuleStoreTestCase):
...
@@ -233,33 +120,28 @@ class TestRescoringBase(LoginEnrollmentTestCase, ModuleStoreTestCase):
self
.
assertGreater
(
len
(
state
[
'correct_map'
]),
0
)
self
.
assertGreater
(
len
(
state
[
'correct_map'
]),
0
)
self
.
assertGreater
(
len
(
state
[
'student_answers'
]),
0
)
self
.
assertGreater
(
len
(
state
[
'student_answers'
]),
0
)
def
get_task_status
(
self
,
task_id
):
def
submit_rescore_all_student_answers
(
self
,
instructor
,
problem_url_name
):
"""Use api method to fetch task status, using mock request."""
"""Submits the particular problem for rescoring"""
mock_request
=
Mock
()
return
submit_rescore_problem_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
mock_request
.
REQUEST
=
{
'task_id'
:
task_id
}
InstructorTaskTestCase
.
problem_location
(
problem_url_name
))
response
=
instructor_task_status
(
mock_request
)
status
=
json
.
loads
(
response
.
content
)
return
status
class
TestRescoring
(
TestRescoringBase
):
def
submit_rescore_one_student_answer
(
self
,
instructor
,
problem_url_name
,
student
):
"""Test rescoring problems in a background task."""
"""Submits the particular problem for rescoring for a particular student"""
return
submit_rescore_problem_for_student
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
InstructorTaskTestCase
.
problem_location
(
problem_url_name
),
student
)
def
setUp
(
self
):
def
rescore_all_student_answers
(
self
,
instructor
,
problem_url_name
):
self
.
initialize_course
()
"""Runs the task to rescore the current problem"""
self
.
create_instructor
(
'instructor'
)
return
submit_rescore_problem_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
self
.
create_student
(
'u1'
)
InstructorTaskTestCase
.
problem_location
(
problem_url_name
))
self
.
create_student
(
'u2'
)
self
.
create_student
(
'u3'
)
self
.
create_student
(
'u4'
)
self
.
logout
()
def
test_rescoring_option_problem
(
self
):
def
test_rescoring_option_problem
(
self
):
'''Run rescore scenario on option problem'''
'''Run rescore scenario on option problem'''
# get descriptor:
# get descriptor:
problem_url_name
=
'H1P1'
problem_url_name
=
'H1P1'
self
.
define_option_problem
(
problem_url_name
)
self
.
define_option_problem
(
problem_url_name
)
location
=
TestRescoring
.
problem_location
(
problem_url_name
)
location
=
InstructorTaskTestCase
.
problem_location
(
problem_url_name
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
# first store answers for each of the separate users:
# first store answers for each of the separate users:
...
@@ -312,7 +194,7 @@ class TestRescoring(TestRescoringBase):
...
@@ -312,7 +194,7 @@ class TestRescoring(TestRescoringBase):
self
.
assertEqual
(
instructor_task
.
task_type
,
'rescore_problem'
)
self
.
assertEqual
(
instructor_task
.
task_type
,
'rescore_problem'
)
task_input
=
json
.
loads
(
instructor_task
.
task_input
)
task_input
=
json
.
loads
(
instructor_task
.
task_input
)
self
.
assertFalse
(
'student'
in
task_input
)
self
.
assertFalse
(
'student'
in
task_input
)
self
.
assertEqual
(
task_input
[
'problem_url'
],
TestRescoring
.
problem_location
(
problem_url_name
))
self
.
assertEqual
(
task_input
[
'problem_url'
],
InstructorTaskTestCase
.
problem_location
(
problem_url_name
))
status
=
json
.
loads
(
instructor_task
.
task_output
)
status
=
json
.
loads
(
instructor_task
.
task_output
)
self
.
assertEqual
(
status
[
'exception'
],
'ZeroDivisionError'
)
self
.
assertEqual
(
status
[
'exception'
],
'ZeroDivisionError'
)
self
.
assertEqual
(
status
[
'message'
],
expected_message
)
self
.
assertEqual
(
status
[
'message'
],
expected_message
)
...
@@ -395,7 +277,7 @@ class TestRescoring(TestRescoringBase):
...
@@ -395,7 +277,7 @@ class TestRescoring(TestRescoringBase):
"""
)
"""
)
problem_xml
=
factory
.
build_xml
(
script
=
script
,
cfn
=
"check_func"
,
expect
=
"42"
,
num_responses
=
1
)
problem_xml
=
factory
.
build_xml
(
script
=
script
,
cfn
=
"check_func"
,
expect
=
"42"
,
num_responses
=
1
)
if
redefine
:
if
redefine
:
self
.
module_store
.
update_item
(
TestRescoringB
ase
.
problem_location
(
problem_url_name
),
problem_xml
)
self
.
module_store
.
update_item
(
InstructorTaskTestC
ase
.
problem_location
(
problem_url_name
),
problem_xml
)
else
:
else
:
# Use "per-student" rerandomization so that check-problem can be called more than once.
# Use "per-student" rerandomization so that check-problem can be called more than once.
# Using "always" means we cannot check a problem twice, but we want to call once to get the
# Using "always" means we cannot check a problem twice, but we want to call once to get the
...
@@ -413,7 +295,7 @@ class TestRescoring(TestRescoringBase):
...
@@ -413,7 +295,7 @@ class TestRescoring(TestRescoringBase):
# First define the custom response problem:
# First define the custom response problem:
problem_url_name
=
'H1P1'
problem_url_name
=
'H1P1'
self
.
define_randomized_custom_response_problem
(
problem_url_name
)
self
.
define_randomized_custom_response_problem
(
problem_url_name
)
location
=
TestRescoring
.
problem_location
(
problem_url_name
)
location
=
InstructorTaskTestCase
.
problem_location
(
problem_url_name
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
# run with more than one user
# run with more than one user
userlist
=
[
'u1'
,
'u2'
,
'u3'
,
'u4'
]
userlist
=
[
'u1'
,
'u2'
,
'u3'
,
'u4'
]
...
@@ -459,7 +341,7 @@ class TestRescoring(TestRescoringBase):
...
@@ -459,7 +341,7 @@ class TestRescoring(TestRescoringBase):
self
.
check_state
(
username
,
descriptor
,
0
,
1
,
2
)
self
.
check_state
(
username
,
descriptor
,
0
,
1
,
2
)
class
TestResetAttempts
(
TestRescoringBase
):
class
TestResetAttempts
Task
(
TestIntegrationTask
):
"""Test resetting problem attempts in a background task."""
"""Test resetting problem attempts in a background task."""
userlist
=
[
'u1'
,
'u2'
,
'u3'
,
'u4'
]
userlist
=
[
'u1'
,
'u2'
,
'u3'
,
'u4'
]
...
@@ -479,14 +361,14 @@ class TestResetAttempts(TestRescoringBase):
...
@@ -479,14 +361,14 @@ class TestResetAttempts(TestRescoringBase):
def
reset_problem_attempts
(
self
,
instructor
,
problem_url_name
):
def
reset_problem_attempts
(
self
,
instructor
,
problem_url_name
):
"""Submits the current problem for resetting"""
"""Submits the current problem for resetting"""
return
submit_reset_problem_attempts_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
return
submit_reset_problem_attempts_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
TestRescoringB
ase
.
problem_location
(
problem_url_name
))
InstructorTaskTestC
ase
.
problem_location
(
problem_url_name
))
def
test_reset_attempts_on_problem
(
self
):
def
test_reset_attempts_on_problem
(
self
):
'''Run reset-attempts scenario on option problem'''
'''Run reset-attempts scenario on option problem'''
# get descriptor:
# get descriptor:
problem_url_name
=
'H1P1'
problem_url_name
=
'H1P1'
self
.
define_option_problem
(
problem_url_name
)
self
.
define_option_problem
(
problem_url_name
)
location
=
TestRescoringB
ase
.
problem_location
(
problem_url_name
)
location
=
InstructorTaskTestC
ase
.
problem_location
(
problem_url_name
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
num_attempts
=
3
num_attempts
=
3
# first store answers for each of the separate users:
# first store answers for each of the separate users:
...
@@ -520,7 +402,7 @@ class TestResetAttempts(TestRescoringBase):
...
@@ -520,7 +402,7 @@ class TestResetAttempts(TestRescoringBase):
self
.
assertEqual
(
instructor_task
.
task_type
,
'reset_problem_attempts'
)
self
.
assertEqual
(
instructor_task
.
task_type
,
'reset_problem_attempts'
)
task_input
=
json
.
loads
(
instructor_task
.
task_input
)
task_input
=
json
.
loads
(
instructor_task
.
task_input
)
self
.
assertFalse
(
'student'
in
task_input
)
self
.
assertFalse
(
'student'
in
task_input
)
self
.
assertEqual
(
task_input
[
'problem_url'
],
TestRescoring
.
problem_location
(
problem_url_name
))
self
.
assertEqual
(
task_input
[
'problem_url'
],
TestRescoring
Task
.
problem_location
(
problem_url_name
))
status
=
json
.
loads
(
instructor_task
.
task_output
)
status
=
json
.
loads
(
instructor_task
.
task_output
)
self
.
assertEqual
(
status
[
'exception'
],
'ZeroDivisionError'
)
self
.
assertEqual
(
status
[
'exception'
],
'ZeroDivisionError'
)
self
.
assertEqual
(
status
[
'message'
],
expected_message
)
self
.
assertEqual
(
status
[
'message'
],
expected_message
)
...
@@ -543,7 +425,7 @@ class TestResetAttempts(TestRescoringBase):
...
@@ -543,7 +425,7 @@ class TestResetAttempts(TestRescoringBase):
self
.
reset_problem_attempts
(
'instructor'
,
problem_url_name
)
self
.
reset_problem_attempts
(
'instructor'
,
problem_url_name
)
class
TestDeleteProblem
(
TestRescoringBase
):
class
TestDeleteProblem
Task
(
TestIntegrationTask
):
"""Test deleting problem state in a background task."""
"""Test deleting problem state in a background task."""
userlist
=
[
'u1'
,
'u2'
,
'u3'
,
'u4'
]
userlist
=
[
'u1'
,
'u2'
,
'u3'
,
'u4'
]
...
@@ -557,14 +439,14 @@ class TestDeleteProblem(TestRescoringBase):
...
@@ -557,14 +439,14 @@ class TestDeleteProblem(TestRescoringBase):
def
delete_problem_state
(
self
,
instructor
,
problem_url_name
):
def
delete_problem_state
(
self
,
instructor
,
problem_url_name
):
"""Submits the current problem for deletion"""
"""Submits the current problem for deletion"""
return
submit_delete_problem_state_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
return
submit_delete_problem_state_for_all_students
(
self
.
create_task_request
(
instructor
),
self
.
course
.
id
,
TestRescoringB
ase
.
problem_location
(
problem_url_name
))
InstructorTaskTestC
ase
.
problem_location
(
problem_url_name
))
def
test_delete_problem_state
(
self
):
def
test_delete_problem_state
(
self
):
'''Run delete-state scenario on option problem'''
'''Run delete-state scenario on option problem'''
# get descriptor:
# get descriptor:
problem_url_name
=
'H1P1'
problem_url_name
=
'H1P1'
self
.
define_option_problem
(
problem_url_name
)
self
.
define_option_problem
(
problem_url_name
)
location
=
TestRescoringB
ase
.
problem_location
(
problem_url_name
)
location
=
InstructorTaskTestC
ase
.
problem_location
(
problem_url_name
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
descriptor
=
self
.
module_store
.
get_instance
(
self
.
course
.
id
,
location
)
# first store answers for each of the separate users:
# first store answers for each of the separate users:
for
username
in
self
.
userlist
:
for
username
in
self
.
userlist
:
...
@@ -597,7 +479,7 @@ class TestDeleteProblem(TestRescoringBase):
...
@@ -597,7 +479,7 @@ class TestDeleteProblem(TestRescoringBase):
self
.
assertEqual
(
instructor_task
.
task_type
,
'delete_problem_state'
)
self
.
assertEqual
(
instructor_task
.
task_type
,
'delete_problem_state'
)
task_input
=
json
.
loads
(
instructor_task
.
task_input
)
task_input
=
json
.
loads
(
instructor_task
.
task_input
)
self
.
assertFalse
(
'student'
in
task_input
)
self
.
assertFalse
(
'student'
in
task_input
)
self
.
assertEqual
(
task_input
[
'problem_url'
],
TestRescoring
.
problem_location
(
problem_url_name
))
self
.
assertEqual
(
task_input
[
'problem_url'
],
TestRescoring
Task
.
problem_location
(
problem_url_name
))
status
=
json
.
loads
(
instructor_task
.
task_output
)
status
=
json
.
loads
(
instructor_task
.
task_output
)
self
.
assertEqual
(
status
[
'exception'
],
'ZeroDivisionError'
)
self
.
assertEqual
(
status
[
'exception'
],
'ZeroDivisionError'
)
self
.
assertEqual
(
status
[
'message'
],
expected_message
)
self
.
assertEqual
(
status
[
'message'
],
expected_message
)
...
...
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