mirror of
https://github.com/neovim/neovim.git
synced 2024-12-29 14:41:06 -07:00
9ce81f7b2b
In Windows Lua's os.tmpname() returns relative paths starting with \s, prepend them with $TEMP to generate a valid path. In OS X os.tmpname() returns paths in '/tmp' but they should be in '/private/tmp'. We cannot use os_name() for platform detection because some tests use tempname() before nvim is spawned, instead use one of the following: 1. Set SYSTEM_NAME environment variable before calling the tests, it is set from CMAKE_SYSTEM_NAME(i.e. uname -s or 'Windows') 2. Call uname -s 3. Assume windows
43 lines
1.1 KiB
Lua
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)
|