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
17c77dd1
Commit
17c77dd1
authored
Aug 08, 2013
by
Vik Paruchuri
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #392 from edx/fix/vik/answer-unknown
Simplify save_grade and pass through answer_unknown
parents
ece4ec3f
c9ddcd78
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
55 additions
and
73 deletions
+55
-73
common/lib/xmodule/xmodule/open_ended_grading_classes/peer_grading_service.py
+25
-36
common/lib/xmodule/xmodule/peer_grading_module.py
+26
-36
common/lib/xmodule/xmodule/tests/test_peer_grading.py
+1
-0
lms/djangoapps/open_ended_grading/tests.py
+3
-1
No files found.
common/lib/xmodule/xmodule/open_ended_grading_classes/peer_grading_service.py
View file @
17c77dd1
...
@@ -36,21 +36,18 @@ class PeerGradingService(GradingService):
...
@@ -36,21 +36,18 @@ class PeerGradingService(GradingService):
return
self
.
try_to_decode
(
response
)
return
self
.
try_to_decode
(
response
)
def
get_next_submission
(
self
,
problem_location
,
grader_id
):
def
get_next_submission
(
self
,
problem_location
,
grader_id
):
response
=
self
.
get
(
self
.
get_next_submission_url
,
response
=
self
.
get
(
{
'location'
:
problem_location
,
'grader_id'
:
grader_id
})
self
.
get_next_submission_url
,
{
'location'
:
problem_location
,
'grader_id'
:
grader_id
}
)
return
self
.
try_to_decode
(
self
.
_render_rubric
(
response
))
return
self
.
try_to_decode
(
self
.
_render_rubric
(
response
))
def
save_grade
(
self
,
location
,
grader_id
,
submission_id
,
score
,
feedback
,
submission_key
,
rubric_scores
,
def
save_grade
(
self
,
**
kwargs
):
submission_flagged
):
data
=
kwargs
data
=
{
'grader_id'
:
grader_id
,
data
.
update
({
'rubric_scores_complete'
:
True
})
'submission_id'
:
submission_id
,
'score'
:
score
,
'feedback'
:
feedback
,
'submission_key'
:
submission_key
,
'location'
:
location
,
'rubric_scores'
:
rubric_scores
,
'rubric_scores_complete'
:
True
,
'submission_flagged'
:
submission_flagged
}
return
self
.
try_to_decode
(
self
.
post
(
self
.
save_grade_url
,
data
))
return
self
.
try_to_decode
(
self
.
post
(
self
.
save_grade_url
,
data
))
def
is_student_calibrated
(
self
,
problem_location
,
grader_id
):
def
is_student_calibrated
(
self
,
problem_location
,
grader_id
):
...
@@ -62,16 +59,9 @@ class PeerGradingService(GradingService):
...
@@ -62,16 +59,9 @@ class PeerGradingService(GradingService):
response
=
self
.
get
(
self
.
show_calibration_essay_url
,
params
)
response
=
self
.
get
(
self
.
show_calibration_essay_url
,
params
)
return
self
.
try_to_decode
(
self
.
_render_rubric
(
response
))
return
self
.
try_to_decode
(
self
.
_render_rubric
(
response
))
def
save_calibration_essay
(
self
,
problem_location
,
grader_id
,
calibration_essay_id
,
submission_key
,
def
save_calibration_essay
(
self
,
**
kwargs
):
score
,
feedback
,
rubric_scores
):
data
=
kwargs
data
=
{
'location'
:
problem_location
,
data
.
update
({
'rubric_scores_complete'
:
True
})
'student_id'
:
grader_id
,
'calibration_essay_id'
:
calibration_essay_id
,
'submission_key'
:
submission_key
,
'score'
:
score
,
'feedback'
:
feedback
,
'rubric_scores[]'
:
rubric_scores
,
'rubric_scores_complete'
:
True
}
return
self
.
try_to_decode
(
self
.
post
(
self
.
save_calibration_essay_url
,
data
))
return
self
.
try_to_decode
(
self
.
post
(
self
.
save_calibration_essay_url
,
data
))
def
get_problem_list
(
self
,
course_id
,
grader_id
):
def
get_problem_list
(
self
,
course_id
,
grader_id
):
...
@@ -100,16 +90,17 @@ without making actual service calls to the grading controller
...
@@ -100,16 +90,17 @@ without making actual service calls to the grading controller
class
MockPeerGradingService
(
object
):
class
MockPeerGradingService
(
object
):
def
get_next_submission
(
self
,
problem_location
,
grader_id
):
def
get_next_submission
(
self
,
problem_location
,
grader_id
):
return
{
'success'
:
True
,
return
{
'submission_id'
:
1
,
'success'
:
True
,
'submission_key'
:
""
,
'submission_id'
:
1
,
'student_response'
:
'fake student response'
,
'submission_key'
:
""
,
'prompt'
:
'fake submission prompt'
,
'student_response'
:
'fake student response'
,
'rubric'
:
'fake rubric'
,
'prompt'
:
'fake submission prompt'
,
'max_score'
:
4
}
'rubric'
:
'fake rubric'
,
'max_score'
:
4
def
save_grade
(
self
,
location
,
grader_id
,
submission_id
,
}
score
,
feedback
,
submission_key
,
rubric_scores
,
submission_flagged
):
def
save_grade
(
self
,
**
kwargs
):
return
{
'success'
:
True
}
return
{
'success'
:
True
}
def
is_student_calibrated
(
self
,
problem_location
,
grader_id
):
def
is_student_calibrated
(
self
,
problem_location
,
grader_id
):
...
@@ -124,9 +115,7 @@ class MockPeerGradingService(object):
...
@@ -124,9 +115,7 @@ class MockPeerGradingService(object):
'rubric'
:
'fake rubric'
,
'rubric'
:
'fake rubric'
,
'max_score'
:
4
}
'max_score'
:
4
}
def
save_calibration_essay
(
self
,
problem_location
,
grader_id
,
def
save_calibration_essay
(
self
,
**
kwargs
):
calibration_essay_id
,
submission_key
,
score
,
feedback
,
rubric_scores
):
return
{
'success'
:
True
,
'actual_score'
:
2
}
return
{
'success'
:
True
,
'actual_score'
:
2
}
def
get_problem_list
(
self
,
course_id
,
grader_id
):
def
get_problem_list
(
self
,
course_id
,
grader_id
):
...
...
common/lib/xmodule/xmodule/peer_grading_module.py
View file @
17c77dd1
...
@@ -23,6 +23,7 @@ log = logging.getLogger(__name__)
...
@@ -23,6 +23,7 @@ log = logging.getLogger(__name__)
EXTERNAL_GRADER_NO_CONTACT_ERROR
=
"Failed to contact external graders. Please notify course staff."
EXTERNAL_GRADER_NO_CONTACT_ERROR
=
"Failed to contact external graders. Please notify course staff."
class
PeerGradingFields
(
object
):
class
PeerGradingFields
(
object
):
use_for_single_location
=
Boolean
(
use_for_single_location
=
Boolean
(
display_name
=
"Show Single Problem"
,
display_name
=
"Show Single Problem"
,
...
@@ -67,9 +68,11 @@ class PeerGradingFields(object):
...
@@ -67,9 +68,11 @@ class PeerGradingFields(object):
scope
=
Scope
.
settings
,
scope
=
Scope
.
settings
,
default
=
"Peer Grading Interface"
default
=
"Peer Grading Interface"
)
)
data
=
String
(
help
=
"Html contents to display for this module"
,
data
=
String
(
help
=
"Html contents to display for this module"
,
default
=
'<peergrading></peergrading>'
,
default
=
'<peergrading></peergrading>'
,
scope
=
Scope
.
content
)
scope
=
Scope
.
content
)
class
PeerGradingModule
(
PeerGradingFields
,
XModule
):
class
PeerGradingModule
(
PeerGradingFields
,
XModule
):
...
@@ -78,11 +81,14 @@ class PeerGradingModule(PeerGradingFields, XModule):
...
@@ -78,11 +81,14 @@ class PeerGradingModule(PeerGradingFields, XModule):
"""
"""
_VERSION
=
1
_VERSION
=
1
js
=
{
'coffee'
:
[
resource_string
(
__name__
,
'js/src/peergrading/peer_grading.coffee'
),
js
=
{
resource_string
(
__name__
,
'js/src/peergrading/peer_grading_problem.coffee'
),
'coffee'
:
[
resource_string
(
__name__
,
'js/src/collapsible.coffee'
),
resource_string
(
__name__
,
'js/src/peergrading/peer_grading.coffee'
),
resource_string
(
__name__
,
'js/src/javascript_loader.coffee'
),
resource_string
(
__name__
,
'js/src/peergrading/peer_grading_problem.coffee'
),
]}
resource_string
(
__name__
,
'js/src/collapsible.coffee'
),
resource_string
(
__name__
,
'js/src/javascript_loader.coffee'
),
]
}
js_module_name
=
"PeerGrading"
js_module_name
=
"PeerGrading"
css
=
{
'scss'
:
[
resource_string
(
__name__
,
'css/combinedopenended/display.scss'
)]}
css
=
{
'scss'
:
[
resource_string
(
__name__
,
'css/combinedopenended/display.scss'
)]}
...
@@ -133,7 +139,6 @@ class PeerGradingModule(PeerGradingFields, XModule):
...
@@ -133,7 +139,6 @@ class PeerGradingModule(PeerGradingFields, XModule):
return
True
return
True
return
False
return
False
def
_err_response
(
self
,
msg
):
def
_err_response
(
self
,
msg
):
"""
"""
Return a HttpResponse with a json dump with success=False, and the given error message.
Return a HttpResponse with a json dump with success=False, and the given error message.
...
@@ -307,31 +312,22 @@ class PeerGradingModule(PeerGradingFields, XModule):
...
@@ -307,31 +312,22 @@ class PeerGradingModule(PeerGradingFields, XModule):
error: if there was an error in the submission, this is the error message
error: if there was an error in the submission, this is the error message
"""
"""
required
=
set
([
'location'
,
'submission_id'
,
'submission_key'
,
'score'
,
'feedback'
,
'rubric_scores[]'
,
required
=
set
([
'location'
,
'submission_id'
,
'submission_key'
,
'score'
,
'feedback'
,
'rubric_scores[]'
,
'submission_flagged'
,
'answer_unknown'
])
'submission_flagged'
])
success
,
message
=
self
.
_check_required
(
data
,
required
)
success
,
message
=
self
.
_check_required
(
data
,
required
)
if
not
success
:
if
not
success
:
return
self
.
_err_response
(
message
)
return
self
.
_err_response
(
message
)
grader_id
=
self
.
system
.
anonymous_student_id
location
=
data
.
get
(
'location'
)
data_dict
=
{
k
:
data
.
get
(
k
)
for
k
in
required
}
submission_id
=
data
.
get
(
'submission_id'
)
data_dict
[
'rubric_scores'
]
=
data
.
getlist
(
'rubric_scores[]'
)
score
=
data
.
get
(
'score'
)
data_dict
[
'grader_id'
]
=
self
.
system
.
anonymous_student_id
feedback
=
data
.
get
(
'feedback'
)
submission_key
=
data
.
get
(
'submission_key'
)
rubric_scores
=
data
.
getlist
(
'rubric_scores[]'
)
submission_flagged
=
data
.
get
(
'submission_flagged'
)
try
:
try
:
response
=
self
.
peer_gs
.
save_grade
(
location
,
grader_id
,
submission_id
,
response
=
self
.
peer_gs
.
save_grade
(
**
data_dict
)
score
,
feedback
,
submission_key
,
rubric_scores
,
submission_flagged
)
return
response
return
response
except
GradingServiceError
:
except
GradingServiceError
:
# This is a dev_facing_error
# This is a dev_facing_error
log
.
exception
(
"""Error saving grade to open ended grading service. server url: {0}, location: {1}, submission_id:{2},
log
.
exception
(
"""Error saving grade to open ended grading service. server url: {0}"""
submission_key: {3}, score: {4}"""
.
format
(
self
.
peer_gs
.
url
)
.
format
(
self
.
peer_gs
.
url
,
location
,
submission_id
,
submission_key
,
score
)
)
)
# This is a student_facing_error
# This is a student_facing_error
return
{
return
{
...
@@ -450,27 +446,21 @@ class PeerGradingModule(PeerGradingFields, XModule):
...
@@ -450,27 +446,21 @@ class PeerGradingModule(PeerGradingFields, XModule):
success
,
message
=
self
.
_check_required
(
data
,
required
)
success
,
message
=
self
.
_check_required
(
data
,
required
)
if
not
success
:
if
not
success
:
return
self
.
_err_response
(
message
)
return
self
.
_err_response
(
message
)
grader_id
=
self
.
system
.
anonymous_student_id
location
=
data
.
get
(
'location'
)
data_dict
=
{
k
:
data
.
get
(
k
)
for
k
in
required
}
calibration_essay_id
=
data
.
get
(
'submission_id'
)
data_dict
[
'rubric_scores'
]
=
data
.
getlist
(
'rubric_scores[]'
)
submission_key
=
data
.
get
(
'submission_key'
)
data_dict
[
'student_id'
]
=
self
.
system
.
anonymous_student_id
score
=
data
.
get
(
'score'
)
data_dict
[
'calibration_essay_id'
]
=
data_dict
[
'submission_id'
]
feedback
=
data
.
get
(
'feedback'
)
rubric_scores
=
data
.
getlist
(
'rubric_scores[]'
)
try
:
try
:
response
=
self
.
peer_gs
.
save_calibration_essay
(
location
,
grader_id
,
calibration_essay_id
,
response
=
self
.
peer_gs
.
save_calibration_essay
(
**
data_dict
)
submission_key
,
score
,
feedback
,
rubric_scores
)
if
'actual_rubric'
in
response
:
if
'actual_rubric'
in
response
:
rubric_renderer
=
combined_open_ended_rubric
.
CombinedOpenEndedRubric
(
self
.
system
,
True
)
rubric_renderer
=
combined_open_ended_rubric
.
CombinedOpenEndedRubric
(
self
.
system
,
True
)
response
[
'actual_rubric'
]
=
rubric_renderer
.
render_rubric
(
response
[
'actual_rubric'
])[
'html'
]
response
[
'actual_rubric'
]
=
rubric_renderer
.
render_rubric
(
response
[
'actual_rubric'
])[
'html'
]
return
response
return
response
except
GradingServiceError
:
except
GradingServiceError
:
# This is a dev_facing_error
# This is a dev_facing_error
log
.
exception
(
log
.
exception
(
"Error saving calibration grade"
)
"Error saving calibration grade, location: {0}, submission_key: {1}, grader_id: {2}"
.
format
(
location
,
submission_key
,
grader_id
))
# This is a student_facing_error
# This is a student_facing_error
return
self
.
_err_response
(
'There was an error saving your score. Please notify course staff.'
)
return
self
.
_err_response
(
'There was an error saving your score. Please notify course staff.'
)
...
...
common/lib/xmodule/xmodule/tests/test_peer_grading.py
View file @
17c77dd1
...
@@ -28,6 +28,7 @@ class PeerGradingModuleTest(unittest.TestCase, DummyModulestore):
...
@@ -28,6 +28,7 @@ class PeerGradingModuleTest(unittest.TestCase, DummyModulestore):
'feedback'
:
""
,
'feedback'
:
""
,
'rubric_scores[]'
:
[
0
,
1
],
'rubric_scores[]'
:
[
0
,
1
],
'submission_flagged'
:
False
,
'submission_flagged'
:
False
,
'answer_unknown'
:
False
,
})
})
def
setUp
(
self
):
def
setUp
(
self
):
...
...
lms/djangoapps/open_ended_grading/tests.py
View file @
17c77dd1
...
@@ -205,7 +205,9 @@ class TestPeerGradingService(LoginEnrollmentTestCase):
...
@@ -205,7 +205,9 @@ class TestPeerGradingService(LoginEnrollmentTestCase):
'submission_key'
:
'fake key'
,
'submission_key'
:
'fake key'
,
'score'
:
2
,
'score'
:
2
,
'feedback'
:
'feedback'
,
'feedback'
:
'feedback'
,
'submission_flagged'
:
'false'
'submission_flagged'
:
'false'
,
'answer_unknown'
:
'false'
,
'rubric_scores_complete'
:
'true'
}
}
qdict
=
MagicMock
()
qdict
=
MagicMock
()
...
...
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