diff options
author | ZyX <kp-pav@yandex.ru> | 2018-04-15 18:45:12 +0300 |
---|---|---|
committer | ZyX <kp-pav@yandex.ru> | 2018-04-15 18:45:12 +0300 |
commit | f8d574225b61fc4bc0fd52990deda4825f62dc8f (patch) | |
tree | bceb3f4a230d020da93fe609b233c2e2aa7b0eba /test/functional/eval/uniq_spec.lua | |
parent | 6f19b9f4e19d12aea23ac61c889aa122bc2576eb (diff) | |
download | rneovim-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.lua | 34 |
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) |