Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.

Differences Between: [Versions 39 and 311] [Versions 39 and 400] [Versions 39 and 401] [Versions 39 and 402] [Versions 39 and 403]

   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   4  // Moodle is free software: you can redistribute it and/or modify
   5  // it under the terms of the GNU General Public License as published by
   6  // the Free Software Foundation, either version 3 of the License, or
   7  // (at your option) any later version.
   8  //
   9  // Moodle is distributed in the hope that it will be useful,
  10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  // GNU General Public License for more details.
  13  //
  14  // You should have received a copy of the GNU General Public License
  15  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  /**
  18   * DML Table tests.
  19   *
  20   * @package    core_dml
  21   * @category   phpunit
  22   * @copyright  2019 Andrew Nicols <andrew@nicols.co.uk>
  23   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  24   */
  25  
  26  defined('MOODLE_INTERNAL') || die();
  27  
  28  use \core\dml\table;
  29  
  30  /**
  31   * DML Table tests.
  32   *
  33   * @copyright  2019 Andrew Nicols <andrew@nicols.co.uk>
  34   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  35   * @coversDefaultClass \core\dml\table
  36   */
  37  class core_dml_table_testcase extends database_driver_testcase {
  38  
  39      /**
  40       * Data provider for various \core\dml\table method tests.
  41       *
  42       * @return  array
  43       */
  44      public function get_field_select_provider() : array {
  45          return [
  46              'single field' => [
  47                  'tablename' => 'test_table_single',
  48                  'fieldlist' => [
  49                      'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null],
  50                  ],
  51                  'primarykey' => 'id',
  52                  'fieldprefix' => 'ban',
  53                  'tablealias' => 'banana',
  54                  'banana.id AS banid',
  55              ],
  56              'multiple fields' => [
  57                  'tablename' => 'test_table_multiple',
  58                  'fieldlist' => [
  59                      'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null],
  60                      'course' => ['course', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'],
  61                      'name' => ['name', XMLDB_TYPE_CHAR, '255', null, null, null, 'lala'],
  62                  ],
  63                  'primarykey' => 'id',
  64                  'fieldprefix' => 'ban',
  65                  'tablealias' => 'banana',
  66                  'banana.id AS banid, banana.course AS bancourse, banana.name AS banname',
  67              ],
  68          ];
  69      }
  70  
  71      /**
  72       * Ensure that \core\dml\table::get_field_select() works as expected.
  73       *
  74       * @dataProvider get_field_select_provider
  75       * @covers ::get_field_select
  76       * @param   string      $tablename The name of the table
  77       * @param   array       $fieldlist The list of fields
  78       * @param   string      $primarykey The name of the primary key
  79       * @param   string      $fieldprefix The prefix to use for each field
  80       * @param   string      $tablealias The table AS alias name
  81       * @param   string      $expected The expected SQL
  82       */
  83      public function test_get_field_select(
  84          string $tablename,
  85          array $fieldlist,
  86          string $primarykey,
  87          string $fieldprefix,
  88          string $tablealias,
  89          string $expected
  90      ) {
  91          $dbman = $this->tdb->get_manager();
  92  
  93          $xmldbtable = new xmldb_table($tablename);
  94          $xmldbtable->setComment("This is a test'n drop table. You can drop it safely");
  95  
  96          foreach ($fieldlist as $args) {
  97              call_user_func_array([$xmldbtable, 'add_field'], $args);
  98          }
  99          $xmldbtable->add_key('primary', XMLDB_KEY_PRIMARY, [$primarykey]);
 100          $dbman->create_table($xmldbtable);
 101  
 102          $table = new table($tablename, $tablealias, $fieldprefix);
 103          $this->assertEquals($expected, $table->get_field_select());
 104      }
 105  
 106      /**
 107       * Data provider for \core\dml\table::extract_from_result() tests.
 108       *
 109       * @return  array
 110       */
 111      public function extract_from_result_provider() : array {
 112          return [
 113              'single table' => [
 114                  'fieldlist' => [
 115                      'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null],
 116                      'course' => ['course', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'],
 117                      'flag' => ['flag', XMLDB_TYPE_CHAR, '255', null, null, null, 'lala'],
 118                  ],
 119                  'primarykey' => 'id',
 120                  'prefix' => 's',
 121                  'result' => (object) [
 122                      'sid' => 1,
 123                      'scourse' => 42,
 124                      'sflag' => 'foo',
 125                  ],
 126                  'expectedrecord' => (object) [
 127                      'id' => 1,
 128                      'course' => 42,
 129                      'flag' => 'foo',
 130                  ],
 131              ],
 132              'single table amongst others' => [
 133                  'fieldlist' => [
 134                      'id' => ['id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null],
 135                      'course' => ['course', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'],
 136                      'flag' => ['flag', XMLDB_TYPE_CHAR, '255', null, null, null, 'lala'],
 137                  ],
 138                  'primarykey' => 'id',
 139                  'prefix' => 's',
 140                  'result' => (object) [
 141                      'sid' => 1,
 142                      'scourse' => 42,
 143                      'sflag' => 'foo',
 144                      'oid' => 'id',
 145                      'ocourse' => 'course',
 146                      'oflag' => 'flag',
 147                  ],
 148                  'expectedrecord' => (object) [
 149                      'id' => 1,
 150                      'course' => 42,
 151                      'flag' => 'foo',
 152                  ],
 153              ],
 154          ];
 155      }
 156  
 157      /**
 158       * Ensure that \core\dml\table::extract_from_result() works as expected.
 159       *
 160       * @dataProvider        extract_from_result_provider
 161       * @covers ::extract_from_result
 162       * @param   array       $fieldlist The list of fields
 163       * @param   string      $primarykey The name of the primary key
 164       * @param   string      $fieldprefix The prefix to use for each field
 165       * @param   stdClass    $result The result of the get_records_sql
 166       * @param   stdClass    $expected The expected output
 167       */
 168      public function test_extract_fields_from_result(
 169          array $fieldlist,
 170          string $primarykey,
 171          string $fieldprefix,
 172          stdClass $result,
 173          stdClass $expected
 174      ) {
 175          $dbman = $this->tdb->get_manager();
 176  
 177          $tablename = 'test_table_extraction';
 178          $xmldbtable = new xmldb_table($tablename);
 179          $xmldbtable->setComment("This is a test'n drop table. You can drop it safely");
 180  
 181          foreach ($fieldlist as $args) {
 182              call_user_func_array([$xmldbtable, 'add_field'], $args);
 183          }
 184          $xmldbtable->add_key('primary', XMLDB_KEY_PRIMARY, [$primarykey]);
 185          $dbman->create_table($xmldbtable);
 186  
 187          $table = new table($tablename, 'footable', $fieldprefix);
 188          $this->assertEquals($expected, $table->extract_from_result($result));
 189      }
 190  
 191      /**
 192       * Ensure that \core\dml\table::get_from_sql() works as expected.
 193       *
 194       * @dataProvider get_field_select_provider
 195       * @covers ::get_from_sql
 196       * @param   string      $tablename The name of the table
 197       * @param   array       $fieldlist The list of fields
 198       * @param   string      $primarykey The name of the primary key
 199       * @param   string      $fieldprefix The prefix to use for each field
 200       * @param   string      $tablealias The table AS alias name
 201       * @param   string      $expected The expected SQL
 202       */
 203      public function test_get_from_sql(
 204          string $tablename,
 205          array $fieldlist,
 206          string $primarykey,
 207          string $fieldprefix,
 208          string $tablealias,
 209          string $expected
 210      ) {
 211          $dbman = $this->tdb->get_manager();
 212  
 213          $tablename = 'test_table_extraction';
 214          $xmldbtable = new xmldb_table($tablename);
 215          $xmldbtable->setComment("This is a test'n drop table. You can drop it safely");
 216  
 217          foreach ($fieldlist as $args) {
 218              call_user_func_array([$xmldbtable, 'add_field'], $args);
 219          }
 220          $xmldbtable->add_key('primary', XMLDB_KEY_PRIMARY, [$primarykey]);
 221          $dbman->create_table($xmldbtable);
 222  
 223          $table = new table($tablename, $tablealias, $fieldprefix);
 224  
 225          $this->assertEquals("{{$tablename}} {$tablealias}", $table->get_from_sql());
 226      }
 227  }