diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-11-16 13:56:06 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-11-16 13:56:06 +0000 |
commit | 3390bdc6e0cbbfac91f91f2d6f707453a1435bd7 (patch) | |
tree | 52119304dea9ef45c2bd35a19c39d82ab0ecafe7 /test/lua | |
parent | 454f4676389738808d2231d6813e5eb70167efbe (diff) | |
download | rspamd-3390bdc6e0cbbfac91f91f2d6f707453a1435bd7.tar.gz rspamd-3390bdc6e0cbbfac91f91f2d6f707453a1435bd7.zip |
Fix parsing of fragment in urls
Diffstat (limited to 'test/lua')
-rw-r--r-- | test/lua/unit/url.lua | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/test/lua/unit/url.lua b/test/lua/unit/url.lua index 9836ed127..e6b112870 100644 --- a/test/lua/unit/url.lua +++ b/test/lua/unit/url.lua @@ -9,7 +9,7 @@ context("URL check functions", function() void rspamd_url_init (const char *tld_file); unsigned ottery_rand_range(unsigned top); ]] - + local test_dir = string.gsub(debug.getinfo(1).source, "^@(.+/)[^/]+$", "%1") ffi.C.rspamd_url_init(string.format('%s/%s', test_dir, "test_tld.dat")) @@ -33,21 +33,21 @@ context("URL check functions", function() for _,c in ipairs(cases) do local res = url.create(pool, c[1]) - + assert_not_nil(res, "cannot parse " .. c[1]) local t = res:to_table() --local s = logger.slog("%1 -> %2", c[1], t) --print(s) assert_not_nil(t, "cannot convert to table " .. c[1]) assert_equal(c[2][1], t['host']) - + if c[2][2] then assert_equal(c[2][2], t['user']) end end pool:destroy() end) - + -- Some cases from https://code.google.com/p/google-url/source/browse/trunk/src/url_canon_unittest.cc test("Parse urls", function() local pool = mpool.create() @@ -81,16 +81,19 @@ context("URL check functions", function() {"http://[::eeee:192.168.0.1]", true, { host = '::eeee:c0a8:1' }}, + {"http://twitter.com#test", true, { + host = 'twitter.com', fragment = 'test' + }}, } - + for _,c in ipairs(cases) do local res = url.create(pool, c[1]) - + if c[2] then assert_not_nil(res, "cannot parse " .. c[1]) - + local uf = res:to_table() - + for k,v in pairs(c[3]) do assert_not_nil(uf[k], k .. ' is missing in url, must be ' .. v) assert_equal(uf[k], v, 'expected ' .. v .. ' for ' .. k .. ' but got ' .. uf[k] .. ' in url ' .. c[1]) @@ -106,4 +109,4 @@ context("URL check functions", function() end end ) -end)
\ No newline at end of file +end) |