diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-04-23 12:28:26 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-04-23 14:45:27 +0100 |
commit | 49267b5a003e9145283c043bd523a037d7b38370 (patch) | |
tree | 90bdc0866e0e96209101258c8c2fc99961633d10 | |
parent | 6d57fbfa112799366447775d5a52974e29bf887d (diff) | |
download | rspamd-49267b5a003e9145283c043bd523a037d7b38370.tar.gz rspamd-49267b5a003e9145283c043bd523a037d7b38370.zip |
[Test] Add smtp addr unit test
-rw-r--r-- | test/lua/unit/smtp_addr.lua | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/test/lua/unit/smtp_addr.lua b/test/lua/unit/smtp_addr.lua new file mode 100644 index 000000000..fab197dc9 --- /dev/null +++ b/test/lua/unit/smtp_addr.lua @@ -0,0 +1,56 @@ +-- SMTP address parser tests + +context("SMTP address check functions", function() + local logger = require("rspamd_logger") + local ffi = require("ffi") + require "fun" () + ffi.cdef[[ + struct rspamd_email_address { + const char *raw; + const char *addr; + const char *user; + const char *domain; + const char *name; + + unsigned raw_len; + unsigned addr_len; + unsigned user_len; + unsigned domain_len; + unsigned name_len; + int flags; + }; + struct rspamd_email_address * rspamd_email_address_from_smtp (const char *str, unsigned len); + void rspamd_email_address_unref (struct rspamd_email_address *addr); + ]] + + test("Parse addrs", function() + local cases_valid = { + {'<>', {addr = ''}}, + {'<a@example.com>', {user = 'a', domain = 'example.com', addr = 'a@example.com'}}, + {'a@example.com', {user = 'a', domain = 'example.com', addr = 'a@example.com'}}, + {'a+b@example.com', {user = 'a+b', domain = 'example.com', addr = 'a+b@example.com'}}, + {'"a"@example.com', {user = 'a', domain = 'example.com', addr = '"a"@example.com'}}, + } + + each(function(case) + local st = ffi.C.rspamd_email_address_from_smtp(case[1], #case[1]) + + assert_not_nil(st, "cannot parse " .. case[1]) + + each(function(k, ex) + if k == 'user' then + local str = ffi.string(st.user, st.user_len) + assert_equal(str, ex) + elseif k == 'domain' then + local str = ffi.string(st.domain, st.domain_len) + assert_equal(str, ex) + elseif k == 'addr' then + local str = ffi.string(st.addr, st.addr_len) + assert_equal(str, ex) + end + end, case[1]) + ffi.C.rspamd_email_address_unref(st) + end, cases_valid) + end) + +end) |