Current Path : /usr/opt/php72/share/pear/test/DB/tests/driver/ |
FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64 |
Current File : //usr/opt/php72/share/pear/test/DB/tests/driver/19getlistof.phpt |
--TEST-- DB_driver::getListOf --SKIPIF-- <?php require_once dirname(__FILE__) . '/skipif.inc'; ?> --FILE-- <?php require_once dirname(__FILE__) . '/mktable.inc'; /* * An array with keys containing the $type to be passed to the getListOf() * method. The values of the main array are a sub-array that has keys * listing the phptype and dbsyntax of each driver and values of the * result expected from the combination of all these factors. */ $tests = array( 'tables' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => 'array', 'ibase:ibase' => 'array', 'ibase:firebird' => 'array', 'ifx:ifx' => 'array', 'msql:msql' => 'array', 'mssql:mssql' => 'array', 'mysql:mysql' => 'array', 'mysqli:mysqli' => 'array', 'oci8:oci8' => 'array', 'odbc:access' => 'array', 'odbc:db2' => 'array', 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => 'array', 'sybase:sybase' => 'array', ), 'views' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => 'array', 'ibase:ibase' => 'array', 'ibase:firebird' => 'array', 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => 'array', 'mysql:mysql' => DB_ERROR_UNSUPPORTED, 'mysqli:mysqli' => DB_ERROR_UNSUPPORTED, 'oci8:oci8' => 'array', 'odbc:access' => 'array', 'odbc:db2' => 'array', 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => 'array', ), 'users' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => 'array', 'ibase:ibase' => 'array', 'ibase:firebird' => 'array', 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => DB_ERROR_ACCESS_VIOLATION, 'mysqli:mysqli' => DB_ERROR_ACCESS_VIOLATION, 'oci8:oci8' => DB_ERROR_UNSUPPORTED, 'odbc:access' => DB_ERROR_UNSUPPORTED, 'odbc:db2' => DB_ERROR_UNSUPPORTED, 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), 'databases' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => DB_ERROR_UNSUPPORTED, 'ibase:ibase' => DB_ERROR_UNSUPPORTED, 'ibase:firebird' => DB_ERROR_UNSUPPORTED, 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => 'array', 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => 'array', 'mysqli:mysqli' => 'array', 'oci8:oci8' => DB_ERROR_UNSUPPORTED, 'odbc:access' => 'array', 'odbc:db2' => 'array', 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), 'functions' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => 'array', 'ibase:ibase' => DB_ERROR_UNSUPPORTED, 'ibase:firebird' => DB_ERROR_UNSUPPORTED, 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => DB_ERROR_UNSUPPORTED, 'mysqli:mysqli' => DB_ERROR_UNSUPPORTED, 'oci8:oci8' => DB_ERROR_UNSUPPORTED, 'odbc:access' => DB_ERROR_UNSUPPORTED, 'odbc:db2' => DB_ERROR_UNSUPPORTED, 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), 'procedures' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => 'array', 'ibase:ibase' => DB_ERROR_UNSUPPORTED, 'ibase:firebird' => DB_ERROR_UNSUPPORTED, 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => DB_ERROR_UNSUPPORTED, 'mysqli:mysqli' => DB_ERROR_UNSUPPORTED, 'oci8:oci8' => DB_ERROR_UNSUPPORTED, 'odbc:access' => DB_ERROR_UNSUPPORTED, 'odbc:db2' => DB_ERROR_UNSUPPORTED, 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), 'schema.tables' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => DB_ERROR_UNSUPPORTED, 'ibase:ibase' => DB_ERROR_UNSUPPORTED, 'ibase:firebird' => DB_ERROR_UNSUPPORTED, 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => DB_ERROR_UNSUPPORTED, 'mysqli:mysqli' => DB_ERROR_UNSUPPORTED, 'oci8:oci8' => DB_ERROR_UNSUPPORTED, 'odbc:access' => 'array', 'odbc:db2' => 'array', 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), 'schema.views' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => DB_ERROR_UNSUPPORTED, 'ibase:ibase' => DB_ERROR_UNSUPPORTED, 'ibase:firebird' => DB_ERROR_UNSUPPORTED, 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => DB_ERROR_UNSUPPORTED, 'mysqli:mysqli' => DB_ERROR_UNSUPPORTED, 'oci8:oci8' => DB_ERROR_UNSUPPORTED, 'odbc:access' => DB_ERROR_UNSUPPORTED, 'odbc:db2' => DB_ERROR_UNSUPPORTED, 'pgsql:pgsql' => 'array', 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), 'synonyms' => array( 'dbase:dbase' => DB_ERROR_UNSUPPORTED, 'fbsql:fbsql' => DB_ERROR_UNSUPPORTED, 'ibase:ibase' => DB_ERROR_UNSUPPORTED, 'ibase:firebird' => DB_ERROR_UNSUPPORTED, 'ifx:ifx' => DB_ERROR_UNSUPPORTED, 'msql:msql' => DB_ERROR_UNSUPPORTED, 'mssql:mssql' => DB_ERROR_UNSUPPORTED, 'mysql:mysql' => DB_ERROR_UNSUPPORTED, 'mysqli:mysqli' => DB_ERROR_UNSUPPORTED, 'oci8:oci8' => 'array', 'odbc:access' => DB_ERROR_UNSUPPORTED, 'odbc:db2' => DB_ERROR_UNSUPPORTED, 'pgsql:pgsql' => DB_ERROR_UNSUPPORTED, 'sqlite:sqlite' => DB_ERROR_UNSUPPORTED, 'sybase:sybase' => DB_ERROR_UNSUPPORTED, ), ); /** * Determine if the output from the driver matches what we expect * * If things are as we expect, nothing is printed out. * * If things go wrong, print "UNEXPECTED OUTCOME" and display * what happened. * * @param mixed $result the result from getListOf * @param mixed $expected the expected result * @param string $name the name of the current test * * @return void */ function check_output($result, $expected, $name) { if (is_object($result)) { if ($result->getCode() !== $expected) { echo "UNEXPECTED OUTCOME FOR $name...\n"; echo $result->getDebugInfo() . "\n"; } } else { $type = gettype($result); if ($type != $expected) { if ($expected === DB_ERROR_ACCESS_VIOLATION && $type == 'array') { // This user has access to the mysql table. // Not a problem } else { echo "UNEXPECTED OUTCOME FOR $name...\n"; echo " Expected: $expected\n"; echo ' Result: '; print_r($result); echo "\n"; } } } } $dbh->setErrorHandling(PEAR_ERROR_RETURN); foreach ($tests as $test => $dbms) { check_output($dbh->getListOf($test), $dbms[$dbh->phptype . ':' . $dbh->dbsyntax], $test); } drop_table($dbh, 'phptest'); ?> --EXPECT--