aboutsummaryrefslogtreecommitdiff
path: root/test/functional/eval/writefile_spec.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/eval/writefile_spec.lua')
-rw-r--r--test/functional/eval/writefile_spec.lua156
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)