File: gh-3332-tuple-format-leak.test.lua

package info (click to toggle)
tarantool 2.6.0-1.4
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 85,412 kB
  • sloc: ansic: 513,775; cpp: 69,493; sh: 25,650; python: 19,190; perl: 14,973; makefile: 4,178; yacc: 1,329; sql: 1,074; pascal: 620; ruby: 190; awk: 18; lisp: 7
file content (31 lines) | stat: -rwxr-xr-x 872 bytes parent folder | download | duplicates (3)
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
#!/usr/bin/env tarantool
test = require("sqltester")
test:plan(2)

test:do_test(
    "format-leak-prep",
    function()
        box.execute("CREATE TABLE t1(id INTEGER PRIMARY KEY,\
                         max_players INTEGER, n_players INTEGER, flags INTEGER);");
        box.execute("CREATE INDEX IDX_MAX_PLAYERS ON t1(max_players);");
        box.execute("CREATE INDEX IDX_N_PLAYERS ON t1(n_players);");
        box.execute("CREATE INDEX IDX_FLAGS ON t1(flags);");
        for i = 1, 10 do
            box.execute(string.format("INSERT INTO t1 VALUES (%s, %s, %s, %s);",
                                          i, 15, 6, 3));
        end
    end, {

    })

test:do_test(
    "format-leak",
    function()
        for i = 1, 100000 do
            box.execute("SELECT id FROM t1 WHERE flags=3 ORDER BY id LIMIT 2");
        end
    end, {

    })

test:finish_test()