Files
neovim/test/functional/ex_cmds/profile_spec.lua
dundargoc 052498ed42 test: improve test conventions
Specifically, functions that are run in the context of the test runner
are put in module `test/testutil.lua` while the functions that are run
in the context of the test session are put in
`test/functional/testnvim.lua`.

Closes https://github.com/neovim/neovim/issues/27004.
2024-04-23 18:17:04 +02:00

102 lines
2.6 KiB
Lua

local t = require('test.testutil')
local n = require('test.functional.testnvim')()
local uv = vim.uv
require('os')
local eval = n.eval
local command = n.command
local eq, neq = t.eq, t.neq
local tempfile = t.tmpname()
local source = n.source
local matches = t.matches
local read_file = t.read_file
-- tmpname() also creates the file on POSIX systems. Remove it again.
-- We just need the name, ignoring any race conditions.
if uv.fs_stat(tempfile).uid then
os.remove(tempfile)
end
local function assert_file_exists(filepath)
neq(nil, uv.fs_stat(filepath).uid)
end
local function assert_file_exists_not(filepath)
eq(nil, uv.fs_stat(filepath))
end
describe(':profile', function()
before_each(n.clear)
after_each(function()
n.expect_exit(command, 'qall!')
if uv.fs_stat(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)