mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 09:44:31 +00:00 
			
		
		
		
	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)
 |