diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-04-30 13:21:08 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-04-30 13:21:08 +0100 |
commit | 1616d15b5565b7cc61bb541823684f93fe2a19c5 (patch) | |
tree | e934eefb86a1a8398ce11569b73315142c5f8f65 | |
parent | 9ce6af13789d36a43b4f3170969902d7f2c4f2cc (diff) | |
download | rspamd-1616d15b5565b7cc61bb541823684f93fe2a19c5.tar.gz rspamd-1616d15b5565b7cc61bb541823684f93fe2a19c5.zip |
[Minor] More fixes to digests selectors + added tests
-rw-r--r-- | lualib/lua_selectors/extractors.lua | 4 | ||||
-rw-r--r-- | test/lua/unit/selectors.lua | 41 |
2 files changed, 37 insertions, 8 deletions
diff --git a/lualib/lua_selectors/extractors.lua b/lualib/lua_selectors/extractors.lua index e800e98e9..532c56592 100644 --- a/lualib/lua_selectors/extractors.lua +++ b/lualib/lua_selectors/extractors.lua @@ -136,8 +136,8 @@ uses any type by default)]], local digests = {} for _,p in ipairs(parts) do if p:get_filename() then - if not args[2] or args[2] == 'blake2' then - -- Optimise as we already have this hash + if #args == 0 then + -- Optimise as we already have this hash in the API table.insert(digests, p:get_digest()) else table.insert(digests, common.create_digest(p:get_content('raw_parsed'), args)) diff --git a/test/lua/unit/selectors.lua b/test/lua/unit/selectors.lua index ec71927e0..294e98b62 100644 --- a/test/lua/unit/selectors.lua +++ b/test/lua/unit/selectors.lua @@ -118,14 +118,43 @@ context("Selectors test", function() }, ["to"] = { - selector = "to", - expect = {"nobody@example.com"}}, + selector = "to", + expect = {"nobody@example.com"}}, ["attachments"] = { - selector = "attachments", - expect = {{"ce112d07c52ae649f9646f3d0b5aaab5d4834836d771c032d1a75059d31fed84f38e00c0b205918f6d354934c2055d33d19d045f783a62561f467728ebcf0160", - "ce112d07c52ae649f9646f3d0b5aaab5d4834836d771c032d1a75059d31fed84f38e00c0b205918f6d354934c2055d33d19d045f783a62561f467728ebcf0160" - }}}, + selector = "attachments", + expect = {{"ce112d07c52ae649f9646f3d0b5aaab5d4834836d771c032d1a75059d31fed84f38e00c0b205918f6d354934c2055d33d19d045f783a62561f467728ebcf0160", + "ce112d07c52ae649f9646f3d0b5aaab5d4834836d771c032d1a75059d31fed84f38e00c0b205918f6d354934c2055d33d19d045f783a62561f467728ebcf0160" + }} + }, + + ["attachments blake2 base32"] = { + selector = "attachments('base32', 'blake2')", + expect = {{"qqr41dwakt3uwhucxmxsypjiifi8er3gzqhyc3r48fw1ij9dp8b8x8nyyscmoe6tpmp1r4eafezguezurazo87ecs48cw5bfm9udyob", + "qqr41dwakt3uwhucxmxsypjiifi8er3gzqhyc3r48fw1ij9dp8b8x8nyyscmoe6tpmp1r4eafezguezurazo87ecs48cw5bfm9udyob" + }} + }, + + ["attachments blake2 base64"] = { + selector = "attachments('base64', 'blake2')", + expect = {{"zhEtB8Uq5kn5ZG89C1qqtdSDSDbXccAy0adQWdMf7YTzjgDAsgWRj201STTCBV0z0Z0EX3g6YlYfRnco688BYA==", + "zhEtB8Uq5kn5ZG89C1qqtdSDSDbXccAy0adQWdMf7YTzjgDAsgWRj201STTCBV0z0Z0EX3g6YlYfRnco688BYA==" + }} + }, + + ["attachments blake2 rfc base32"] = { + selector = "attachments('rbase32', 'blake2')", + expect = {{"OOE2SDUYKRZTU4TMPLPWANJVVFVHIEZGXO4AMZE2HFUSVJ7DNHBHPHCAAWMLQI6RNLNSE2IYFIXGTIXTEYXQH5IMW2HMU3BFL7TDAQB", + "OOE2SDUYKRZTU4TMPLPWANJVVFVHIEZGXO4AMZE2HFUSVJ7DNHBHPHCAAWMLQI6RNLNSE2IYFIXGTIXTEYXQH5IMW2HMU3BFL7TDAQB" + }} + }, + + ["attachments md5 rfc base32"] = { + selector = "attachments('rbase32', 'md5')", + expect = {{"6SL2VQAR4SSOVYNNYUZ744JRAB", + "6SL2VQAR4SSOVYNNYUZ744JRAB" + }} + }, ["attachments id"] = { selector = "attachments.id", |