Skip to content

Commit

Permalink
MDL-76811 mod_data: Generator test cleanup
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewnicols committed Jan 10, 2023
1 parent cd07230 commit e8ea491
Showing 1 changed file with 53 additions and 35 deletions.
88 changes: 53 additions & 35 deletions mod/data/tests/generator_test.php
Expand Up @@ -28,6 +28,9 @@
* @coversDefaultClass \mod_data_generator
*/
class generator_test extends \advanced_testcase {
/**
* @covers ::create_instance
*/
public function test_generator() {
global $DB;

Expand All @@ -42,9 +45,9 @@ public function test_generator() {
$this->assertInstanceOf('mod_data_generator', $generator);
$this->assertEquals('data', $generator->get_modulename());

$generator->create_instance(array('course' => $course->id));
$generator->create_instance(array('course' => $course->id));
$data = $generator->create_instance(array('course' => $course->id));
$generator->create_instance(['course' => $course->id]);
$generator->create_instance(['course' => $course->id]);
$data = $generator->create_instance(['course' => $course->id]);
$this->assertEquals(3, $DB->count_records('data'));

$cm = get_coursemodule_from_instance('data', $data->id);
Expand All @@ -55,16 +58,23 @@ public function test_generator() {
$context = \context_module::instance($cm->id);
$this->assertEquals($data->cmid, $context->instanceid);

// test gradebook integration using low level DB access - DO NOT USE IN PLUGIN CODE!
$data = $generator->create_instance(array('course' => $course->id, 'assessed' => 1, 'scale' => 100));
$gitem = $DB->get_record('grade_items', array('courseid' => $course->id, 'itemtype' => 'mod',
'itemmodule' => 'data', 'iteminstance' => $data->id));
// Test gradebook integration using low level DB access - DO NOT USE IN PLUGIN CODE!
$data = $generator->create_instance(['course' => $course->id, 'assessed' => 1, 'scale' => 100]);
$gitem = $DB->get_record('grade_items', [
'courseid' => $course->id,
'itemtype' => 'mod',
'itemmodule' => 'data',
'iteminstance' => $data->id,
]);
$this->assertNotEmpty($gitem);
$this->assertEquals(100, $gitem->grademax);
$this->assertEquals(0, $gitem->grademin);
$this->assertEquals(GRADE_TYPE_VALUE, $gitem->gradetype);
}

/**
* @covers ::create_field
*/
public function test_create_field() {
global $DB;

Expand All @@ -80,7 +90,7 @@ public function test_create_field() {
$this->assertInstanceOf('mod_data_generator', $generator);
$this->assertEquals('data', $generator->get_modulename());

$data = $generator->create_instance(array('course' => $course->id));
$data = $generator->create_instance(['course' => $course->id]);
$this->assertEquals(1, $DB->count_records('data'));

$cm = get_coursemodule_from_instance('data', $data->id);
Expand All @@ -91,13 +101,12 @@ public function test_create_field() {
$context = \context_module::instance($cm->id);
$this->assertEquals($data->cmid, $context->instanceid);

$fieldtypes = array('checkbox', 'date', 'menu', 'multimenu', 'number', 'radiobutton', 'text', 'textarea', 'url');
$fieldtypes = ['checkbox', 'date', 'menu', 'multimenu', 'number', 'radiobutton', 'text', 'textarea', 'url'];

$count = 1;

// Creating test Fields with default parameter values.
foreach ($fieldtypes as $fieldtype) {

// Creating variables dynamically.
$fieldname = 'field-' . $count;
$record = new \stdClass();
Expand All @@ -110,9 +119,9 @@ public function test_create_field() {
$count++;
}

$this->assertEquals(count($fieldtypes), $DB->count_records('data_fields', array('dataid' => $data->id)));
$this->assertEquals(count($fieldtypes), $DB->count_records('data_fields', ['dataid' => $data->id]));

$addtemplate = $DB->get_record('data', array('id' => $data->id), 'addtemplate');
$addtemplate = $DB->get_record('data', ['id' => $data->id], 'addtemplate');
$addtemplate = $addtemplate->addtemplate;

for ($i = 1; $i < $count; $i++) {
Expand All @@ -121,6 +130,9 @@ public function test_create_field() {
}
}

/**
* @covers ::create_entry
*/
public function test_create_entry() {
global $DB;

Expand All @@ -133,15 +145,15 @@ public function test_create_entry() {
$course = $this->getDataGenerator()->create_course();
$this->getDataGenerator()->enrol_user($user1->id, $course->id, 'student');

$groupa = $this->getDataGenerator()->create_group(array('courseid' => $course->id, 'name' => 'groupA'));
$this->getDataGenerator()->create_group_member(array('userid' => $user1->id, 'groupid' => $groupa->id));
$groupa = $this->getDataGenerator()->create_group(['courseid' => $course->id, 'name' => 'groupA']);
$this->getDataGenerator()->create_group_member(['userid' => $user1->id, 'groupid' => $groupa->id]);

/** @var mod_data_generator $generator */
$generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
$this->assertInstanceOf('mod_data_generator', $generator);
$this->assertEquals('data', $generator->get_modulename());

$data = $generator->create_instance(array('course' => $course->id));
$data = $generator->create_instance(['course' => $course->id]);
$this->assertEquals(1, $DB->count_records('data'));

$cm = get_coursemodule_from_instance('data', $data->id);
Expand All @@ -152,14 +164,14 @@ public function test_create_entry() {
$context = \context_module::instance($cm->id);
$this->assertEquals($data->cmid, $context->instanceid);

$fieldtypes = array('checkbox', 'date', 'menu', 'multimenu', 'number', 'radiobutton', 'text', 'textarea', 'url',
'latlong', 'file', 'picture');
$fieldtypes = ['checkbox', 'date', 'menu', 'multimenu', 'number', 'radiobutton', 'text', 'textarea', 'url',
'latlong', 'file', 'picture',
];

$count = 1;

// Creating test Fields with default parameter values.
foreach ($fieldtypes as $fieldtype) {

// Creating variables dynamically.
$fieldname = 'field-' . $count;
$record = new \stdClass();
Expand All @@ -172,42 +184,46 @@ public function test_create_entry() {
$count++;
}

$this->assertEquals(count($fieldtypes), $DB->count_records('data_fields', array('dataid' => $data->id)));
$this->assertEquals(count($fieldtypes), $DB->count_records('data_fields', ['dataid' => $data->id]));

$fields = $DB->get_records('data_fields', array('dataid' => $data->id), 'id');
$fields = $DB->get_records('data_fields', ['dataid' => $data->id], 'id');

$contents = array();
$contents[] = array('opt1', 'opt2', 'opt3', 'opt4');
$contents = [];
$contents[] = ['opt1', 'opt2', 'opt3', 'opt4'];
$contents[] = '01-01-2037'; // It should be lower than 2038, to avoid failing on 32-bit windows.
$contents[] = 'menu1';
$contents[] = array('multimenu1', 'multimenu2', 'multimenu3', 'multimenu4');
$contents[] = ['multimenu1', 'multimenu2', 'multimenu3', 'multimenu4'];
$contents[] = '12345';
$contents[] = 'radioopt1';
$contents[] = 'text for testing';
$contents[] = '<p>text area testing<br /></p>';
$contents[] = array('example.url', 'sampleurl');
$contents[] = ['example.url', 'sampleurl'];
$contents[] = [-31.9489873, 115.8382036]; // Latlong.
$contents[] = 'Filename.pdf'; // File - filename.
$contents[] = array('Cat1234.jpg', 'Cat'); // Picture - filename with alt text.
$contents[] = ['Cat1234.jpg', 'Cat']; // Picture - filename with alt text.
$count = 0;
$fieldcontents = array();
$fieldcontents = [];
foreach ($fields as $fieldrecord) {
$fieldcontents[$fieldrecord->id] = $contents[$count++];
}

$tags = ['Cats', 'mice'];

$this->setUser($user1);
$datarecordid = $this->getDataGenerator()->get_plugin_generator('mod_data')->create_entry($data,
$fieldcontents, $groupa->id, $tags);
$datarecordid = $this->getDataGenerator()->get_plugin_generator('mod_data')->create_entry(
$data,
$fieldcontents,
$groupa->id,
$tags
);

$this->assertEquals(1, $DB->count_records('data_records', array('dataid' => $data->id)));
$this->assertEquals(count($contents), $DB->count_records('data_content', array('recordid' => $datarecordid)));
$this->assertEquals(1, $DB->count_records('data_records', ['dataid' => $data->id]));
$this->assertEquals(count($contents), $DB->count_records('data_content', ['recordid' => $datarecordid]));

$entry = $DB->get_record('data_records', array('id' => $datarecordid));
$entry = $DB->get_record('data_records', ['id' => $datarecordid]);
$this->assertEquals($entry->groupid, $groupa->id);

$contents = $DB->get_records('data_content', array('recordid' => $datarecordid), 'id');
$contents = $DB->get_records('data_content', ['recordid' => $datarecordid], 'id');

$contentstartid = 0;
$flag = 0;
Expand All @@ -229,8 +245,10 @@ public function test_create_entry() {
$this->assertEquals($contents[$contentstartid]->content1, '1');
$this->assertEquals($contents[++$contentstartid]->content, 'http://example.url');
$this->assertEquals($contents[$contentstartid]->content1, 'sampleurl');
$this->assertEquals(array('Cats', 'mice'),
array_values(\core_tag_tag::get_item_tags_array('mod_data', 'data_records', $datarecordid)));
$this->assertEquals(
['Cats', 'mice'],
array_values(\core_tag_tag::get_item_tags_array('mod_data', 'data_records', $datarecordid))
);
}

/**
Expand All @@ -250,7 +268,7 @@ public function test_create_preset(?stdClass $record) {
$activity = $this->getDataGenerator()->create_module(manager::MODULE, ['course' => $course]);
$cm = get_coursemodule_from_id(manager::MODULE, $activity->cmid, 0, false, MUST_EXIST);
if (!is_null($record) && property_exists($record, 'user')) {
$user = $this->getDataGenerator()->create_and_enrol($course, 'teacher', (object)['username' => $record->user]);
$user = $this->getDataGenerator()->create_and_enrol($course, 'teacher', (object) ['username' => $record->user]);
$record->userid = $user->id;
unset($record->user);
}
Expand Down

0 comments on commit e8ea491

Please sign in to comment.