mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 01:34:25 +00:00 
			
		
		
		
	- Add a test to make sure that 'profile dump' does not reset the profile. - Add a test to make sure that 'profile stop' does reset the profile.
		
			
				
	
	
		
			102 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
require('os')
 | 
						|
local lfs = require('lfs')
 | 
						|
 | 
						|
local helpers  = require('test.functional.helpers')(after_each)
 | 
						|
local eval     = helpers.eval
 | 
						|
local command  = helpers.command
 | 
						|
local eq, neq  = helpers.eq, helpers.neq
 | 
						|
local tempfile = helpers.tmpname()
 | 
						|
local source   = helpers.source
 | 
						|
local matches  = helpers.matches
 | 
						|
local read_file = helpers.read_file
 | 
						|
 | 
						|
-- tmpname() also creates the file on POSIX systems. Remove it again.
 | 
						|
-- We just need the name, ignoring any race conditions.
 | 
						|
if lfs.attributes(tempfile, 'uid') then
 | 
						|
  os.remove(tempfile)
 | 
						|
end
 | 
						|
 | 
						|
local function assert_file_exists(filepath)
 | 
						|
  -- Use 2-argument lfs.attributes() so no extra table gets created.
 | 
						|
  -- We don't really care for the uid.
 | 
						|
  neq(nil, lfs.attributes(filepath, 'uid'))
 | 
						|
end
 | 
						|
 | 
						|
local function assert_file_exists_not(filepath)
 | 
						|
  eq(nil, lfs.attributes(filepath, 'uid'))
 | 
						|
end
 | 
						|
 | 
						|
describe(':profile', function()
 | 
						|
  before_each(helpers.clear)
 | 
						|
 | 
						|
  after_each(function()
 | 
						|
    if lfs.attributes(tempfile, 'uid') ~= nil then
 | 
						|
      os.remove(tempfile)
 | 
						|
    end
 | 
						|
  end)
 | 
						|
 | 
						|
  describe('dump', function()
 | 
						|
    it('works', function()
 | 
						|
      eq(0, eval('v:profiling'))
 | 
						|
      command('profile start ' .. tempfile)
 | 
						|
      eq(1, eval('v:profiling'))
 | 
						|
      assert_file_exists_not(tempfile)
 | 
						|
      command('profile dump')
 | 
						|
      assert_file_exists(tempfile)
 | 
						|
    end)
 | 
						|
 | 
						|
    it('not resetting the profile', function()
 | 
						|
      source([[
 | 
						|
        function! Test()
 | 
						|
        endfunction
 | 
						|
      ]])
 | 
						|
      command('profile start ' .. tempfile)
 | 
						|
      assert_file_exists_not(tempfile)
 | 
						|
      command('profile func Test')
 | 
						|
      command('call Test()')
 | 
						|
      command('profile dump')
 | 
						|
      assert_file_exists(tempfile)
 | 
						|
      local profile = read_file(tempfile)
 | 
						|
      matches('Called 1 time', profile)
 | 
						|
      command('call Test()')
 | 
						|
      command('profile dump')
 | 
						|
      assert_file_exists(tempfile)
 | 
						|
      profile = read_file(tempfile)
 | 
						|
      matches('Called 2 time', profile)
 | 
						|
      command('profile stop')
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
 | 
						|
  describe('stop', function()
 | 
						|
    it('works', function()
 | 
						|
      command('profile start ' .. tempfile)
 | 
						|
      assert_file_exists_not(tempfile)
 | 
						|
      command('profile stop')
 | 
						|
      assert_file_exists(tempfile)
 | 
						|
      eq(0, eval('v:profiling'))
 | 
						|
    end)
 | 
						|
 | 
						|
    it('resetting the profile', function()
 | 
						|
      source([[
 | 
						|
        function! Test()
 | 
						|
        endfunction
 | 
						|
      ]])
 | 
						|
      command('profile start ' .. tempfile)
 | 
						|
      assert_file_exists_not(tempfile)
 | 
						|
      command('profile func Test')
 | 
						|
      command('call Test()')
 | 
						|
      command('profile stop')
 | 
						|
      assert_file_exists(tempfile)
 | 
						|
      local profile = read_file(tempfile)
 | 
						|
      matches('Called 1 time', profile)
 | 
						|
      command('profile start ' .. tempfile)
 | 
						|
      command('profile func Test')
 | 
						|
      command('call Test()')
 | 
						|
      command('profile stop')
 | 
						|
      assert_file_exists(tempfile)
 | 
						|
      profile = read_file(tempfile)
 | 
						|
      matches('Called 1 time', profile)
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
end)
 |