aboutsummaryrefslogtreecommitdiff
path: root/test/functional/eval/printf_spec.lua
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2021-09-17 09:16:40 -0700
committerGitHub <noreply@github.com>2021-09-17 09:16:40 -0700
commitd8de4eb685e35646c7d541e9a75bdc296127b7e2 (patch)
tree4bb05ec713856715ac9ba57e5d116eed344511b9 /test/functional/eval/printf_spec.lua
parentd56002f7b722facd97b0958e141c8ed2d01495f7 (diff)
downloadrneovim-d8de4eb685e35646c7d541e9a75bdc296127b7e2.tar.gz
rneovim-d8de4eb685e35646c7d541e9a75bdc296127b7e2.tar.bz2
rneovim-d8de4eb685e35646c7d541e9a75bdc296127b7e2.zip
test: reorg #15698
Problem: Subdirectories like "visual", "insert", "normal" encourage people to separate *related* tests for no good reason. Typically the _mode_ is not the relevant topic of a test (and when it is, _then_ create an appropriate describe() or it()). Solution: - Delete the various `test/functional/<mode>/` subdirectories, move their tests to more meaningful topics. - Rename `…/normal/` to `…/editor/`. - Move or merge `…/visual/*` and `…/insert/*` tests into here where appropriate. - Rename `…/eval/` to `…/vimscript/`. - Move `…/viml/*` into here also. * test(reorg): insert/* => editor/mode_insert_spec.lua * test(reorg): cmdline/* => editor/mode_cmdline_spec.lua * test(reorg): eval core tests => eval_spec.lua
Diffstat (limited to 'test/functional/eval/printf_spec.lua')
-rw-r--r--test/functional/eval/printf_spec.lua92
1 files changed, 0 insertions, 92 deletions
diff --git a/test/functional/eval/printf_spec.lua b/test/functional/eval/printf_spec.lua
deleted file mode 100644
index 27e24c4118..0000000000
--- a/test/functional/eval/printf_spec.lua
+++ /dev/null
@@ -1,92 +0,0 @@
-local helpers = require('test.functional.helpers')(after_each)
-
-local clear = helpers.clear
-local eq = helpers.eq
-local eval = helpers.eval
-local funcs = helpers.funcs
-local meths = helpers.meths
-local exc_exec = helpers.exc_exec
-
-describe('printf()', function()
- before_each(clear)
-
- it('works with zero and %b', function()
- eq('0', funcs.printf('%lb', 0))
- eq('0', funcs.printf('%llb', 0))
- eq('0', funcs.printf('%zb', 0))
- end)
- it('works with one and %b', function()
- eq('1', funcs.printf('%b', 1))
- eq('1', funcs.printf('%lb', 1))
- eq('1', funcs.printf('%llb', 1))
- eq('1', funcs.printf('%zb', 1))
- end)
- it('works with 0xff and %b', function()
- eq('11111111', funcs.printf('%b', 0xff))
- eq('11111111', funcs.printf('%lb', 0xff))
- eq('11111111', funcs.printf('%llb', 0xff))
- eq('11111111', funcs.printf('%zb', 0xff))
- end)
- it('accepts width modifier with %b', function()
- eq(' 1', funcs.printf('%3b', 1))
- end)
- it('accepts prefix modifier with %b', function()
- eq('0b1', funcs.printf('%#b', 1))
- end)
- it('writes capital B with %B', function()
- eq('0B1', funcs.printf('%#B', 1))
- end)
- it('accepts prefix, zero-fill and width modifiers with %b', function()
- eq('0b001', funcs.printf('%#05b', 1))
- end)
- it('accepts prefix and width modifiers with %b', function()
- eq(' 0b1', funcs.printf('%#5b', 1))
- end)
- it('does not write prefix for zero with prefix and width modifier used with %b', function()
- eq(' 0', funcs.printf('%#5b', 0))
- end)
- it('accepts precision modifier with %b', function()
- eq('00000', funcs.printf('%.5b', 0))
- end)
- it('accepts all modifiers with %b at once', function()
- -- zero-fill modifier is ignored when used with left-align
- -- force-sign and add-blank are ignored
- -- use-grouping-characters modifier is ignored always
- eq('0b00011 ', funcs.printf('% \'+#0-10.5b', 3))
- end)
- it('errors out when %b modifier is used for a list', function()
- eq('Vim(call):E745: Using a List as a Number', exc_exec('call printf("%b", [])'))
- end)
- it('errors out when %b modifier is used for a float', function()
- eq('Vim(call):E805: Using a Float as a Number', exc_exec('call printf("%b", 3.1415926535)'))
- end)
- it('works with %p correctly', function()
- local null_ret = nil
- local seen_rets = {}
- -- Collect all args in an array to avoid possible allocation of the same
- -- address after freeing unreferenced values.
- meths.set_var('__args', {})
- local function check_printf(expr, is_null)
- eq(0, exc_exec('call add(__args, ' .. expr .. ')'))
- eq(0, exc_exec('let __result = printf("%p", __args[-1])'))
- local id_ret = eval('id(__args[-1])')
- eq(id_ret, meths.get_var('__result'))
- if is_null then
- if null_ret then
- eq(null_ret, id_ret)
- else
- null_ret = id_ret
- end
- else
- eq(nil, seen_rets[id_ret])
- seen_rets[id_ret] = expr
- end
- meths.del_var('__result')
- end
- check_printf('v:_null_list', true)
- check_printf('v:_null_dict', true)
- check_printf('[]')
- check_printf('{}')
- check_printf('function("tr", ["a"])')
- end)
-end)