mirror of
https://github.com/neovim/neovim.git
synced 2024-12-27 14:21:31 -07:00
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)
|