Merge branch 'MDL-34211' of git://github.com/appalachianstate/moodle into MOODLE_23_S...
[moodle.git] / enrol / database / tests / adodb_test.php
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/>.
17 /**
18  * basic adodb connection test
19  *
20  * @package    enrol_database
21  * @category   phpunit
22  * @copyright  2011 Petr Skoda {@link http://skodak.org}
23  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24  */
26 defined('MOODLE_INTERNAL') || die();
28 global $CFG;
29 require_once($CFG->dirroot.'/enrol/database/lib.php');
31 class core_adodb_testcase extends advanced_testcase {
32     public function test_read_table() {
33         global $DB, $CFG;
35         $this->resetAfterTest();
37         set_config('dbencoding', 'utf-8', 'enrol_database');
39         set_config('dbhost', $CFG->dbhost, 'enrol_database');
40         set_config('dbuser', $CFG->dbuser, 'enrol_database');
41         set_config('dbpass', $CFG->dbpass, 'enrol_database');
42         set_config('dbname', $CFG->dbname, 'enrol_database');
44         if (!empty($CFG->dboptions['dbport'])) {
45             set_config('dbhost', $CFG->dbhost.':'.$CFG->dboptions['dbport'], 'enrol_database');
46         }
48         switch (get_class($DB)) {
49             case 'mssql_native_moodle_database':
50                 set_config('dbtype', 'mssql_n', 'enrol_database');
51                 set_config('dbsybasequoting', '1', 'enrol_database');
52                 break;
54             case 'mysqli_native_moodle_database':
55                 set_config('dbtype', 'mysqli', 'enrol_database');
56                 set_config('dbsetupsql', 'SET NAMES \'UTF-8\'', 'enrol_database');
57                 set_config('dbsybasequoting', '0', 'enrol_database');
58                 if (!empty($CFG->dboptions['dbsocket'])) {
59                     set_config('dbtype', 'mysqli://'.rawurlencode($CFG->dbuser).':'.rawurlencode($CFG->dbpass).'@'.rawurlencode($CFG->dbhost).'/'.rawurlencode($CFG->dbname).'?socket='.rawurlencode($CFG->dboptions['dbsocket']), 'enrol_database');
60                 }
61                 break;
63             case 'oci_native_moodle_database':
64                 set_config('dbtype', 'oci8po', 'enrol_database');
65                 set_config('dbsybasequoting', '1', 'enrol_database');
66                 break;
68             case 'pgsql_native_moodle_database':
69                 set_config('dbtype', 'postgres7', 'enrol_database');
70                 set_config('dbsetupsql', 'SET NAMES \'UTF-8\'', 'enrol_database');
71                 set_config('dbsybasequoting', '0', 'enrol_database');
72                 if (!empty($CFG->dboptions['dbsocket']) and ($CFG->dbhost === 'localhost' or $CFG->dbhost === '127.0.0.1')) {
73                     if (strpos($CFG->dboptions['dbsocket'], '/') !== false) {
74                       set_config('dbhost', $CFG->dboptions['dbsocket'], 'enrol_database');
75                     } else {
76                       set_config('dbhost', '', 'enrol_database');
77                     }
78                 }
79                 break;
81             case 'sqlsrv_native_moodle_database':
82                 set_config('dbtype', 'mssqlnative', 'enrol_database');
83                 set_config('dbsybasequoting', '1', 'enrol_database');
84                 break;
86             default:
87                 $this->markTestSkipped('Unknown database driver.');
88                 return;
89         }
91         $plugin = new enrol_database_tester();
93         // can we connect?
94         $extdb = $plugin->test_get_db_init();
95         $this->assertNotEmpty($extdb);
97         // let's fetch one row
98         $sql = $plugin->test_db_get_sql($CFG->prefix.'user', array('id'=>2), array('id', 'username'));
99         $rs = $extdb->Execute($sql);
100         $this->assertEmpty($rs->EOF);
101         $row = $rs->FetchRow();
102         $row = array_change_key_case($row, CASE_LOWER);
103         $this->assertEquals('2', $row['id']);
104         $this->assertEquals('admin', $row['username']);
105         $this->assertEmpty($rs->FetchRow());
106         $rs->Close();
108         $extdb->Close();
109     }
113 class enrol_database_tester extends enrol_database_plugin {
114     public function test_get_db_init() {
115         return self::db_init();
116     }
118     public function test_db_get_sql($table, array $conditions, array $fields, $distinct = false, $sort = "") {
119         return self::db_get_sql($table, $conditions, $fields, $distinct, $sort);
120     }