2024-04-20 08:44:13 -07:00
|
|
|
local t = require('test.testutil')
|
|
|
|
local n = require('test.functional.testnvim')()
|
2022-11-05 12:37:05 -07:00
|
|
|
local Screen = require('test.functional.ui.screen')
|
|
|
|
|
2024-04-08 02:03:20 -07:00
|
|
|
local eq = t.eq
|
2024-04-20 08:44:13 -07:00
|
|
|
local clear = n.clear
|
|
|
|
local command = n.command
|
|
|
|
local pathsep = n.get_pathsep()
|
2024-04-08 02:03:20 -07:00
|
|
|
local is_os = t.is_os
|
2024-04-20 08:44:13 -07:00
|
|
|
local api = n.api
|
|
|
|
local exec_lua = n.exec_lua
|
|
|
|
local feed_command = n.feed_command
|
|
|
|
local feed = n.feed
|
|
|
|
local fn = n.fn
|
2024-03-25 12:06:28 -07:00
|
|
|
local stdpath = fn.stdpath
|
2024-04-08 02:03:20 -07:00
|
|
|
local pcall_err = t.pcall_err
|
|
|
|
local matches = t.matches
|
|
|
|
local read_file = t.read_file
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
describe('vim.secure', function()
|
|
|
|
describe('read()', function()
|
|
|
|
local xstate = 'Xstate'
|
|
|
|
|
|
|
|
setup(function()
|
2023-04-27 00:51:44 -07:00
|
|
|
clear { env = { XDG_STATE_HOME = xstate } }
|
2024-04-20 08:44:13 -07:00
|
|
|
n.mkdir_p(xstate .. pathsep .. (is_os('win') and 'nvim-data' or 'nvim'))
|
2024-04-08 02:03:20 -07:00
|
|
|
t.write_file(
|
2022-11-05 12:37:05 -07:00
|
|
|
'Xfile',
|
|
|
|
[[
|
|
|
|
let g:foobar = 42
|
|
|
|
]]
|
|
|
|
)
|
|
|
|
end)
|
|
|
|
|
2023-04-27 00:51:44 -07:00
|
|
|
teardown(function()
|
2022-11-05 12:37:05 -07:00
|
|
|
os.remove('Xfile')
|
2024-04-20 08:44:13 -07:00
|
|
|
n.rmdir(xstate)
|
2022-11-05 12:37:05 -07:00
|
|
|
end)
|
|
|
|
|
|
|
|
it('works', function()
|
|
|
|
local screen = Screen.new(80, 8)
|
|
|
|
screen:attach()
|
|
|
|
screen:set_default_attr_ids({
|
|
|
|
[1] = { bold = true, foreground = Screen.colors.Blue1 },
|
|
|
|
[2] = { bold = true, reverse = true },
|
|
|
|
[3] = { bold = true, foreground = Screen.colors.SeaGreen },
|
|
|
|
[4] = { reverse = true },
|
|
|
|
})
|
|
|
|
|
2023-02-17 18:27:10 -07:00
|
|
|
--- XXX: screen:expect() may fail if this path is too long.
|
2024-01-12 10:59:57 -07:00
|
|
|
local cwd = fn.getcwd()
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
-- Need to use feed_command instead of exec_lua because of the confirmation prompt
|
|
|
|
feed_command([[lua vim.secure.read('Xfile')]])
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
|
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*3
|
2022-11-05 12:37:05 -07:00
|
|
|
{2: }|
|
|
|
|
:lua vim.secure.read('Xfile') |
|
2023-02-17 18:27:10 -07:00
|
|
|
{3:]]
|
|
|
|
.. cwd
|
|
|
|
.. pathsep
|
|
|
|
.. [[Xfile is not trusted.}{MATCH:%s+}|
|
2022-11-05 12:37:05 -07:00
|
|
|
{3:[i]gnore, (v)iew, (d)eny, (a)llow: }^ |
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
feed('d')
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
^ |
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*6
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
|
2024-03-25 12:06:28 -07:00
|
|
|
local trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-05 12:37:05 -07:00
|
|
|
eq(string.format('! %s', cwd .. pathsep .. 'Xfile'), vim.trim(trust))
|
2024-01-12 04:28:20 -07:00
|
|
|
eq(vim.NIL, exec_lua([[return vim.secure.read('Xfile')]]))
|
2022-11-05 12:37:05 -07:00
|
|
|
|
2024-03-25 12:06:28 -07:00
|
|
|
os.remove(stdpath('state') .. pathsep .. 'trust')
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
feed_command([[lua vim.secure.read('Xfile')]])
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
|
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*3
|
2022-11-05 12:37:05 -07:00
|
|
|
{2: }|
|
|
|
|
:lua vim.secure.read('Xfile') |
|
2023-02-17 18:27:10 -07:00
|
|
|
{3:]]
|
|
|
|
.. cwd
|
|
|
|
.. pathsep
|
|
|
|
.. [[Xfile is not trusted.}{MATCH:%s+}|
|
2022-11-05 12:37:05 -07:00
|
|
|
{3:[i]gnore, (v)iew, (d)eny, (a)llow: }^ |
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
feed('a')
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
^ |
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*6
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
|
2024-03-25 12:06:28 -07:00
|
|
|
local hash = fn.sha256(read_file('Xfile'))
|
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-05 12:37:05 -07:00
|
|
|
eq(string.format('%s %s', hash, cwd .. pathsep .. 'Xfile'), vim.trim(trust))
|
2024-01-12 04:28:20 -07:00
|
|
|
eq(vim.NIL, exec_lua([[vim.secure.read('Xfile')]]))
|
2022-11-05 12:37:05 -07:00
|
|
|
|
2024-03-25 12:06:28 -07:00
|
|
|
os.remove(stdpath('state') .. pathsep .. 'trust')
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
feed_command([[lua vim.secure.read('Xfile')]])
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
|
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*3
|
2022-11-05 12:37:05 -07:00
|
|
|
{2: }|
|
|
|
|
:lua vim.secure.read('Xfile') |
|
2023-02-17 18:27:10 -07:00
|
|
|
{3:]]
|
|
|
|
.. cwd
|
|
|
|
.. pathsep
|
|
|
|
.. [[Xfile is not trusted.}{MATCH:%s+}|
|
2022-11-05 12:37:05 -07:00
|
|
|
{3:[i]gnore, (v)iew, (d)eny, (a)llow: }^ |
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
feed('i')
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
^ |
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*6
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
|
|
|
|
-- Trust database is not updated
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-05 12:37:05 -07:00
|
|
|
eq(nil, trust)
|
|
|
|
|
|
|
|
feed_command([[lua vim.secure.read('Xfile')]])
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
|
|
|
|
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*3
|
2022-11-05 12:37:05 -07:00
|
|
|
{2: }|
|
|
|
|
:lua vim.secure.read('Xfile') |
|
2023-02-17 18:27:10 -07:00
|
|
|
{3:]]
|
|
|
|
.. cwd
|
|
|
|
.. pathsep
|
|
|
|
.. [[Xfile is not trusted.}{MATCH:%s+}|
|
2022-11-05 12:37:05 -07:00
|
|
|
{3:[i]gnore, (v)iew, (d)eny, (a)llow: }^ |
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
feed('v')
|
|
|
|
screen:expect {
|
|
|
|
grid = [[
|
2022-12-05 11:59:04 -07:00
|
|
|
^let g:foobar = 42 |
|
2023-12-09 05:42:00 -07:00
|
|
|
{1:~ }|*2
|
2023-02-17 18:27:10 -07:00
|
|
|
{2:]]
|
2024-01-12 10:59:57 -07:00
|
|
|
.. fn.fnamemodify(cwd, ':~')
|
2023-02-17 18:27:10 -07:00
|
|
|
.. pathsep
|
|
|
|
.. [[Xfile [RO]{MATCH:%s+}}|
|
2022-11-05 12:37:05 -07:00
|
|
|
|
|
|
|
|
{1:~ }|
|
|
|
|
{4:[No Name] }|
|
|
|
|
|
|
|
|
|
]],
|
|
|
|
}
|
|
|
|
|
|
|
|
-- Trust database is not updated
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-05 12:37:05 -07:00
|
|
|
eq(nil, trust)
|
|
|
|
|
|
|
|
-- Cannot write file
|
|
|
|
pcall_err(command, 'write')
|
2024-01-12 10:59:57 -07:00
|
|
|
eq(true, api.nvim_get_option_value('readonly', {}))
|
2022-11-05 12:37:05 -07:00
|
|
|
end)
|
|
|
|
end)
|
2022-11-28 12:23:04 -07:00
|
|
|
|
|
|
|
describe('trust()', function()
|
|
|
|
local xstate = 'Xstate'
|
|
|
|
|
|
|
|
setup(function()
|
2023-04-27 00:51:44 -07:00
|
|
|
clear { env = { XDG_STATE_HOME = xstate } }
|
2024-04-20 08:44:13 -07:00
|
|
|
n.mkdir_p(xstate .. pathsep .. (is_os('win') and 'nvim-data' or 'nvim'))
|
2022-11-28 12:23:04 -07:00
|
|
|
end)
|
|
|
|
|
|
|
|
teardown(function()
|
2024-04-20 08:44:13 -07:00
|
|
|
n.rmdir(xstate)
|
2022-11-28 12:23:04 -07:00
|
|
|
end)
|
|
|
|
|
|
|
|
before_each(function()
|
2024-04-08 02:03:20 -07:00
|
|
|
t.write_file('test_file', 'test')
|
2022-11-28 12:23:04 -07:00
|
|
|
end)
|
|
|
|
|
|
|
|
after_each(function()
|
|
|
|
os.remove('test_file')
|
|
|
|
end)
|
|
|
|
|
|
|
|
it('returns error when passing both path and bufnr', function()
|
2022-11-28 15:40:50 -07:00
|
|
|
matches(
|
|
|
|
'"path" and "bufnr" are mutually exclusive',
|
2022-11-28 12:23:04 -07:00
|
|
|
pcall_err(exec_lua, [[vim.secure.trust({action='deny', bufnr=0, path='test_file'})]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2022-11-28 12:23:04 -07:00
|
|
|
end)
|
|
|
|
|
2022-11-28 15:40:50 -07:00
|
|
|
it('returns error when passing neither path or bufnr', function()
|
|
|
|
matches(
|
|
|
|
'one of "path" or "bufnr" is required',
|
|
|
|
pcall_err(exec_lua, [[vim.secure.trust({action='deny'})]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2022-11-28 15:40:50 -07:00
|
|
|
end)
|
|
|
|
|
2022-11-28 12:23:04 -07:00
|
|
|
it('trust then deny then remove a file using bufnr', function()
|
2024-01-12 10:59:57 -07:00
|
|
|
local cwd = fn.getcwd()
|
2024-03-25 12:06:28 -07:00
|
|
|
local hash = fn.sha256(read_file('test_file'))
|
2022-11-28 12:23:04 -07:00
|
|
|
local full_path = cwd .. pathsep .. 'test_file'
|
|
|
|
|
|
|
|
command('edit test_file')
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='allow', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
local trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('%s %s', hash, full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='deny', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('! %s', full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='remove', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq('', vim.trim(trust))
|
|
|
|
end)
|
|
|
|
|
|
|
|
it('deny then trust then remove a file using bufnr', function()
|
2024-01-12 10:59:57 -07:00
|
|
|
local cwd = fn.getcwd()
|
2024-03-25 12:06:28 -07:00
|
|
|
local hash = fn.sha256(read_file('test_file'))
|
2022-11-28 12:23:04 -07:00
|
|
|
local full_path = cwd .. pathsep .. 'test_file'
|
|
|
|
|
|
|
|
command('edit test_file')
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='deny', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
local trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('! %s', full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='allow', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('%s %s', hash, full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='remove', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq('', vim.trim(trust))
|
|
|
|
end)
|
|
|
|
|
|
|
|
it('trust using bufnr then deny then remove a file using path', function()
|
2024-01-12 10:59:57 -07:00
|
|
|
local cwd = fn.getcwd()
|
2024-03-25 12:06:28 -07:00
|
|
|
local hash = fn.sha256(read_file('test_file'))
|
2022-11-28 12:23:04 -07:00
|
|
|
local full_path = cwd .. pathsep .. 'test_file'
|
|
|
|
|
|
|
|
command('edit test_file')
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='allow', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
local trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('%s %s', hash, full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq(
|
|
|
|
{ true, full_path },
|
|
|
|
exec_lua([[return {vim.secure.trust({action='deny', path='test_file'})}]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('! %s', full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq(
|
|
|
|
{ true, full_path },
|
|
|
|
exec_lua([[return {vim.secure.trust({action='remove', path='test_file'})}]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq('', vim.trim(trust))
|
|
|
|
end)
|
|
|
|
|
|
|
|
it('deny then trust then remove a file using bufnr', function()
|
2024-01-12 10:59:57 -07:00
|
|
|
local cwd = fn.getcwd()
|
2024-03-25 12:06:28 -07:00
|
|
|
local hash = fn.sha256(read_file('test_file'))
|
2022-11-28 12:23:04 -07:00
|
|
|
local full_path = cwd .. pathsep .. 'test_file'
|
|
|
|
|
|
|
|
command('edit test_file')
|
|
|
|
eq(
|
|
|
|
{ true, full_path },
|
|
|
|
exec_lua([[return {vim.secure.trust({action='deny', path='test_file'})}]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-03-25 12:06:28 -07:00
|
|
|
local trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('! %s', full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq({ true, full_path }, exec_lua([[return {vim.secure.trust({action='allow', bufnr=0})}]]))
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq(string.format('%s %s', hash, full_path), vim.trim(trust))
|
|
|
|
|
|
|
|
eq(
|
|
|
|
{ true, full_path },
|
|
|
|
exec_lua([[return {vim.secure.trust({action='remove', path='test_file'})}]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2024-03-25 12:06:28 -07:00
|
|
|
trust = read_file(stdpath('state') .. pathsep .. 'trust')
|
2022-11-28 12:23:04 -07:00
|
|
|
eq('', vim.trim(trust))
|
|
|
|
end)
|
|
|
|
|
|
|
|
it('trust returns error when buffer not associated to file', function()
|
|
|
|
command('new')
|
|
|
|
eq(
|
|
|
|
{ false, 'buffer is not associated with a file' },
|
|
|
|
exec_lua([[return {vim.secure.trust({action='allow', bufnr=0})}]])
|
2024-01-02 18:09:18 -07:00
|
|
|
)
|
2022-11-28 12:23:04 -07:00
|
|
|
end)
|
|
|
|
end)
|
2022-11-05 12:37:05 -07:00
|
|
|
end)
|