mirror of
https://github.com/php/php-src.git
synced 2024-10-20 16:02:44 +00:00
f8156f1607
Currently they have failed by default. Note also the environment variable MYSQL_TEST_SKIP_CONNECT_FAILURE to control the default (skip or fail)
71 lines
2.2 KiB
PHP
71 lines
2.2 KiB
PHP
--TEST--
|
|
mysql_client_encoding()
|
|
--SKIPIF--
|
|
<?php
|
|
require_once('skipif.inc');
|
|
require_once('skipifconnectfailure.inc');
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
include_once "connect.inc";
|
|
|
|
$tmp = NULL;
|
|
$link = NULL;
|
|
|
|
if (!$link = my_mysql_connect($host, $user, $passwd, $db, $port, $socket))
|
|
printf("[002] Cannot connect to the server using host=%s, user=%s, passwd=***, dbname=%s, port=%s, socket=%s\n",
|
|
$host, $user, $db, $port, $socket);
|
|
|
|
$default_link_enc = mysql_client_encoding();
|
|
$link_enc = mysql_client_encoding($link);
|
|
|
|
if ($default_link_enc !== $link_enc)
|
|
printf("[003] %s != %s, [%d] %s\n", $default_link_enc, $link_enc, mysql_errno($link), mysql_error($link));
|
|
|
|
if (!$res = mysql_query('SELECT version() AS server_version', $link))
|
|
printf("[004] [%d] %s\n", mysql_errno($link), mysql_error($link));
|
|
$tmp = mysql_fetch_assoc($res);
|
|
mysql_free_result($res);
|
|
$version = explode('.', $tmp['server_version']);
|
|
if (empty($version))
|
|
printf("[005] Cannot determine server version, need MySQL Server 4.1+ for the test!\n");
|
|
|
|
if ($version[0] <= 4 && $version[1] < 1)
|
|
printf("[006] Need MySQL Server 4.1+ for the test!\n");
|
|
|
|
if (!$res = mysql_query('SELECT @@character_set_connection AS charset, @@collation_connection AS collation', $link))
|
|
printf("[007] [%d] %s\n", mysql_errno($link), mysql_error($link));
|
|
$tmp = mysql_fetch_assoc($res);
|
|
mysql_free_result($res);
|
|
if (!$tmp['charset'])
|
|
printf("[008] Cannot determine current character set and collation\n");
|
|
|
|
if ($link_enc !== $tmp['charset']) {
|
|
if ($link_enc === $tmp['collation']) {
|
|
printf("[009] Known bug, collation instead of chatset returned, http://bugs.mysql.com/bug.php?id=7923\n");
|
|
} else {
|
|
printf("[009] Check manually, watch out for unicode and others\n");
|
|
var_dump($link_enc);
|
|
var_dump($tmp);
|
|
}
|
|
}
|
|
|
|
if (ini_get('unicode.semantics') && function_exists('is_unicode')) {
|
|
// unicode mode
|
|
if (!is_unicode($default_link_enc) || !is_unicode($link_enc)) {
|
|
printf("[010] No unicode returned!\n");
|
|
var_dump($default_link_enc);
|
|
var_dump($link_enc);
|
|
}
|
|
}
|
|
|
|
mysql_close($link);
|
|
|
|
if (false !== ($tmp = @mysql_client_encoding($link)))
|
|
printf("[012] Expecting boolean/false, got %s/%s\n", gettype($tmp), $tmp);
|
|
|
|
print "done!";
|
|
?>
|
|
--EXPECTF--
|
|
done!
|