neovim/test/functional/legacy/file_perm_spec.lua
Justin M. Keyes c9f3174075 API: return non-generic VimL errors
- Return VimL errors instead of generic errors for:
  - nvim_call_function
  - nvim_call_dict_function
- Fix tests which were silently broken before this change.

This violates #6150 where we agreed not to translate API errors.  But
that can be fixed later.
2018-05-09 23:18:38 +02:00

43 lines
1.1 KiB
Lua

-- Test getting and setting file permissions.
require('os')
local helpers = require('test.functional.helpers')(after_each)
local clear, call, eq = helpers.clear, helpers.call, helpers.eq
local neq, exc_exec = helpers.neq, helpers.exc_exec
describe('Test getting and setting file permissions', function()
local tempfile = helpers.tmpname()
before_each(function()
os.remove(tempfile)
clear()
end)
it('file permissions', function()
eq('', call('getfperm', tempfile))
eq(0, call('setfperm', tempfile, 'r--------'))
call('writefile', {'one'}, tempfile)
eq(9, call('len', call('getfperm', tempfile)))
eq(1, call('setfperm', tempfile, 'rwx------'))
if helpers.os_name() == 'windows' then
eq('rw-rw-rw-', call('getfperm', tempfile))
else
eq('rwx------', call('getfperm', tempfile))
end
eq(1, call('setfperm', tempfile, 'r--r--r--'))
eq('r--r--r--', call('getfperm', tempfile))
local err = exc_exec(('call setfperm("%s", "---")'):format(tempfile))
neq(err:find('E475:'), nil)
eq(1, call('setfperm', tempfile, 'rwx------'))
end)
after_each(function()
os.remove(tempfile)
end)
end)