Ejemplo n.º 1
0
 public function test_force_import_option()
 {
     // Need to add users into the system.
     $user = new stdClass();
     $user->firstname = 'Anne';
     $user->lastname = 'Able';
     $user->email = '*****@*****.**';
     $user->id_number = 1;
     $user1 = $this->getDataGenerator()->create_user($user);
     $user = new stdClass();
     $user->firstname = 'Bobby';
     $user->lastname = 'Bunce';
     $user->email = '*****@*****.**';
     $user->id_number = 2;
     $user2 = $this->getDataGenerator()->create_user($user);
     // Create a new grade item.
     $params = array('itemtype' => 'manual', 'itemname' => 'Grade item 1', 'gradetype' => GRADE_TYPE_VALUE, 'courseid' => $this->courseid);
     $gradeitem = new grade_item($params, false);
     $gradeitemid = $gradeitem->insert();
     $importcode = 01;
     $verbosescales = 0;
     // Form data object.
     $formdata = new stdClass();
     $formdata->mapfrom = 5;
     $formdata->mapto = 'useremail';
     $formdata->mapping_0 = 0;
     $formdata->mapping_1 = 0;
     $formdata->mapping_2 = 0;
     $formdata->mapping_3 = 0;
     $formdata->mapping_4 = 0;
     $formdata->mapping_5 = 0;
     $formdata->mapping_6 = $gradeitemid;
     $formdata->mapping_7 = 'feedback_2';
     $formdata->mapping_8 = 0;
     $formdata->mapping_9 = 0;
     $formdata->map = 1;
     $formdata->id = 2;
     $formdata->iid = $this->iid;
     $formdata->importcode = $importcode;
     $formdata->forceimport = false;
     // Add last download from this course column to csv content.
     $exportdate = time();
     $newcsvdata = str_replace('{exportdate}', $exportdate, $this->csvtext);
     $this->csv_load($newcsvdata);
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     $this->assertTrue($dataloaded);
     // We must update the last modified date.
     grade_import_commit($this->courseid, $importcode, false, false);
     // Test using force import disabled and a date in the past.
     $pastdate = strtotime('-1 day', time());
     $newcsvdata = str_replace('{exportdate}', $pastdate, $this->csvtext);
     $this->csv_load($newcsvdata);
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     $this->assertFalse($dataloaded);
     $errors = $testobject->get_gradebookerrors();
     $this->assertEquals($errors[0], get_string('gradealreadyupdated', 'grades', fullname($user1)));
     // Test using force import enabled and a date in the past.
     $formdata->forceimport = true;
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     $this->assertTrue($dataloaded);
     // Test importing using an old exported file (2 years ago).
     $formdata->forceimport = false;
     $twoyearsago = strtotime('-2 year', time());
     $newcsvdata = str_replace('{exportdate}', $twoyearsago, $this->csvtext);
     $this->csv_load($newcsvdata);
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     $this->assertFalse($dataloaded);
     $errors = $testobject->get_gradebookerrors();
     $this->assertEquals($errors[0], get_string('invalidgradeexporteddate', 'grades'));
     // Test importing using invalid exported date.
     $baddate = '0123A56B89';
     $newcsvdata = str_replace('{exportdate}', $baddate, $this->csvtext);
     $this->csv_load($newcsvdata);
     $formdata->mapping_6 = $gradeitemid;
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     $this->assertFalse($dataloaded);
     $errors = $testobject->get_gradebookerrors();
     $this->assertEquals($errors[0], get_string('invalidgradeexporteddate', 'grades'));
     // Test importing using date in the future.
     $oneyearahead = strtotime('+1 year', time());
     $oldcsv = str_replace('{exportdate}', $oneyearahead, $this->csvtext);
     $this->csv_load($oldcsv);
     $formdata->mapping_6 = $gradeitemid;
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     $this->assertFalse($dataloaded);
     $errors = $testobject->get_gradebookerrors();
     $this->assertEquals($errors[0], get_string('invalidgradeexporteddate', 'grades'));
 }
Ejemplo n.º 2
0
 /**
  * Test importing data into the gradebook.
  */
 public function test_prepare_import_grade_data()
 {
     global $DB;
     // Need to add one of the users into the system.
     $user = new stdClass();
     $user->firstname = 'Anne';
     $user->lastname = 'Able';
     $user->email = '*****@*****.**';
     // Insert user 1.
     $this->getDataGenerator()->create_user($user);
     $user = new stdClass();
     $user->firstname = 'Bobby';
     $user->lastname = 'Bunce';
     $user->email = '*****@*****.**';
     // Insert user 2.
     $this->getDataGenerator()->create_user($user);
     $this->csv_load($this->oktext);
     $importcode = 07;
     $verbosescales = 0;
     // Form data object.
     $formdata = new stdClass();
     $formdata->mapfrom = 5;
     $formdata->mapto = 'useremail';
     $formdata->mapping_0 = 0;
     $formdata->mapping_1 = 0;
     $formdata->mapping_2 = 0;
     $formdata->mapping_3 = 0;
     $formdata->mapping_4 = 0;
     $formdata->mapping_5 = 0;
     $formdata->mapping_6 = 'new';
     $formdata->mapping_7 = 'feedback_2';
     $formdata->mapping_8 = 0;
     $formdata->map = 1;
     $formdata->id = 2;
     $formdata->iid = $this->iid;
     $formdata->importcode = $importcode;
     // Blam go time.
     $testobject = new phpunit_gradeimport_csv_load_data();
     $dataloaded = $testobject->prepare_import_grade_data($this->columns, $formdata, $this->csvimport, $this->courseid, '', '', $verbosescales);
     // If everything inserted properly then this should be true.
     $this->assertTrue($dataloaded);
 }