. /** * DML Table tests. * * @package core_dml * @category phpunit * @copyright 2019 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); use \core\dml\table; /** * DML Table tests. * * @copyright 2019 Andrew Nicols * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later * @coversDefaultClass \core\dml\table * @covers :: */ class core_dml_table_testcase extends database_driver_testcase { /** * Data provider for various \core\dml\table method tests. * * @return array */ public function get_field_select_provider() : array { return [ 'single field' => [ 'tablename' => 'test_table_single', 'fieldlist' => [ 'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null], ], 'primarykey' => 'id', 'fieldprefix' => 'ban', 'tablealias' => 'banana', 'banana.id AS banid', ], 'multiple fields' => [ 'tablename' => 'test_table_multiple', 'fieldlist' => [ 'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null], 'course' => ['course', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'], 'name' => ['name', XMLDB_TYPE_CHAR, '255', null, null, null, 'lala'], ], 'primarykey' => 'id', 'fieldprefix' => 'ban', 'tablealias' => 'banana', 'banana.id AS banid, banana.course AS bancourse, banana.name AS banname', ], ]; } /** * Ensure that \core\dml\table::get_field_select() works as expected. * * @dataProvider get_field_select_provider * @covers ::get_field_select * @param string $tablename The name of the table * @param array $fieldlist The list of fields * @param string $primarykey The name of the primary key * @param string $fieldprefix The prefix to use for each field * @param string $tablealias The table AS alias name * @param string $expected The expected SQL */ public function test_get_field_select( string $tablename, array $fieldlist, string $primarykey, string $fieldprefix, string $tablealias, string $expected ) { $dbman = $this->tdb->get_manager(); $xmldbtable = new xmldb_table($tablename); $xmldbtable->setComment("This is a test'n drop table. You can drop it safely"); foreach ($fieldlist as $args) { call_user_func_array([$xmldbtable, 'add_field'], $args); } $xmldbtable->add_key('primary', XMLDB_KEY_PRIMARY, [$primarykey]); $dbman->create_table($xmldbtable); $table = new table($tablename, $tablealias, $fieldprefix); $this->assertEquals($expected, $table->get_field_select()); } /** * Data provider for \core\dml\table::extract_from_result() tests. * * @return array */ public function extract_from_result_provider() : array { return [ 'single table' => [ 'fieldlist' => [ 'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null], 'course' => ['course', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'], 'flag' => ['flag', XMLDB_TYPE_CHAR, '255', null, null, null, 'lala'], ], 'primarykey' => 'id', 'prefix' => 's', 'result' => (object) [ 'sid' => 1, 'scourse' => 42, 'sflag' => 'foo', ], 'expectedrecord' => (object) [ 'id' => 1, 'course' => 42, 'flag' => 'foo', ], ], 'single table amongst others' => [ 'fieldlist' => [ 'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null], 'course' => ['course', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'], 'flag' => ['flag', XMLDB_TYPE_CHAR, '255', null, null, null, 'lala'], ], 'primarykey' => 'id', 'prefix' => 's', 'result' => (object) [ 'sid' => 1, 'scourse' => 42, 'sflag' => 'foo', 'oid' => 'id', 'ocourse' => 'course', 'oflag' => 'flag', ], 'expectedrecord' => (object) [ 'id' => 1, 'course' => 42, 'flag' => 'foo', ], ], ]; } /** * Ensure that \core\dml\table::extract_from_result() works as expected. * * @dataProvider extract_from_result_provider * @covers ::extract_from_result * @param array $fieldlist The list of fields * @param string $primarykey The name of the primary key * @param string $fieldprefix The prefix to use for each field * @param stdClass $result The result of the get_records_sql * @param stdClass $expected The expected output */ public function test_extract_fields_from_result( array $fieldlist, string $primarykey, string $fieldprefix, stdClass $result, stdClass $expected ) { $dbman = $this->tdb->get_manager(); $tablename = 'test_table_extraction'; $xmldbtable = new xmldb_table($tablename); $xmldbtable->setComment("This is a test'n drop table. You can drop it safely"); foreach ($fieldlist as $args) { call_user_func_array([$xmldbtable, 'add_field'], $args); } $xmldbtable->add_key('primary', XMLDB_KEY_PRIMARY, [$primarykey]); $dbman->create_table($xmldbtable); $table = new table($tablename, 'footable', $fieldprefix); $this->assertEquals($expected, $table->extract_from_result($result)); } /** * Ensure that \core\dml\table::get_from_sql() works as expected. * * @dataProvider get_field_select_provider * @covers ::get_from_sql * @param string $tablename The name of the table * @param array $fieldlist The list of fields * @param string $primarykey The name of the primary key * @param string $fieldprefix The prefix to use for each field * @param string $tablealias The table AS alias name * @param string $expected The expected SQL */ public function test_get_from_sql( string $tablename, array $fieldlist, string $primarykey, string $fieldprefix, string $tablealias, string $expected ) { $dbman = $this->tdb->get_manager(); $tablename = 'test_table_extraction'; $xmldbtable = new xmldb_table($tablename); $xmldbtable->setComment("This is a test'n drop table. You can drop it safely"); foreach ($fieldlist as $args) { call_user_func_array([$xmldbtable, 'add_field'], $args); } $xmldbtable->add_key('primary', XMLDB_KEY_PRIMARY, [$primarykey]); $dbman->create_table($xmldbtable); $table = new table($tablename, $tablealias, $fieldprefix); $this->assertEquals("{{$tablename}} {$tablealias}", $table->get_from_sql()); } }