diff --git a/src/transformer/events/mod_quiz/question_answered/handler.php b/src/transformer/events/mod_quiz/question_answered/handler.php index 8e3dc4547..44b61fd01 100644 --- a/src/transformer/events/mod_quiz/question_answered/handler.php +++ b/src/transformer/events/mod_quiz/question_answered/handler.php @@ -29,6 +29,8 @@ function handler(array $config, \stdClass $event, \stdClass $questionattempt) { return essay($config, $event, $questionattempt, $question); case 'truefalse': return truefalse($config, $event, $questionattempt, $question); + case 'numerical': + return numerical($config, $event, $questionattempt, $question); default: return []; } diff --git a/src/transformer/events/mod_quiz/question_answered/numerical.php b/src/transformer/events/mod_quiz/question_answered/numerical.php new file mode 100644 index 000000000..6e0e13c7f --- /dev/null +++ b/src/transformer/events/mod_quiz/question_answered/numerical.php @@ -0,0 +1,75 @@ +. + +namespace src\transformer\events\mod_quiz\question_answered; + +defined('MOODLE_INTERNAL') || die(); + +use src\transformer\utils as utils; + +function numerical(array $config, \stdClass $event, \stdClass $questionattempt, \stdClass $question) { + $repo = $config['repo']; + $user = $repo->read_record_by_id('user', $event->relateduserid); + $course = $repo->read_record_by_id('course', $event->courseid); + $attempt = $repo->read_record_by_id('quiz_attempts', $questionattempt->questionusageid); + $quiz = $repo->read_record_by_id('quiz', $attempt->quiz); + $coursemodule = $repo->read_record_by_id('course_modules', $event->contextinstanceid); + $lang = utils\get_course_lang($course); + + return [[ + 'actor' => utils\get_user($config, $user), + 'verb' => [ + 'id' => 'http://adlnet.gov/expapi/verbs/answered', + 'display' => [ + $lang => 'answered' + ], + ], + 'object' => [ + 'id' => $config['app_url'].'/question/question.php?cmid='.$coursemodule->id.'&id='.$question->id, + 'definition' => [ + 'type' => 'http://adlnet.gov/expapi/activities/question', + 'name' => [ + $lang => $questionattempt->questionsummary, + ], + 'interactionType' => 'numeric', + ] + ], + 'timestamp' => utils\get_event_timestamp($event), + 'result' => [ + 'response' => $questionattempt->responsesummary, + 'completion' => $questionattempt->responsesummary !== '', + 'success' => $questionattempt->rightanswer === $questionattempt->responsesummary, + ], + 'context' => [ + 'platform' => $config['source_name'], + 'language' => $lang, + 'extensions' => [ + utils\INFO_EXTENSION => utils\get_info($config, $event), + ], + 'contextActivities' => [ + 'grouping' => [ + utils\get_activity\site($config), + utils\get_activity\course($config, $course), + utils\get_activity\module($config, 'quiz', $quiz, $lang), + utils\get_activity\module($config, 'attempt', $attempt, $lang), + ], + 'category' => [ + utils\get_activity\source($config), + ] + ], + ] + ]]; +} \ No newline at end of file diff --git a/tests/mod_quiz/attempt_submitted/numerical/data.json b/tests/mod_quiz/attempt_submitted/numerical/data.json new file mode 100644 index 000000000..44f713fab --- /dev/null +++ b/tests/mod_quiz/attempt_submitted/numerical/data.json @@ -0,0 +1,66 @@ +{ + "user": [ + { + "id": 1, + "firstname": "test_fullname", + "email": "test@test.com" + } + ], + "course": [ + { + "id": 1, + "fullname": "test_name", + "lang": "en" + } + ], + "course_modules": [ + { + "id": 1, + "course": 1, + "module": 1, + "instance": 1 + } + ], + "quiz_attempts": [ + { + "id": 1, + "quiz": 1, + "sumgrades": 50, + "state": "finished", + "timefinish": 1, + "timestart": 0 + } + ], + "quiz": [ + { + "id": 1, + "name": "test_quiz_name" + } + ], + "grade_items": [ + { + "id": 1, + "iteminstance": 1, + "itemmodule": "quiz", + "grademin": 0, + "grademax": 100, + "gradepass": 50 + } + ], + "question_attempts": [ + { + "id": 1, + "questionusageid": 1, + "questionid": 1, + "questionsummary": "test_question", + "responsesummary": "1", + "rightanswer": "1" + } + ], + "question": [ + { + "id": 1, + "qtype": "numerical" + } + ] +} \ No newline at end of file diff --git a/tests/mod_quiz/attempt_submitted/numerical/event.json b/tests/mod_quiz/attempt_submitted/numerical/event.json new file mode 100644 index 000000000..0f8370b23 --- /dev/null +++ b/tests/mod_quiz/attempt_submitted/numerical/event.json @@ -0,0 +1,10 @@ +{ + "id": 1, + "relateduserid": 1, + "courseid": 1, + "timecreated": 1433946701, + "objecttable": "attempt", + "objectid": 1, + "contextinstanceid": 1, + "eventname": "\\mod_quiz\\event\\attempt_submitted" +} \ No newline at end of file diff --git a/tests/mod_quiz/attempt_submitted/numerical/statements.json b/tests/mod_quiz/attempt_submitted/numerical/statements.json new file mode 100644 index 000000000..3c36e2371 --- /dev/null +++ b/tests/mod_quiz/attempt_submitted/numerical/statements.json @@ -0,0 +1,188 @@ +[ + { + "actor": { + "name": "test_fullname", + "account": { + "homePage": "http:\/\/www.example.org", + "name": "1" + } + }, + "verb": { + "id": "http:\/\/adlnet.gov\/expapi\/verbs\/completed", + "display": { + "en": "completed" + } + }, + "object": { + "id": "http:\/\/www.example.org\/mod\/quiz\/view.php?id=1", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms\/module", + "name": { + "en": "test_quiz_name" + } + } + }, + "timestamp": "2015-06-10T15:31:41+01:00", + "result": { + "score": { + "raw": 50, + "min": 0, + "max": 100, + "scaled": 0.5 + }, + "completion": true, + "success": true, + "duration": "PT1S" + }, + "context": { + "platform": "Moodle", + "language": "en", + "extensions": { + "http:\/\/lrs.learninglocker.net\/define\/extensions\/info": { + "http:\/\/moodle.org": "1.0.0", + "https:\/\/github.com\/xAPI-vle\/moodle-logstore_xapi": "0.0.0-development", + "event_name": "\\mod_quiz\\event\\attempt_submitted", + "event_function": "\\src\\transformer\\events\\mod_quiz\\attempt_submitted\\handler" + } + }, + "contextActivities": { + "other": [ + { + "id": "http:\/\/www.example.org\/mod\/attempt\/view.php?id=1", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms\/module", + "name": { + "en": "attempt" + } + } + } + ], + "grouping": [ + { + "id": "http:\/\/www.example.org", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms", + "name": { + "en": "test_name" + } + } + }, + { + "id": "http:\/\/www.example.org\/course\/view.php?id=1", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms\/course", + "name": { + "en": "test_name" + } + } + } + ], + "category": [ + { + "id": "http:\/\/moodle.org", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/source", + "name": { + "en": "Moodle" + } + } + } + ] + } + } + }, + { + "actor": { + "name": "test_fullname", + "account": { + "homePage": "http:\/\/www.example.org", + "name": "1" + } + }, + "verb": { + "id": "http:\/\/adlnet.gov\/expapi\/verbs\/answered", + "display": { + "en": "answered" + } + }, + "object": { + "id": "http:\/\/www.example.org\/question\/question.php?cmid=1&id=1", + "definition": { + "type": "http:\/\/adlnet.gov\/expapi\/activities\/question", + "name": { + "en": "test_question" + }, + "interactionType": "numeric" + } + }, + "timestamp": "2015-06-10T15:31:41+01:00", + "result": { + "response": "1", + "completion": true, + "success": true + }, + "context": { + "platform": "Moodle", + "language": "en", + "extensions": { + "http:\/\/lrs.learninglocker.net\/define\/extensions\/info": { + "http:\/\/moodle.org": "1.0.0", + "https:\/\/github.com\/xAPI-vle\/moodle-logstore_xapi": "0.0.0-development", + "event_name": "\\mod_quiz\\event\\attempt_submitted", + "event_function": "\\src\\transformer\\events\\mod_quiz\\attempt_submitted\\handler" + } + }, + "contextActivities": { + "grouping": [ + { + "id": "http:\/\/www.example.org", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms", + "name": { + "en": "test_name" + } + } + }, + { + "id": "http:\/\/www.example.org\/course\/view.php?id=1", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms\/course", + "name": { + "en": "test_name" + } + } + }, + { + "id": "http:\/\/www.example.org\/mod\/quiz\/view.php?id=1", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms\/module", + "name": { + "en": "test_quiz_name" + } + } + }, + { + "id": "http:\/\/www.example.org\/mod\/attempt\/view.php?id=1", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/lms\/module", + "name": { + "en": "attempt" + } + } + } + ], + "category": [ + { + "id": "http:\/\/moodle.org", + "definition": { + "type": "http:\/\/id.tincanapi.com\/activitytype\/source", + "name": { + "en": "Moodle" + } + } + } + ] + } + } + } +] \ No newline at end of file diff --git a/tests/mod_quiz/attempt_submitted/numerical/test.php b/tests/mod_quiz/attempt_submitted/numerical/test.php new file mode 100644 index 000000000..53094f328 --- /dev/null +++ b/tests/mod_quiz/attempt_submitted/numerical/test.php @@ -0,0 +1,24 @@ +. + +namespace tests\mod_quiz\attempt_submitted\numerical; +defined('MOODLE_INTERNAL') || die(); + +class test extends \tests\xapi_test_case { + protected function get_test_dir() { + return __DIR__; + } +} \ No newline at end of file