summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-04-30 13:21:08 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-04-30 13:21:08 +0100
commit1616d15b5565b7cc61bb541823684f93fe2a19c5 (patch)
treee934eefb86a1a8398ce11569b73315142c5f8f65
parent9ce6af13789d36a43b4f3170969902d7f2c4f2cc (diff)
downloadrspamd-1616d15b5565b7cc61bb541823684f93fe2a19c5.tar.gz
rspamd-1616d15b5565b7cc61bb541823684f93fe2a19c5.zip
[Minor] More fixes to digests selectors + added tests
-rw-r--r--lualib/lua_selectors/extractors.lua4
-rw-r--r--test/lua/unit/selectors.lua41
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",