aboutsummaryrefslogtreecommitdiff
path: root/test/functional/eval/getline_spec.lua
diff options
context:
space:
mode:
authorJames McCoy <jamessan@jamessan.com>2018-01-15 22:28:41 -0500
committerJames McCoy <jamessan@jamessan.com>2018-01-15 22:55:15 -0500
commit514a51ef3e63362d9d96f23930bbde5cd8581da8 (patch)
treef7d66fb28eaaa34b6ac80c4cb84922f0edd13aeb /test/functional/eval/getline_spec.lua
parentc06995b34d604a37f80ee1174fcb3530dbd59206 (diff)
downloadrneovim-514a51ef3e63362d9d96f23930bbde5cd8581da8.tar.gz
rneovim-514a51ef3e63362d9d96f23930bbde5cd8581da8.tar.bz2
rneovim-514a51ef3e63362d9d96f23930bbde5cd8581da8.zip
get_buffer_lines: Return a string, when requested, on invalid input
Closes #7859
Diffstat (limited to 'test/functional/eval/getline_spec.lua')
-rw-r--r--test/functional/eval/getline_spec.lua39
1 files changed, 39 insertions, 0 deletions
diff --git a/test/functional/eval/getline_spec.lua b/test/functional/eval/getline_spec.lua
new file mode 100644
index 0000000000..8082745ec0
--- /dev/null
+++ b/test/functional/eval/getline_spec.lua
@@ -0,0 +1,39 @@
+local helpers = require('test.functional.helpers')(after_each)
+
+local call = helpers.call
+local clear = helpers.clear
+local eq = helpers.eq
+local expect = helpers.expect
+
+describe('getline', function()
+ before_each(function()
+ clear()
+ call('setline', 1, {'a', 'b', 'c'})
+ expect([[
+ a
+ b
+ c]])
+ end)
+
+ it('returns empty string for invalid line', function()
+ eq('', call('getline', -1))
+ eq('', call('getline', 0))
+ eq('', call('getline', 4))
+ end)
+
+ it('returns empty list for invalid range', function()
+ eq({}, call('getline', 2, 1))
+ eq({}, call('getline', -1, 1))
+ eq({}, call('getline', 4, 4))
+ end)
+
+ it('returns value of valid line', function()
+ eq('b', call('getline', 2))
+ eq('a', call('getline', '.'))
+ end)
+
+ it('returns value of valid range', function()
+ eq({'a', 'b'}, call('getline', 1, 2))
+ eq({'a', 'b', 'c'}, call('getline', 1, 4))
+ end)
+end)