diff options
Diffstat (limited to 'test/functional/eval/writefile_spec.lua')
-rw-r--r-- | test/functional/eval/writefile_spec.lua | 156 |
1 files changed, 0 insertions, 156 deletions
diff --git a/test/functional/eval/writefile_spec.lua b/test/functional/eval/writefile_spec.lua deleted file mode 100644 index 14be8c377c..0000000000 --- a/test/functional/eval/writefile_spec.lua +++ /dev/null @@ -1,156 +0,0 @@ -local helpers = require('test.functional.helpers')(after_each) -local lfs = require('lfs') - -local clear = helpers.clear -local eq = helpers.eq -local funcs = helpers.funcs -local meths = helpers.meths -local exc_exec = helpers.exc_exec -local read_file = helpers.read_file -local write_file = helpers.write_file -local redir_exec = helpers.redir_exec - -local fname = 'Xtest-functional-eval-writefile' -local dname = fname .. '.d' -local dfname_tail = '1' -local dfname = dname .. '/' .. dfname_tail -local ddname_tail = '2' -local ddname = dname .. '/' .. ddname_tail - -before_each(function() - lfs.mkdir(dname) - lfs.mkdir(ddname) - clear() -end) - -after_each(function() - os.remove(fname) - os.remove(dfname) - lfs.rmdir(ddname) - lfs.rmdir(dname) -end) - -describe('writefile()', function() - it('writes empty list to a file', function() - eq(nil, read_file(fname)) - eq(0, funcs.writefile({}, fname)) - eq('', read_file(fname)) - os.remove(fname) - eq(nil, read_file(fname)) - eq(0, funcs.writefile({}, fname, 'b')) - eq('', read_file(fname)) - os.remove(fname) - eq(nil, read_file(fname)) - eq(0, funcs.writefile({}, fname, 'ab')) - eq('', read_file(fname)) - os.remove(fname) - eq(nil, read_file(fname)) - eq(0, funcs.writefile({}, fname, 'a')) - eq('', read_file(fname)) - end) - - it('writes list with an empty string to a file', function() - eq(0, exc_exec( - ('call writefile([$XXX_NONEXISTENT_VAR_XXX], "%s", "b")'):format( - fname))) - eq('', read_file(fname)) - eq(0, exc_exec(('call writefile([$XXX_NONEXISTENT_VAR_XXX], "%s")'):format( - fname))) - eq('\n', read_file(fname)) - end) - - it('writes list with a null string to a file', function() - eq(0, exc_exec( - ('call writefile([v:_null_string], "%s", "b")'):format( - fname))) - eq('', read_file(fname)) - eq(0, exc_exec(('call writefile([v:_null_string], "%s")'):format( - fname))) - eq('\n', read_file(fname)) - end) - - it('appends to a file', function() - eq(nil, read_file(fname)) - eq(0, funcs.writefile({'abc', 'def', 'ghi'}, fname)) - eq('abc\ndef\nghi\n', read_file(fname)) - eq(0, funcs.writefile({'jkl'}, fname, 'a')) - eq('abc\ndef\nghi\njkl\n', read_file(fname)) - os.remove(fname) - eq(nil, read_file(fname)) - eq(0, funcs.writefile({'abc', 'def', 'ghi'}, fname, 'b')) - eq('abc\ndef\nghi', read_file(fname)) - eq(0, funcs.writefile({'jkl'}, fname, 'ab')) - eq('abc\ndef\nghijkl', read_file(fname)) - end) - - it('correctly treats NLs', function() - eq(0, funcs.writefile({'\na\nb\n'}, fname, 'b')) - eq('\0a\0b\0', read_file(fname)) - eq(0, funcs.writefile({'a\n\n\nb'}, fname, 'b')) - eq('a\0\0\0b', read_file(fname)) - end) - - it('writes with s and S', function() - eq(0, funcs.writefile({'\na\nb\n'}, fname, 'bs')) - eq('\0a\0b\0', read_file(fname)) - eq(0, funcs.writefile({'a\n\n\nb'}, fname, 'bS')) - eq('a\0\0\0b', read_file(fname)) - end) - - it('correctly overwrites file', function() - eq(0, funcs.writefile({'\na\nb\n'}, fname, 'b')) - eq('\0a\0b\0', read_file(fname)) - eq(0, funcs.writefile({'a\n'}, fname, 'b')) - eq('a\0', read_file(fname)) - end) - - it('shows correct file name when supplied numbers', function() - meths.set_current_dir(dname) - eq('\nE482: Can\'t open file 2 for writing: illegal operation on a directory', - redir_exec(('call writefile([42], %s)'):format(ddname_tail))) - end) - - it('errors out with invalid arguments', function() - write_file(fname, 'TEST') - eq('\nE119: Not enough arguments for function: writefile', - redir_exec('call writefile()')) - eq('\nE119: Not enough arguments for function: writefile', - redir_exec('call writefile([])')) - eq('\nE118: Too many arguments for function: writefile', - redir_exec(('call writefile([], "%s", "b", 1)'):format(fname))) - for _, arg in ipairs({'0', '0.0', 'function("tr")', '{}', '"test"'}) do - eq('\nE475: Invalid argument: writefile() first argument must be a List or a Blob', - redir_exec(('call writefile(%s, "%s", "b")'):format(arg, fname))) - end - for _, args in ipairs({'[], %s, "b"', '[], "' .. fname .. '", %s'}) do - eq('\nE806: using Float as a String', - redir_exec(('call writefile(%s)'):format(args:format('0.0')))) - eq('\nE730: using List as a String', - redir_exec(('call writefile(%s)'):format(args:format('[]')))) - eq('\nE731: using Dictionary as a String', - redir_exec(('call writefile(%s)'):format(args:format('{}')))) - eq('\nE729: using Funcref as a String', - redir_exec(('call writefile(%s)'):format(args:format('function("tr")')))) - end - eq('\nE5060: Unknown flag: «»', - redir_exec(('call writefile([], "%s", "bs«»")'):format(fname))) - eq('TEST', read_file(fname)) - end) - - it('does not write to file if error in list', function() - local args = '["tset"] + repeat([%s], 3), "' .. fname .. '"' - eq('\nE805: Expected a Number or a String, Float found', - redir_exec(('call writefile(%s)'):format(args:format('0.0')))) - eq(nil, read_file(fname)) - write_file(fname, 'TEST') - eq('\nE745: Expected a Number or a String, List found', - redir_exec(('call writefile(%s)'):format(args:format('[]')))) - eq('TEST', read_file(fname)) - eq('\nE728: Expected a Number or a String, Dictionary found', - redir_exec(('call writefile(%s)'):format(args:format('{}')))) - eq('TEST', read_file(fname)) - eq('\nE703: Expected a Number or a String, Funcref found', - redir_exec(('call writefile(%s)'):format(args:format('function("tr")')))) - eq('TEST', read_file(fname)) - end) -end) |