Annotation of embedaddon/php/ext/mysqli/tests/mysqli_set_local_infile_handler.phpt, revision 1.1.1.1

1.1       misho       1: --TEST--
                      2: mysqli_set_local_infile_handler()
                      3: --SKIPIF--
                      4: <?php
                      5: require_once('skipif.inc');
                      6: require_once('skipifemb.inc');
                      7: require_once('skipifconnectfailure.inc');
                      8: 
                      9: if (!function_exists('mysqli_set_local_infile_handler'))
                     10:        die("skip - function not available.");
                     11: 
                     12: require_once('connect.inc');
                     13: if (!$link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket))
                     14:        die("skip Cannot connect to MySQL");
                     15: 
                     16: include_once("local_infile_tools.inc");
                     17: if ($msg = check_local_infile_support($link, $engine))
                     18:        die(sprintf("skip %s, [%d] %s", $msg, $link->errno, $link->error));
                     19: 
                     20: mysqli_close($link);
                     21: ?>
                     22: --INI--
                     23: mysqli.allow_local_infile=1
                     24: --FILE--
                     25: <?php
                     26:        require_once('connect.inc');
                     27:        require_once('local_infile_tools.inc');
                     28:        require_once('table.inc');
                     29: 
                     30:        function callback_simple($fp, &$buffer, $buflen, &$error) {
                     31:                static $invocation = 0;
                     32: 
                     33:                printf("Callback: %d\n", $invocation);
                     34: 
                     35:                $invocation++;
                     36:                if (!is_resource($fp))
                     37:                        printf("[012] First argument passed to callback is not a resource but %s/%s\n",
                     38:                                $fp, gettype($fp));
                     39: 
                     40:                if (!$buffer = fread($fp, $buflen)) {
                     41:                        if ($invocation == 1) {
                     42:                                printf("[013] Cannot read from stream\n");
                     43:                                        $error = 'Cannot read from stream';
                     44:                        } else {
                     45:                                return strlen($buffer);
                     46:                        }
                     47:                }
                     48: 
                     49:                $lines = explode("\n", $buffer);
                     50:                if (count($lines) != 4 && strlen($buffer) > 0) {
                     51:                        printf("[014] Test is too simple to handle a buffer of size %d that cannot hold all lines\n", $buflen);
                     52:                        $error = 'Parser too simple';
                     53:                }
                     54: 
                     55:                $buffer = '';
                     56:                foreach ($lines as $k => $line) {
                     57:                        if ('' === trim($line))
                     58:                                continue;
                     59: 
                     60:                        $columns = explode(';', $line);
                     61:                        if (empty($columns)) {
                     62:                                printf("[015] Cannot parse columns\n");
                     63:                                $error = 'Cannot parse columns';
                     64:                        }
                     65: 
                     66:                        // increase id column value
                     67:                        $columns[0] += 1;
                     68:                        $buffer .= implode(';', $columns);
                     69:                        $buffer .= "\n";
                     70:                }
                     71: 
                     72:                return strlen($buffer);
                     73:        }
                     74: 
                     75:        function callback_fclose($fp, &$buffer, $buflen, &$error) {
                     76:                static $invocation = 0;
                     77: 
                     78:                printf("Callback: %d\n", $invocation++);
                     79: 
                     80:                fclose($fp);
                     81:                return strlen($buffer);
                     82:        }
                     83: 
                     84:        function callback_closefile($fp, &$buffer, $buflen, &$error) {
                     85:                static $invocation = 0;
                     86: 
                     87:                printf("Callback: %d\n", $invocation++);
                     88:                flush();
                     89:                if (is_resource($fp))
                     90:                        fclose($fp);
                     91:                $buffer = "1;'a';\n";
                     92:                if ($invocation > 10)
                     93:                        return 0;
                     94: 
                     95:                return strlen($buffer);
                     96:        }
                     97: 
                     98:        function callback_invalid_args($fp, &$buffer, $buflen) {
                     99:                static $invocation = 0;
                    100: 
                    101:                printf("Callback: %d\n", $invocation++);
                    102:                $buffer = fread($fp, $buflen);
                    103: 
                    104:                return strlen($buffer);
                    105:        }
                    106: 
                    107:        function callback_error($fp, &$buffer, $buflen, &$error) {
                    108:                static $invocation = 0;
                    109: 
                    110:                printf("Callback: %d\n", $invocation++);
                    111:                $buffer = fread($fp, $buflen);
                    112:                $error = 'How to access this error?';
                    113: 
                    114:                return -1;
                    115:        }
                    116: 
                    117:        if (!is_null($tmp = @mysqli_set_local_infile_handler()))
                    118:                printf("[001] Expecting NULL/NULL got %s/%s\n", $tmp, gettype($tmp));
                    119: 
                    120:        $handle = null;
                    121:        if (!is_null($tmp = @mysqli_set_local_infile_handler($handle)))
                    122:                printf("[002] Expecting NULL/NULL got %s/%s\n", $tmp, gettype($tmp));
                    123: 
                    124:        $handle = @new mysqli();
                    125:        if (!is_null($tmp = @mysqli_set_local_infile_handler($handle, 'callback_simple')))
                    126:                printf("[003] Expecting NULL/NULL got %s/%s\n", $tmp, gettype($tmp));
                    127: 
                    128:        if (false !== ($tmp = @mysqli_set_local_infile_handler($link, 'unknown')))
                    129:                printf("[004] Expecting false/boolean got %s/%s\n", $tmp, gettype($tmp));
                    130: 
                    131:        $file = create_standard_csv(5);
                    132: 
                    133:        $expected = array(
                    134:                array('id' => 98,   'label' => 'x'),
                    135:                array('id' => 99,   'label' => 'y'),
                    136:                array('id' => 100,  'label' => 'z'),
                    137:        );
                    138:        try_handler(10, $link, $file, 'callback_simple', $expected);
                    139: 
                    140:        $expected = array();
                    141:        try_handler(20, $link, $file, 'callback_fclose', $expected);
                    142: 
                    143:        // FIXME - TODO - KLUDGE -
                    144:   // IMHO this is wrong. ext/mysqli should bail as the function signature
                    145:   // is not complete. That's a BC break, OK, but it makes perfectly sense.
                    146:        $expected = array();
                    147:        try_handler(30, $link, $file, 'callback_invalid_args', $expected);
                    148: 
                    149:        $expected = array();
                    150:        try_handler(40, $link, $file, 'callback_error', $expected);
                    151: 
                    152: 
                    153:        mysqli_close($link);
                    154: 
                    155:        if (!is_null($tmp = @mysqli_set_local_infile_handler($link, 'callback_simple')))
                    156:                printf("[300] Expecting NULL/NULL got %s/%s\n", $tmp, gettype($tmp));
                    157: 
                    158:        print "done!";
                    159: ?>
                    160: --CLEAN--
                    161: <?php
                    162:        require_once("clean_table.inc");
                    163: ?>
                    164: --EXPECTF--
                    165: Callback set to 'callback_simple'
                    166: Callback: 0
                    167: Callback: 1
                    168: Callback set to 'callback_fclose'
                    169: Callback: 0
                    170: [022] LOAD DATA failed, [2000] File handle close%s
                    171: Callback set to 'callback_invalid_args'
                    172: Callback: 0
                    173: Callback: 1
                    174: [037] More results than expected!
                    175: array(2) {
                    176:   [%u|b%"id"]=>
                    177:   %unicode|string%(2) "97"
                    178:   [%u|b%"label"]=>
                    179:   %unicode|string%(1) "x"
                    180: }
                    181: array(2) {
                    182:   [%u|b%"id"]=>
                    183:   %unicode|string%(2) "98"
                    184:   [%u|b%"label"]=>
                    185:   %unicode|string%(1) "y"
                    186: }
                    187: array(2) {
                    188:   [%u|b%"id"]=>
                    189:   %unicode|string%(2) "99"
                    190:   [%u|b%"label"]=>
                    191:   %unicode|string%(1) "z"
                    192: }
                    193: Callback set to 'callback_error'
                    194: Callback: 0
                    195: [042] LOAD DATA failed, [2000] How to access this error?
                    196: done!

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>