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
76cf2027
Commit
76cf2027
authored
Aug 01, 2013
by
Adam
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #424 from edx/fix/adam/dash-reset
convert user objects to unicode, improve error logging
parents
1b83cfc4
0076d6a6
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
53 additions
and
22 deletions
+53
-22
lms/djangoapps/instructor/views.py
+53
-22
No files found.
lms/djangoapps/instructor/views.py
View file @
76cf2027
...
...
@@ -310,7 +310,9 @@ def instructor_dashboard(request, course_id):
"Delete student state for module"
in
action
or
"Rescore student's problem submission"
in
action
):
# get the form data
unique_student_identifier
=
request
.
POST
.
get
(
'unique_student_identifier'
,
''
)
unique_student_identifier
=
request
.
POST
.
get
(
'unique_student_identifier'
,
''
)
problem_urlname
=
request
.
POST
.
get
(
'problem_for_student'
,
''
)
module_state_key
=
get_module_url
(
problem_urlname
)
# try to uniquely id student by email address or username
...
...
@@ -320,23 +322,42 @@ def instructor_dashboard(request, course_id):
if
student
is
not
None
:
# find the module in question
try
:
student_module
=
StudentModule
.
objects
.
get
(
student_id
=
student
.
id
,
course_id
=
course_id
,
module_state_key
=
module_state_key
)
student_module
=
StudentModule
.
objects
.
get
(
student_id
=
student
.
id
,
course_id
=
course_id
,
module_state_key
=
module_state_key
)
msg
+=
"Found module. "
except
StudentModule
.
DoesNotExist
:
msg
+=
"<font color='red'>Couldn't find module with that urlname. </font>"
except
StudentModule
.
DoesNotExist
as
err
:
error_msg
=
"Couldn't find module with that urlname: {0}. "
.
format
(
problem_urlname
)
msg
+=
"<font color='red'>"
+
error_msg
+
"({0}) "
.
format
(
err
)
+
"</font>"
log
.
debug
(
error_msg
)
if
student_module
is
not
None
:
if
"Delete student state for module"
in
action
:
# delete the state
try
:
student_module
.
delete
()
msg
+=
"<font color='red'>Deleted student module state for
%
s!</font>"
%
module_state_key
event
=
{
"problem"
:
problem_url
,
"student"
:
unique_student_identifier
,
"course"
:
course_id
}
track
.
views
.
server_track
(
request
,
"delete-student-module-state"
,
event
,
page
=
"idashboard"
)
except
:
msg
+=
"Failed to delete module state for
%
s/
%
s"
%
(
unique_student_identifier
,
problem_urlname
)
msg
+=
"<font color='red'>Deleted student module state for {0}!</font>"
.
format
(
module_state_key
)
event
=
{
"problem"
:
problem_url
,
"student"
:
unique_student_identifier
,
"course"
:
course_id
}
track
.
views
.
server_track
(
request
,
"delete-student-module-state"
,
event
,
page
=
"idashboard"
)
except
Exception
as
err
:
error_msg
=
"Failed to delete module state for {0}/{1}. "
.
format
(
unique_student_identifier
,
problem_urlname
)
msg
+=
"<font color='red'>"
+
error_msg
+
"({0}) "
.
format
(
err
)
+
"</font>"
log
.
exception
(
error_msg
)
elif
"Reset student's attempts"
in
action
:
# modify the problem's state
try
:
...
...
@@ -344,19 +365,24 @@ def instructor_dashboard(request, course_id):
problem_state
=
json
.
loads
(
student_module
.
state
)
old_number_of_attempts
=
problem_state
[
"attempts"
]
problem_state
[
"attempts"
]
=
0
# save
student_module
.
state
=
json
.
dumps
(
problem_state
)
student_module
.
save
()
event
=
{
"old_attempts"
:
old_number_of_attempts
,
"student"
:
student
,
"problem"
:
student_module
.
module_state_key
,
"instructor"
:
request
.
user
,
"course"
:
course_id
}
event
=
{
"old_attempts"
:
old_number_of_attempts
,
"student"
:
unicode
(
student
),
"problem"
:
student_module
.
module_state_key
,
"instructor"
:
unicode
(
request
.
user
),
"course"
:
course_id
}
track
.
views
.
server_track
(
request
,
"reset-student-attempts"
,
event
,
page
=
"idashboard"
)
msg
+=
"<font color='green'>Module state successfully reset!</font>"
except
:
msg
+=
"<font color='red'>Couldn't reset module state. </font>"
except
Exception
as
err
:
error_msg
=
"Couldn't reset module state for {0}/{1}. "
.
format
(
unique_student_identifier
,
problem_urlname
)
msg
+=
"<font color='red'>"
+
error_msg
+
"({0}) "
.
format
(
err
)
+
"</font>"
log
.
exception
(
error_msg
)
else
:
# "Rescore student's problem submission" case
try
:
...
...
@@ -365,9 +391,14 @@ def instructor_dashboard(request, course_id):
msg
+=
'<font color="red">Failed to create a background task for rescoring "{0}" for student {1}.</font>'
.
format
(
module_state_key
,
unique_student_identifier
)
else
:
track
.
views
.
server_track
(
request
,
"rescore-student-submission"
,
{
"problem"
:
module_state_key
,
"student"
:
unique_student_identifier
,
"course"
:
course_id
},
page
=
"idashboard"
)
except
Exception
as
e
:
log
.
exception
(
"Encountered exception from rescore: {0}"
)
msg
+=
'<font color="red">Failed to create a background task for rescoring "{0}": {1}.</font>'
.
format
(
module_state_key
,
e
.
message
)
except
Exception
as
err
:
msg
+=
'<font color="red">Failed to create a background task for rescoring "{0}": {1}.</font>'
.
format
(
module_state_key
,
err
.
message
)
log
.
exception
(
"Encountered exception from rescore: student '{0}' problem '{1}'"
.
format
(
unique_student_identifier
,
module_state_key
)
)
elif
"Get link to student's progress page"
in
action
:
unique_student_identifier
=
request
.
POST
.
get
(
'unique_student_identifier'
,
''
)
...
...
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