From d8de4eb685e35646c7d541e9a75bdc296127b7e2 Mon Sep 17 00:00:00 2001 From: "Justin M. Keyes" Date: Fri, 17 Sep 2021 09:16:40 -0700 Subject: test: reorg #15698 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 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//` 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 --- test/functional/eval/printf_spec.lua | 92 ------------------------------------ 1 file changed, 92 deletions(-) delete mode 100644 test/functional/eval/printf_spec.lua (limited to 'test/functional/eval/printf_spec.lua') 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) -- cgit