123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- --TEST--
- new mysqli()
- --EXTENSIONS--
- mysqli
- --SKIPIF--
- <?php
- require_once('skipifconnectfailure.inc');
- ?>
- --FILE--
- <?php
- require_once("connect.inc");
- $tmp = NULL;
- $link = NULL;
- $obj = new stdClass();
- if ($mysqli = new mysqli($host, $user . 'unknown_really', $passwd . 'non_empty', $db, $port, $socket) && !mysqli_connect_errno())
- printf("[003] Can connect to the server using host=%s, user=%s, passwd=***non_empty, dbname=%s, port=%s, socket=%s\n",
- $host, $user . 'unknown_really', $db, $port, $socket);
- if (false !== $mysqli)
- printf("[004] Expecting boolean/false, got %s/%s\n", gettype($mysqli), $mysqli);
- // Run the following tests without an anoynmous MySQL user and use a password for the test user!
- ini_set('mysqli.default_socket', $socket);
- if (!is_object($mysqli = new mysqli($host, $user, $passwd, $db, $port)) || (0 !== mysqli_connect_errno())) {
- printf("[005] Usage of mysqli.default_socket failed\n") ;
- } else {
- $mysqli->close();
- }
- ini_set('mysqli.default_port', $port);
- if (!is_object($mysqli = new mysqli($host, $user, $passwd, $db)) || (0 !== mysqli_connect_errno())) {
- printf("[006] Usage of mysqli.default_port failed\n") ;
- } else {
- $mysqli->close();
- }
- ini_set('mysqli.default_pw', $passwd);
- if (!is_object($mysqli = new mysqli($host, $user)) || (0 !== mysqli_connect_errno())) {
- printf("[007] Usage of mysqli.default_pw failed\n") ;
- } else {
- $mysqli->close();
- }
- ini_set('mysqli.default_user', $user);
- if (!is_object($mysqli = new mysqli($host)) || (0 !== mysqli_connect_errno())) {
- printf("[008] Usage of mysqli.default_user failed\n") ;
- } else {
- $mysqli->close();
- }
- ini_set('mysqli.default_host', $host);
- if (!is_object($mysqli = new mysqli()) || (0 !== mysqli_connect_errno())) {
- printf("[012] Failed to create mysqli object\n");
- } else {
- // There shall be NO connection! Using new mysqli(void) shall not use defaults for a connection!
- // We had long discussions on this and found that the ext/mysqli API as
- // such is broken. As we can't fix it, we document how it has behaved from
- // the first day on. And that's: no connection.
- try {
- $mysqli->query('SELECT 1');
- } catch (Error $exception) {
- echo $exception->getMessage() . "\n";
- }
- }
- if ($IS_MYSQLND) {
- ini_set('mysqli.default_host', 'p:' . $host);
- if (!is_object($mysqli = new mysqli())) {
- // Due to an API flaw this shall not connect
- printf("[010] Failed to create mysqli object\n");
- } else {
- // There shall be NO connection! Using new mysqli(void) shall not use defaults for a connection!
- // We had long discussions on this and found that the ext/mysqli API as
- // such is broken. As we can't fix it, we document how it has behaved from
- // the first day on. And that's: no connection.
- try {
- $mysqli->query('SELECT 1');
- } catch (Error $exception) {
- echo $exception->getMessage() . "\n";
- }
- }
- }
- print "... and now Exceptions\n";
- mysqli_report(MYSQLI_REPORT_OFF);
- mysqli_report(MYSQLI_REPORT_STRICT);
- try {
- $mysqli = new mysqli($host, $user . 'unknown_really', $passwd . 'non_empty', $db, $port, $socket);
- printf("[016] Can connect to the server using host=%s, user=%s, passwd=***non_empty, dbname=%s, port=%s, socket=%s\n",
- $host, $user . 'unknown_really', $db, $port, $socket);
- $mysqli->close();
- } catch (mysqli_sql_exception $e) {
- printf("%s\n", $e->getMessage());
- }
- ini_set('mysqli.default_socket', $socket);
- try {
- $mysqli = new mysqli($host, $user, $passwd, $db, $port);
- $mysqli->close();
- } catch (mysqli_sql_exception $e) {
- printf("%s\n", $e->getMessage());
- printf("[017] Usage of mysqli.default_socket failed\n") ;
- }
- ini_set('mysqli.default_port', $port);
- try {
- $mysqli = new mysqli($host, $user, $passwd, $db);
- $mysqli->close();
- } catch (mysqli_sql_exception $e) {
- printf("%s\n", $e->getMessage());
- printf("[018] Usage of mysqli.default_port failed\n") ;
- }
- ini_set('mysqli.default_pw', $passwd);
- try {
- $mysqli = new mysqli($host, $user);
- $mysqli->close();
- } catch (mysqli_sql_exception $e) {
- printf("%s\n", $e->getMessage());
- printf("[019] Usage of mysqli.default_pw failed\n");
- }
- ini_set('mysqli.default_user', $user);
- try {
- $mysqli = new mysqli($host);
- $mysqli->close();
- } catch (mysqli_sql_exception $e) {
- printf("%s\n", $e->getMessage());
- printf("[020] Usage of mysqli.default_user failed\n") ;
- }
- ini_set('mysqli.default_host', $host);
- try {
- /* NOTE that at this point one must use a different syntax! */
- $mysqli = mysqli_init();
- $mysqli->real_connect();
- assert(0 === mysqli_connect_errno());
- $mysqli->close();
- assert(0 === mysqli_connect_errno());
- } catch (mysqli_sql_exception $e) {
- printf("%s\n", $e->getMessage());
- printf("[021] Usage of mysqli.default_host failed\n");
- }
- print "done!";
- ?>
- --EXPECTF--
- Warning: mysqli::__construct(): (%s/%d): Access denied for user '%sunknown%s'@'%s' (using password: %s) in %s on line %d
- mysqli object is not fully initialized
- mysqli object is not fully initialized
- ... and now Exceptions
- Access denied for user '%s'@'%s' (using password: %s)
- done!
|