Commit edefa04d by kimth

Workaround for 500 on showanswer for choiceresponse

parent 9bcd3cd4
...@@ -557,7 +557,7 @@ class ChoiceResponse(LoncapaResponse): ...@@ -557,7 +557,7 @@ class ChoiceResponse(LoncapaResponse):
return CorrectMap(self.answer_id, 'incorrect') return CorrectMap(self.answer_id, 'incorrect')
def get_answers(self): def get_answers(self):
return {self.answer_id: self.correct_choices} return {self.answer_id: list(self.correct_choices)}
#----------------------------------------------------------------------------- #-----------------------------------------------------------------------------
......
...@@ -390,9 +390,19 @@ class CapaModule(XModule): ...@@ -390,9 +390,19 @@ class CapaModule(XModule):
raise NotFoundError('Answer is not available') raise NotFoundError('Answer is not available')
else: else:
answers = self.lcp.get_question_answers() answers = self.lcp.get_question_answers()
# answers (eg <solution>) may have embedded images # answers (eg <solution>) may have embedded images
answers = dict( (k,self.system.replace_urls(answers[k], self.metadata['data_dir'])) for k in answers ) # but be careful, some problems are using non-string answer dicts
return {'answers': answers} new_answers = dict()
for answer_id in answers:
try:
new_answer = {answer_id: self.system.replace_urls(answers[answer_id], self.metadata['data_dir'])}
except TypeError:
log.debug('Unable to perform URL substitution on answers[%s]: %s' % (answer_id, answers[answer_id]))
new_answer = {answer_id: answers[answer_id]}
new_answers.update(new_answer)
return {'answers': new_answers}
# Figure out if we should move these to capa_problem? # Figure out if we should move these to capa_problem?
def get_problem(self, get): def get_problem(self, get):
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment