2024-04-09 04:26:16 -07:00
|
|
|
local t = require('test.functional.testutil')()
|
2017-02-20 10:58:17 -07:00
|
|
|
|
2024-04-08 02:03:20 -07:00
|
|
|
local eq = t.eq
|
|
|
|
local eval = t.eval
|
|
|
|
local feed = t.feed
|
|
|
|
local clear = t.clear
|
|
|
|
local fn = t.fn
|
|
|
|
local api = t.api
|
|
|
|
local command = t.command
|
|
|
|
local exc_exec = t.exc_exec
|
|
|
|
local pcall_err = t.pcall_err
|
|
|
|
local exec_capture = t.exec_capture
|
2017-02-20 10:58:17 -07:00
|
|
|
|
|
|
|
before_each(clear)
|
|
|
|
|
|
|
|
local function changedtick()
|
2024-01-12 10:59:57 -07:00
|
|
|
local ct = api.nvim_buf_get_changedtick(0)
|
|
|
|
eq(ct, api.nvim_buf_get_var(0, 'changedtick'))
|
|
|
|
eq(ct, api.nvim_buf_get_var(0, 'changedtick'))
|
2017-02-20 10:58:17 -07:00
|
|
|
eq(ct, eval('b:changedtick'))
|
|
|
|
eq(ct, eval('b:["changedtick"]'))
|
|
|
|
eq(ct, eval('b:.changedtick'))
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(ct, fn.getbufvar('%', 'changedtick'))
|
|
|
|
eq(ct, fn.getbufvar('%', '').changedtick)
|
2017-02-20 10:58:17 -07:00
|
|
|
eq(ct, eval('b:').changedtick)
|
|
|
|
return ct
|
|
|
|
end
|
|
|
|
|
|
|
|
describe('b:changedtick', function()
|
|
|
|
-- Ported tests from Vim-8.0.333
|
|
|
|
it('increments', function() -- Test_changedtick_increments
|
|
|
|
-- New buffer has an empty line, tick starts at 2
|
|
|
|
eq(2, changedtick())
|
2024-01-12 10:59:57 -07:00
|
|
|
fn.setline(1, 'hello')
|
2017-02-20 10:58:17 -07:00
|
|
|
eq(3, changedtick())
|
|
|
|
eq(0, exc_exec('undo'))
|
|
|
|
-- Somehow undo counts as two changes
|
|
|
|
eq(5, changedtick())
|
|
|
|
end)
|
|
|
|
it('is present in b: dictionary', function()
|
|
|
|
eq(2, changedtick())
|
|
|
|
command('let d = b:')
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(2, api.nvim_get_var('d').changedtick)
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|
|
|
|
it('increments at bdel', function()
|
|
|
|
command('new')
|
|
|
|
eq(2, changedtick())
|
2024-01-12 10:59:57 -07:00
|
|
|
local bnr = api.nvim_buf_get_number(0)
|
2017-02-20 10:58:17 -07:00
|
|
|
eq(2, bnr)
|
|
|
|
command('bdel')
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(3, fn.getbufvar(bnr, 'changedtick'))
|
|
|
|
eq(1, api.nvim_buf_get_number(0))
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|
|
|
|
it('fails to be changed by user', function()
|
|
|
|
local ct = changedtick()
|
|
|
|
local ctn = ct + 100500
|
|
|
|
eq(0, exc_exec('let d = b:'))
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "b:changedtick"',
|
|
|
|
pcall_err(command, 'let b:changedtick = ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "b:["changedtick"]"',
|
|
|
|
pcall_err(command, 'let b:["changedtick"] = ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "b:.changedtick"',
|
|
|
|
pcall_err(command, 'let b:.changedtick = ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "d.changedtick"',
|
|
|
|
pcall_err(command, 'let d.changedtick = ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-01-12 10:59:57 -07:00
|
|
|
eq('Key is read-only: changedtick', pcall_err(api.nvim_buf_set_var, 0, 'changedtick', ctn))
|
2017-02-20 10:58:17 -07:00
|
|
|
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(unlet):E795: Cannot delete variable b:changedtick',
|
|
|
|
pcall_err(command, 'unlet b:changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(unlet):E46: Cannot change read-only variable "b:.changedtick"',
|
|
|
|
pcall_err(command, 'unlet b:.changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(unlet):E46: Cannot change read-only variable "b:["changedtick"]"',
|
|
|
|
pcall_err(command, 'unlet b:["changedtick"]')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(unlet):E46: Cannot change read-only variable "d.changedtick"',
|
|
|
|
pcall_err(command, 'unlet d.changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-01-12 10:59:57 -07:00
|
|
|
eq('Key is read-only: changedtick', pcall_err(api.nvim_buf_del_var, 0, 'changedtick'))
|
2017-02-20 10:58:17 -07:00
|
|
|
eq(ct, changedtick())
|
|
|
|
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "b:["changedtick"]"',
|
|
|
|
pcall_err(command, 'let b:["changedtick"] += ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "b:["changedtick"]"',
|
|
|
|
pcall_err(command, 'let b:["changedtick"] -= ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(let):E46: Cannot change read-only variable "b:["changedtick"]"',
|
|
|
|
pcall_err(command, 'let b:["changedtick"] .= ' .. ctn)
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2017-02-20 12:45:37 -07:00
|
|
|
|
|
|
|
eq(ct, changedtick())
|
|
|
|
|
2024-01-12 10:59:57 -07:00
|
|
|
fn.setline(1, 'hello')
|
2017-02-20 12:45:37 -07:00
|
|
|
|
|
|
|
eq(ct + 1, changedtick())
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|
|
|
|
it('is listed in :let output', function()
|
2021-09-19 02:29:37 -07:00
|
|
|
eq('b:changedtick #2', exec_capture(':let b:'))
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|
|
|
|
it('fails to unlock b:changedtick', function()
|
2017-02-20 12:04:20 -07:00
|
|
|
eq(0, exc_exec('let d = b:'))
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(0, fn.islocked('b:changedtick'))
|
|
|
|
eq(0, fn.islocked('d.changedtick'))
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(unlockvar):E940: Cannot lock or unlock variable b:changedtick',
|
|
|
|
pcall_err(command, 'unlockvar b:changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(unlockvar):E46: Cannot change read-only variable "d.changedtick"',
|
|
|
|
pcall_err(command, 'unlockvar d.changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(0, fn.islocked('b:changedtick'))
|
|
|
|
eq(0, fn.islocked('d.changedtick'))
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(lockvar):E940: Cannot lock or unlock variable b:changedtick',
|
|
|
|
pcall_err(command, 'lockvar b:changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(lockvar):E46: Cannot change read-only variable "d.changedtick"',
|
|
|
|
pcall_err(command, 'lockvar d.changedtick')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(0, fn.islocked('b:changedtick'))
|
|
|
|
eq(0, fn.islocked('d.changedtick'))
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|
|
|
|
it('is being completed', function()
|
|
|
|
feed(':echo b:<Tab><Home>let cmdline="<End>"<CR>')
|
2024-01-12 10:59:57 -07:00
|
|
|
eq('echo b:changedtick', api.nvim_get_var('cmdline'))
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|
2017-02-20 13:19:19 -07:00
|
|
|
it('cannot be changed by filter() or map()', function()
|
|
|
|
eq(2, changedtick())
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(call):E795: Cannot delete variable filter() argument',
|
|
|
|
pcall_err(command, 'call filter(b:, 0)')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(call):E742: Cannot change value of map() argument',
|
|
|
|
pcall_err(command, 'call map(b:, 0)')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(call):E742: Cannot change value of map() argument',
|
|
|
|
pcall_err(command, 'call map(b:, "v:val")')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2017-02-20 13:19:19 -07:00
|
|
|
eq(2, changedtick())
|
|
|
|
end)
|
|
|
|
it('cannot be remove()d', function()
|
|
|
|
eq(2, changedtick())
|
2021-09-19 02:29:37 -07:00
|
|
|
eq(
|
|
|
|
'Vim(call):E795: Cannot delete variable remove() argument',
|
|
|
|
pcall_err(command, 'call remove(b:, "changedtick")')
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2017-02-20 13:19:19 -07:00
|
|
|
eq(2, changedtick())
|
|
|
|
end)
|
|
|
|
it('does not inherit VAR_FIXED when copying dictionary over', function()
|
|
|
|
eq(2, changedtick())
|
2021-09-19 02:29:37 -07:00
|
|
|
eq('', exec_capture('let d1 = copy(b:)|let d1.changedtick = 42'))
|
|
|
|
eq('', exec_capture('let d2 = copy(b:)|unlet d2.changedtick'))
|
2017-02-20 13:19:19 -07:00
|
|
|
eq(2, changedtick())
|
|
|
|
end)
|
2017-02-20 10:58:17 -07:00
|
|
|
end)
|