--TEST-- Bug #51647 (Certificate file without private key (pk in another file) doesn't work) --SKIPIF-- host_info, 'TCP/IP')) die(sprintf("skip SSL only supported on TCP/IP")); $row = NULL; if ($res = $link->query('SHOW VARIABLES LIKE "have_ssl"')) { $row = $res->fetch_row(); } else { if ($link->errno == 1064 && ($res = $link->query("SHOW VARIABLES"))) { while ($row = $res->fetch_row()) if ($row[0] == 'have_ssl') break; } else { die(sprintf("skip Failed to test for MySQL SSL support, [%d] %s", $link->errno, $link->error)); } } if (empty($row)) die(sprintf("skip Failed to test for MySQL SSL support, [%d] %s", $link->errno, $link->error)); if (($row[1] == 'NO') || ($row[1] == 'DISABLED')) die(sprintf("skip MySQL has no SSL support, [%d] %s", $link->errno, $link->error)); $link->close(); ?> --FILE-- query('SHOW STATUS like "Ssl_cipher"')) { if (1064 == $link->errno) { /* ERROR 1064 (42000): You have an error in your SQL syntax; = sql strict mode */ if ($res = $link->query("SHOW STATUS")) { while ($row = $res->fetch_assoc()) if ($row['Variable_name'] == 'Ssl_cipher') break; } else { printf("[005] [%d] %s\n", $link->errno, $link->error); } } else { printf("[004] [%d] %s\n", $link->errno, $link->error); } } else { if (!$row = $res->fetch_assoc()) printf("[006] [%d] %s\n", $link->errno, $link->error); if (!strlen($row["Value"])) printf("[007] Empty cipher. No encryption!"); var_dump($row); } $link->close(); if (!is_object($link = mysqli_init())) printf("[008] Cannot create link\n"); if (!my_mysqli_real_connect($link, $host, $user, $passwd, $db, $port, $socket, MYSQLI_CLIENT_SSL)) { printf("[009] Connect failed, [%d] %s\n", mysqli_connect_errno(), mysqli_connect_error()); } if (!$res = $link->query('SHOW STATUS like "Ssl_cipher"')) { if (1064 == $link->errno) { /* ERROR 1064 (42000): You have an error in your SQL syntax; = sql strict mode */ if ($res = $link->query("SHOW STATUS")) { while ($row = $res->fetch_assoc()) if ($row['Variable_name'] == 'Ssl_cipher') break; } else { printf("[010] [%d] %s\n", $link->errno, $link->error); } } else { printf("[011] [%d] %s\n", $link->errno, $link->error); } } else { if (!$row = $res->fetch_assoc()) printf("[012] [%d] %s\n", $link->errno, $link->error); if (!strlen($row["Value"])) printf("[013] Empty cipher. No encryption!"); var_dump($row); } $link->close(); print "done!"; ?> --EXPECTF-- array(2) { ["Variable_name"]=> string(10) "Ssl_cipher" ["Value"]=> string(%d) "%S" } array(2) { ["Variable_name"]=> string(10) "Ssl_cipher" ["Value"]=> string(%d) "%S" } done!