MDL-47494 gapselect: Implement the new variants handling.
authorTim Hunt <T.J.Hunt@open.ac.uk>
Thu, 26 May 2011 21:10:13 +0000 (22:10 +0100)
committerTim Hunt <T.J.Hunt@open.ac.uk>
Thu, 26 May 2011 21:10:13 +0000 (22:10 +0100)
question/type/gapselect/questionbase.php
question/type/gapselect/simpletest/testquestion.php

index bcda4bd..e487c52 100755 (executable)
@@ -65,7 +65,7 @@ abstract class qtype_gapselect_question_base extends question_graded_automatical
     /** @var array shuffled choice indexes. */
     protected $choiceorder;
 
-    public function start_attempt(question_attempt_step $step) {
+    public function start_attempt(question_attempt_step $step, $variant) {
         foreach ($this->choices as $group => $choices) {
             $choiceorder = array_keys($choices);
             if ($this->shufflechoices) {
index c232cde..d7bafbc 100755 (executable)
@@ -55,7 +55,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_summarise_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual('{quick} {fox} {lazy}',
                 $gapselect->summarise_response(array('p1' => '1', 'p2' => '1', 'p3' => '1')));
@@ -64,7 +64,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_summarise_response_maths() {
         $gapselect = qtype_gapselect_test_helper::make_a_maths_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual('{+} {-} {+} {-}', $gapselect->summarise_response(
                 array('p1' => '1', 'p2' => '2', 'p3' => '1', 'p4' => '2')));
@@ -83,7 +83,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_get_right_choice_for() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(1, $gapselect->get_right_choice_for(1));
         $this->assertEqual(1, $gapselect->get_right_choice_for(2));
@@ -92,7 +92,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_get_right_choice_for_maths() {
         $gapselect = qtype_gapselect_test_helper::make_a_maths_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(1, $gapselect->get_right_choice_for(1));
         $this->assertEqual(2, $gapselect->get_right_choice_for(2));
@@ -101,7 +101,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_clear_wrong_from_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_maths_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $initialresponse = array('p1' => '1', 'p2' => '1', 'p3' => '1', 'p4' => '1');
         $this->assertEqual(array('p1' => '1', 'p2' => '0', 'p3' => '1', 'p4' => '0'),
@@ -111,7 +111,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_get_num_parts_right() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array(2, 3),
                 $gapselect->get_num_parts_right(array('p1' => '1', 'p2' => '1', 'p3' => '2')));
@@ -122,7 +122,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_get_num_parts_right_maths() {
         $gapselect = qtype_gapselect_test_helper::make_a_maths_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array(2, 4), $gapselect->get_num_parts_right(
                 array('p1' => '1', 'p2' => '1', 'p3' => '1', 'p4' => '1')));
@@ -130,7 +130,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
 
     public function test_get_expected_data() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array('p1' => PARAM_INT, 'p2' => PARAM_INT, 'p3' => PARAM_INT),
                 $gapselect->get_expected_data());
@@ -139,7 +139,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_get_correct_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array('p1' => '1', 'p2' => '1', 'p3' => '1'),
                 $gapselect->get_correct_response());
@@ -148,7 +148,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_get_correct_response_maths() {
         $gapselect = qtype_gapselect_test_helper::make_a_maths_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array('p1' => '1', 'p2' => '2', 'p3' => '1', 'p4' => '2'),
                 $gapselect->get_correct_response());
@@ -156,7 +156,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
 
     public function test_is_same_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertTrue($gapselect->is_same_response(
                 array(),
@@ -180,7 +180,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     }
     public function test_is_complete_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertFalse($gapselect->is_complete_response(array()));
         $this->assertFalse($gapselect->is_complete_response(
@@ -192,7 +192,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
 
     public function test_is_gradable_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertFalse($gapselect->is_gradable_response(array()));
         $this->assertFalse($gapselect->is_gradable_response(
@@ -207,7 +207,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_grading() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array(1, question_state::$gradedright),
                 $gapselect->grade_response(array('p1' => '1', 'p2' => '1', 'p3' => '1')));
@@ -220,7 +220,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_grading_maths() {
         $gapselect = qtype_gapselect_test_helper::make_a_maths_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array(1, question_state::$gradedright), $gapselect->grade_response(
                 array('p1' => '1', 'p2' => '2', 'p3' => '1', 'p4' => '2')));
@@ -233,7 +233,7 @@ class qtype_gapselect_question_test extends UnitTestCase {
     public function test_classify_response() {
         $gapselect = qtype_gapselect_test_helper::make_a_gapselect_question();
         $gapselect->shufflechoices = false;
-        $gapselect->start_attempt(new question_attempt_step());
+        $gapselect->start_attempt(new question_attempt_step(), 1);
 
         $this->assertEqual(array(
                     1 => new question_classified_response(1, 'quick', 1),