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

1.1       misho       1: --TEST--
                      2: mysqli_real_escape_string() - SQL Mode NO_BACKSLASH_ESCAPE
                      3: --SKIPIF--
                      4: <?php
                      5: require_once('skipif.inc');
                      6: require_once('skipifemb.inc');
                      7: require_once('skipifconnectfailure.inc');
                      8: ?>
                      9: --FILE--
                     10: <?php
                     11:        require_once("connect.inc");
                     12:        require_once('table.inc');
                     13: 
                     14:        if (!mysqli_query($link, 'SET @@sql_mode="NO_BACKSLASH_ESCAPES"'))
                     15:                printf("[001] Cannot set NO_BACKSLASH_ESCAPES, [%d] %s\n", mysqli_errno($link), mysqli_error($link));
                     16: 
                     17:        if ('\\' !== ($tmp = mysqli_real_escape_string($link, '\\')))
                     18:                printf("[002] Expecting \\, got %s\n", $tmp);
                     19: 
                     20:        if ('"' !== ($tmp = mysqli_real_escape_string($link, '"')))
                     21:                printf("[003] Expecting \", got %s\n", $tmp);
                     22: 
                     23:        if ("''" !== ($tmp = mysqli_real_escape_string($link, "'")))
                     24:                printf("[004] Expecting '', got %s\n", $tmp);
                     25: 
                     26:        if ("\n" !== ($tmp = mysqli_real_escape_string($link, "\n")))
                     27:                printf("[005] Expecting \\n, got %s\n", $tmp);
                     28: 
                     29:        if ("\r" !== ($tmp = mysqli_real_escape_string($link, "\r")))
                     30:                printf("[006] Expecting \\r, got %s\n", $tmp);
                     31: 
                     32:        assert("foo" . chr(0) . "bar" === "foo" . chr(0) . "bar");
                     33:        if ("foo" . chr(0) . "bar" !== ($tmp = mysqli_real_escape_string($link, "foo" . chr(0) . "bar")))
                     34:                printf("[007] Expecting %s, got %s\n", "foo" . chr(0) . "bar", $tmp);
                     35: 
                     36:        if (!mysqli_query($link, sprintf('INSERT INTO test(id, label) VALUES (100, "%s")',
                     37:                        mysqli_real_escape_string($link, "\\"))))
                     38:                printf("[009] Cannot INSERT, [%d] %s\n", mysqli_errno($link), mysqli_error($link));
                     39: 
                     40:        if (!($res = mysqli_query($link, 'SELECT label FROM test WHERE id = 100')) ||
                     41:                        !($row = mysqli_fetch_assoc($res)))
                     42:                printf("[010] [%d] %s\n", mysqli_errno($link), mysqli_error($link));
                     43: 
                     44:        var_dump($row);
                     45:        mysqli_free_result($res);
                     46: 
                     47:        if (!mysqli_query($link, 'SET @@sql_mode=""'))
                     48:                printf("[011] Cannot disable NO_BACKSLASH_ESCAPES, [%d] %s\n", mysqli_errno($link), mysqli_error($link));
                     49: 
                     50:        if ('\\\\' !== ($tmp = mysqli_real_escape_string($link, '\\')))
                     51:                printf("[012] Expecting \\, got %s\n", $tmp);
                     52: 
                     53:        if ("foo\\0bar" !== ($tmp = mysqli_real_escape_string($link, "foo" . chr(0) . "bar")))
                     54:                printf("[013] Expecting %s, got %s\n", "foo" . chr(0) . "bar", $tmp);
                     55: 
                     56:        mysqli_close($link);
                     57: 
                     58:        print "done!";
                     59: ?>
                     60: --EXPECTF--
                     61: array(1) {
                     62:   [%u|b%"label"]=>
                     63:   %unicode|string%(1) "\"
                     64: }
                     65: done!

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