summaryrefslogtreecommitdiff
path: root/ThirdParty/tolua_runtime/luajit-2.1/src/x64/test/test_str_comp.lua
blob: 3a5c3e6766f3d808e85b5f4b8bc389f325a5297a (plain)
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
--[[
 Given two content-idental string s1, s2, test if they end up to be the
 same string object. The purpose of this test is to make sure hash function
 do not accidently include extraneous bytes before and after the string in
 question.
]]

local ffi = require("ffi")
local C = ffi.C

ffi.cdef[[
    void free(void*);
    char* malloc(size_t);
    void *memset(void*, int, size_t);
    void *memcpy(void*, void*, size_t);
    long time(void*);
    void srandom(unsigned);
    long random(void);
]]


local function test_equal(len_min, len_max)
    -- source string is wrapped by 16-byte-junk both before and after the
    -- string
    local x = C.random()
    local l = len_min + x % (len_max - len_min);
    local buf_len = tonumber(l + 16 * 2)

    local src_buf = C.malloc(buf_len)
    for i = 0, buf_len - 1 do
        src_buf[i] = C.random() % 255
    end

    -- dest string is the clone of the source string, but it is sandwiched
    -- by different junk bytes
    local dest_buf = C.malloc(buf_len)
    C.memset(dest_buf, 0x5a, buf_len)

    local ofst = 8 + (C.random() % 8)
    C.memcpy(dest_buf + ofst, src_buf + 16, l);

    local str1 = ffi.string(src_buf + 16, l)
    local str2 = ffi.string(dest_buf + ofst, l)

    C.free(src_buf)
    C.free(dest_buf)

    if str1 ~= str2 then
        -- Oops, look like hash function mistakenly include extraneous bytes
        -- close to the string
        return 1 -- wtf
    end
end

--local lens = {1, 4, 16, 128, 1024}
local lens = {128, 1024}
local iter = 1000

for i = 1, #lens - 1 do
    for j = 1, iter do
        if test_equal(lens[i], lens[i+1]) ~= nil then
            os.exit(1)
        end
    end
end

os.exit(0)