| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
 | --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 ((version_compare(PHP_VERSION, '5.9.9', '>') == 1) && 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--
Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in %s on line %d
done!
 |