<?php /** * Query * * Free Query Builder / Database Abstraction Layer * * @package Query * @author Timothy J. Warren * @copyright Copyright (c) 2012 - 2014 * @link https://github.com/aviat4ion/Query * @license http://philsturgeon.co.uk/code/dbad-license */ // -------------------------------------------------------------------------- /** * @requires extension pdo_mysql */ class MySQLQBTest extends QBTest { public function setUp() { // Attempt to connect, if there is a test config file if (is_file(QTEST_DIR . "/settings.json")) { $params = json_decode(file_get_contents(QTEST_DIR . "/settings.json")); $params = $params->mysql; $params->type = "MySQL"; $params->options = array(); $params->options[PDO::ATTR_PERSISTENT] = TRUE; } elseif (($var = getenv('CI'))) // Travis CI Connection Info { $params = array( 'host' => '127.0.0.1', 'port' => '3306', 'database' => 'test', 'prefix' => 'create_', 'user' => 'root', 'pass' => NULL, 'type' => 'mysql' ); } $this->db = Query($params); //echo "Mysql Queries <br />"; } // -------------------------------------------------------------------------- public function testExists() { $this->assertTrue(in_array('mysql', PDO::getAvailableDrivers())); } // -------------------------------------------------------------------------- public function testQueryExplain() { $query = $this->db->select('id, key as k, val') ->explain() ->where('id >', 1) ->where('id <', 900) ->get('test', 2, 1); $res = $query->fetchAll(PDO::FETCH_ASSOC); $expected = array ( array ( 'id' => '1', 'select_type' => 'SIMPLE', 'table' => 'create_test', 'type' => 'range', 'possible_keys' => 'PRIMARY', 'key' => 'PRIMARY', 'key_len' => '4', 'ref' => NULL, 'rows' => '1', 'filtered' => '100.00', 'Extra' => 'Using where', ) ); $this->assertEqual($expected, $res); } }