Annotation of embedaddon/php/ext/mysqli/tests/mysqli_set_local_infile_handler.phpt, revision 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>