mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 12:27:24 +00:00 
			
		
		
		
	 7872877ce5
			
		
	
	7872877ce5
	
	
	
		
			
			- 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)
 |