--TEST--
mysqli_fetch_assoc() - ZEROFILL
--SKIPIF--
<?php
require_once('skipif.inc');
require_once(
'skipifemb.inc');
require_once(
'skipifconnectfailure.inc');
?>
--FILE--
<?php
    
require_once('connect.inc');
    require_once(
'table.inc');

    function 
zerofill($offset$link$datatype$insert 1) {

        
mysqli_query($link'ALTER TABLE test DROP zero');
        
$sql sprintf('ALTER TABLE test ADD zero %s UNSIGNED ZEROFILL'$datatype);
        if (!
mysqli_query($link$sql)) {
            
// no worries - server might not support it
            
return true;
        }

        if (!
mysqli_query($linksprintf('UPDATE test SET zero = %s'$insert))) {
            
printf("[%03d] UPDATE failed, [%d] %s\n",
                
$offsetmysqli_errno($link), mysqli_error($link));
            return 
false;
        }

        if (!(
$res mysqli_query($link'SELECT zero FROM test LIMIT 1'))) {
            
printf("[%03d] SELECT failed, [%d] %s\n",
                
$offsetmysqli_errno($link), mysqli_error($link));
            return 
false;
        }

        
$row mysqli_fetch_assoc($res);
        
$meta mysqli_fetch_fields($res);
        
mysqli_free_result($res);
        
$meta $meta[0];
        
$length $meta->length;
        if (
$length strlen($insert)) {

            
$expected str_repeat('0'$length strlen($insert));
            
$expected .= $insert;
            if (
$expected !== $row['zero']) {
                
printf("[%03d] Expecting '%s' got '%s'\n"$offset$expected$row['zero']);
                return 
false;
            }

        } else if (
$length <= 1) {
            
printf("[%03d] Length reported is too small to run test\n"$offset);
            return 
false;
        }

        return 
true;
    }

    
zerofill(2$link'TINYINT');
    
zerofill(3$link'SMALLINT');
    
zerofill(4$link'MEDIUMINT');
    
zerofill(5$link'INT');
    
zerofill(6$link'INTEGER');
    
zerofill(7$link'BIGINT');
    
zerofill(8$link'FLOAT');
    
zerofill(9$link'DOUBLE');
    
zerofill(10$link'DOUBLE PRECISION');
    
zerofill(11$link'DECIMAL');
    
zerofill(12$link'DEC');

    
mysqli_close($link);

    print 
"done!";
?>
--CLEAN--
<?php
    
require_once("clean_table.inc");
?>
--EXPECTF--
done!