aboutsummaryrefslogtreecommitdiff
path: root/test/functional/api/buffer_spec.lua
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2015-07-11 22:33:57 -0400
committerJustin M. Keyes <justinkz@gmail.com>2015-07-11 22:33:57 -0400
commit366aa8c1963fadabc164e823b6ba758759a30178 (patch)
tree1f755096202e55c4b6557b6555b6b013fa7aebac /test/functional/api/buffer_spec.lua
parent5fdaac45a60cb555579fd2f10fad7e52c67ae042 (diff)
parent7b56a8230fcb57ab63dbc2923dfa3c4bcec42edd (diff)
downloadrneovim-366aa8c1963fadabc164e823b6ba758759a30178.tar.gz
rneovim-366aa8c1963fadabc164e823b6ba758759a30178.tar.bz2
rneovim-366aa8c1963fadabc164e823b6ba758759a30178.zip
Merge #2846 'out-of-bounds slicing'
Diffstat (limited to 'test/functional/api/buffer_spec.lua')
-rw-r--r--test/functional/api/buffer_spec.lua35
1 files changed, 35 insertions, 0 deletions
diff --git a/test/functional/api/buffer_spec.lua b/test/functional/api/buffer_spec.lua
index b85594f7af..c924988d06 100644
--- a/test/functional/api/buffer_spec.lua
+++ b/test/functional/api/buffer_spec.lua
@@ -35,6 +35,20 @@ describe('buffer_* functions', function()
eq('', curbuf('get_line', 0))
end)
+ it('get_line: out-of-bounds returns empty string', function()
+ curbuf('set_line', 0, 'line1.a')
+ eq('', curbuf('get_line', 1))
+ eq('', curbuf('get_line', -2))
+ end)
+
+ it('set_line, del_line: out-of-bounds is an error', function()
+ curbuf('set_line', 0, 'line1.a')
+ eq(false, pcall(curbuf, 'set_line', 1, 'line1.b'))
+ eq(false, pcall(curbuf, 'set_line', -2, 'line1.b'))
+ eq(false, pcall(curbuf, 'del_line', 2))
+ eq(false, pcall(curbuf, 'del_line', -3))
+ end)
+
it('can handle NULs', function()
curbuf('set_line', 0, 'ab\0cd')
eq('ab\0cd', curbuf('get_line', 0))
@@ -43,6 +57,27 @@ describe('buffer_* functions', function()
describe('{get,set}_line_slice', function()
+ it('get_line_slice: out-of-bounds returns empty array', function()
+ curbuf('set_line_slice', 0, 0, true, true, {'a', 'b', 'c'})
+ eq({'a', 'b', 'c'}, curbuf('get_line_slice', 0, 2, true, true)) --sanity
+
+ eq({}, curbuf('get_line_slice', 2, 3, false, true))
+ eq({}, curbuf('get_line_slice', 3, 9, true, true))
+ eq({}, curbuf('get_line_slice', 3, -1, true, true))
+ eq({}, curbuf('get_line_slice', -3, -4, false, true))
+ eq({}, curbuf('get_line_slice', -4, -5, true, true))
+ end)
+
+ it('set_line_slice: out-of-bounds is an error', function()
+ curbuf('set_line_slice', 0, 0, true, true, {'a', 'b', 'c'})
+ eq({'a', 'b', 'c'}, curbuf('get_line_slice', 0, 2, true, true)) --sanity
+
+ eq({'c'}, curbuf('get_line_slice', -1, 4, true, true))
+ eq({'a', 'b', 'c'}, curbuf('get_line_slice', 0, 5, true, true))
+ eq(false, pcall(curbuf, 'set_line_slice', 4, 5, true, true, {'d'}))
+ eq(false, pcall(curbuf, 'set_line_slice', -4, -5, true, true, {'d'}))
+ end)
+
it('works', function()
eq({''}, curbuf('get_line_slice', 0, -1, true, true))
-- Replace buffer