aboutsummaryrefslogtreecommitdiff
path: root/test/functional/lua/xdiff_spec.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/lua/xdiff_spec.lua')
-rw-r--r--test/functional/lua/xdiff_spec.lua112
1 files changed, 66 insertions, 46 deletions
diff --git a/test/functional/lua/xdiff_spec.lua b/test/functional/lua/xdiff_spec.lua
index d5589c1f13..269dbde10a 100644
--- a/test/functional/lua/xdiff_spec.lua
+++ b/test/functional/lua/xdiff_spec.lua
@@ -12,15 +12,11 @@ describe('xdiff bindings', function()
end)
describe('can diff text', function()
- before_each(function()
- exec_lua [[
- a1 = 'Hello\n'
- b1 = 'Helli\n'
-
- a2 = 'Hello\nbye\nfoo\n'
- b2 = 'Helli\nbye\nbar\nbaz\n'
- ]]
- end)
+ local a1 = 'Hello\n'
+ local b1 = 'Helli\n'
+
+ local a2 = 'Hello\nbye\nfoo\n'
+ local b2 = 'Helli\nbye\nbar\nbaz\n'
it('with no callback', function()
eq(
@@ -30,7 +26,9 @@ describe('xdiff bindings', function()
'+Helli',
'',
}, '\n'),
- exec_lua('return vim.diff(a1, b1)')
+ exec_lua(function()
+ return vim.diff(a1, b1)
+ end)
)
eq(
@@ -44,63 +42,81 @@ describe('xdiff bindings', function()
'+baz',
'',
}, '\n'),
- exec_lua('return vim.diff(a2, b2)')
+ exec_lua(function()
+ return vim.diff(a2, b2)
+ end)
)
end)
it('with callback', function()
- exec_lua([[on_hunk = function(sa, ca, sb, cb)
- exp[#exp+1] = {sa, ca, sb, cb}
- end]])
-
eq(
{ { 1, 1, 1, 1 } },
- exec_lua [[
- exp = {}
- assert(vim.diff(a1, b1, {on_hunk = on_hunk}) == nil)
+ exec_lua(function()
+ local exp = {} --- @type table[]
+ assert(vim.diff(a1, b1, {
+ on_hunk = function(...)
+ exp[#exp + 1] = { ... }
+ end,
+ }) == nil)
return exp
- ]]
+ end)
)
eq(
{ { 1, 1, 1, 1 }, { 3, 1, 3, 2 } },
- exec_lua [[
- exp = {}
- assert(vim.diff(a2, b2, {on_hunk = on_hunk}) == nil)
+ exec_lua(function()
+ local exp = {} --- @type table[]
+ assert(vim.diff(a2, b2, {
+ on_hunk = function(...)
+ exp[#exp + 1] = { ... }
+ end,
+ }) == nil)
return exp
- ]]
+ end)
)
-- gives higher precedence to on_hunk over result_type
eq(
{ { 1, 1, 1, 1 }, { 3, 1, 3, 2 } },
- exec_lua [[
- exp = {}
- assert(vim.diff(a2, b2, {on_hunk = on_hunk, result_type='indices'}) == nil)
+ exec_lua(function()
+ local exp = {} --- @type table[]
+ assert(vim.diff(a2, b2, {
+ on_hunk = function(...)
+ exp[#exp + 1] = { ... }
+ end,
+ result_type = 'indices',
+ }) == nil)
return exp
- ]]
+ end)
)
end)
it('with error callback', function()
- exec_lua [[
- on_hunk = function(sa, ca, sb, cb)
- error('ERROR1')
- end
- ]]
-
eq(
- [[error running function on_hunk: [string "<nvim>"]:0: ERROR1]],
- pcall_err(exec_lua, [[vim.diff(a1, b1, {on_hunk = on_hunk})]])
+ [[.../xdiff_spec.lua:0: error running function on_hunk: .../xdiff_spec.lua:0: ERROR1]],
+ pcall_err(exec_lua, function()
+ vim.diff(a1, b1, {
+ on_hunk = function()
+ error('ERROR1')
+ end,
+ })
+ end)
)
end)
it('with hunk_lines', function()
- eq({ { 1, 1, 1, 1 } }, exec_lua([[return vim.diff(a1, b1, {result_type = 'indices'})]]))
+ eq(
+ { { 1, 1, 1, 1 } },
+ exec_lua(function()
+ return vim.diff(a1, b1, { result_type = 'indices' })
+ end)
+ )
eq(
{ { 1, 1, 1, 1 }, { 3, 1, 3, 2 } },
- exec_lua([[return vim.diff(a2, b2, {result_type = 'indices'})]])
+ exec_lua(function()
+ return vim.diff(a2, b2, { result_type = 'indices' })
+ end)
)
end)
@@ -143,16 +159,11 @@ describe('xdiff bindings', function()
'+}',
'',
}, '\n'),
- exec_lua(
- [[
- local args = {...}
- return vim.diff(args[1], args[2], {
- algorithm = 'patience'
+ exec_lua(function()
+ return vim.diff(a, b, {
+ algorithm = 'patience',
})
- ]],
- a,
- b
- )
+ end)
)
end)
end)
@@ -174,4 +185,13 @@ describe('xdiff bindings', function()
pcall_err(exec_lua, [[vim.diff('a', 'b', { on_hunk = true })]])
)
end)
+
+ it('can handle strings with embedded NUL characters (GitHub #30305)', function()
+ eq(
+ { { 0, 0, 1, 1 }, { 1, 0, 3, 2 } },
+ exec_lua(function()
+ return vim.diff('\n', '\0\n\n\nb', { linematch = true, result_type = 'indices' })
+ end)
+ )
+ end)
end)