aboutsummaryrefslogtreecommitdiff
path: root/test/functional/eval/uniq_spec.lua
diff options
context:
space:
mode:
authorZyX <kp-pav@yandex.ru>2018-04-15 18:45:12 +0300
committerZyX <kp-pav@yandex.ru>2018-04-15 18:45:12 +0300
commitf8d574225b61fc4bc0fd52990deda4825f62dc8f (patch)
treebceb3f4a230d020da93fe609b233c2e2aa7b0eba /test/functional/eval/uniq_spec.lua
parent6f19b9f4e19d12aea23ac61c889aa122bc2576eb (diff)
downloadrneovim-f8d574225b61fc4bc0fd52990deda4825f62dc8f.tar.gz
rneovim-f8d574225b61fc4bc0fd52990deda4825f62dc8f.tar.bz2
rneovim-f8d574225b61fc4bc0fd52990deda4825f62dc8f.zip
eval: Silence PVS/V547: E882 may be triggered
I failed to deduce why analyzer thinks E882 may not be triggered, though conditions for triggering it are strange: it would trigger E882 only in the single case “function returned non-number”. Cases “function thrown exception”, or “built-in sorter encountered error” will neither yield E882 nor stop sort()/uniq(). Note though that searching test code revealed that neither E702 nor E882 are not tested anywhere.
Diffstat (limited to 'test/functional/eval/uniq_spec.lua')
-rw-r--r--test/functional/eval/uniq_spec.lua34
1 files changed, 34 insertions, 0 deletions
diff --git a/test/functional/eval/uniq_spec.lua b/test/functional/eval/uniq_spec.lua
new file mode 100644
index 0000000000..5217034d81
--- /dev/null
+++ b/test/functional/eval/uniq_spec.lua
@@ -0,0 +1,34 @@
+local helpers = require('test.functional.helpers')(after_each)
+
+local eq = helpers.eq
+local NIL = helpers.NIL
+local eval = helpers.eval
+local clear = helpers.clear
+local meths = helpers.meths
+local funcs = helpers.funcs
+local command = helpers.command
+local exc_exec = helpers.exc_exec
+local redir_exec = helpers.redir_exec
+
+before_each(clear)
+
+describe('uniq()', function()
+ it('errors out when processing special values', function()
+ eq('Vim(call):E907: Using a special value as a Float',
+ exc_exec('call uniq([v:true, v:false], "f")'))
+ end)
+
+ it('can yield E882 and stop filtering after that', function()
+ command([[
+ function Cmp(a, b)
+ if type(a:a) == type([]) || type(a:b) == type([])
+ return []
+ endif
+ return (a:a > a:b) - (a:a < a:b)
+ endfunction
+ ]])
+ eq('\nE745: Using a List as a Number\nE882: Uniq compare function failed',
+ redir_exec('let fl = uniq([0, 0, [], 1, 1], "Cmp")'))
+ eq({0, {}, 1, 1}, meths.get_var('fl'))
+ end)
+end)