neovim/test/functional/provider/ruby_spec.lua
Famiu Haque 576dddb461 test: don't unnecessarily specify win/buf for nvim_(get|set)_option_value
`nvim_(get|set)_option_value` pick the current buffer / window by default for buffer-local/window-local (but not global-local) options. So specifying `buf = 0` or `win = 0` in opts is unnecessary for those options. This PR removes those to reduce code clutter.
2023-05-22 13:02:07 +06:00

133 lines
3.7 KiB
Lua

local helpers = require('test.functional.helpers')(after_each)
local assert_alive = helpers.assert_alive
local clear = helpers.clear
local command = helpers.command
local eq = helpers.eq
local exc_exec = helpers.exc_exec
local expect = helpers.expect
local feed = helpers.feed
local feed_command = helpers.feed_command
local funcs = helpers.funcs
local insert = helpers.insert
local meths = helpers.meths
local missing_provider = helpers.missing_provider
local matches = helpers.matches
local write_file = helpers.write_file
local pcall_err = helpers.pcall_err
do
clear()
local reason = missing_provider('ruby')
if reason then
it(':ruby reports E319 if provider is missing', function()
local expected = [[Vim%(ruby.*%):E319: No "ruby" provider found.*]]
matches(expected, pcall_err(command, 'ruby puts "foo"'))
matches(expected, pcall_err(command, 'rubyfile foo'))
end)
pending(string.format('Missing neovim RubyGem (%s)', reason), function() end)
return
end
end
before_each(function()
clear()
end)
describe('ruby feature test', function()
it('works', function()
eq(1, funcs.has('ruby'))
end)
end)
describe(':ruby command', function()
it('evaluates ruby', function()
command('ruby VIM.command("let g:set_by_ruby = [100, 0]")')
eq({100, 0}, meths.get_var('set_by_ruby'))
end)
it('supports nesting', function()
command([[ruby VIM.command('ruby VIM.command("let set_by_nested_ruby = 555")')]])
eq(555, meths.get_var('set_by_nested_ruby'))
end)
end)
describe(':rubyfile command', function()
it('evaluates a ruby file', function()
local fname = 'rubyfile.rb'
write_file(fname, 'VIM.command("let set_by_rubyfile = 123")')
command('rubyfile rubyfile.rb')
eq(123, meths.get_var('set_by_rubyfile'))
os.remove(fname)
end)
end)
describe(':rubydo command', function()
it('exposes the $_ variable for modifying lines', function()
insert('abc\ndef\nghi\njkl')
expect([[
abc
def
ghi
jkl]])
feed('ggjvj:rubydo $_.upcase!<CR>')
expect([[
abc
DEF
GHI
jkl]])
end)
it('operates on all lines when not given a range', function()
insert('abc\ndef\nghi\njkl')
expect([[
abc
def
ghi
jkl]])
feed(':rubydo $_.upcase!<CR>')
expect([[
ABC
DEF
GHI
JKL]])
end)
it('does not modify the buffer if no changes are made', function()
command('normal :rubydo 42')
eq(false, meths.get_option_value('modified', {}))
end)
end)
describe('ruby provider', function()
it('RPC call to expand("<afile>") during BufDelete #5245 #5617', function()
helpers.add_builddir_to_rtp()
command([=[autocmd BufDelete * ruby VIM::evaluate('expand("<afile>")')]=])
feed_command('help help')
assert_alive()
end)
end)
describe('rubyeval()', function()
it('evaluates ruby objects', function()
eq({1, 2, {['key'] = 'val'}}, funcs.rubyeval('[1, 2, {key: "val"}]'))
end)
it('returns nil for empty strings', function()
eq(helpers.NIL, funcs.rubyeval(''))
end)
it('errors out when given non-string', function()
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(10)'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(v:_null_dict)'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(v:_null_list)'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(0.0)'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(function("tr"))'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(v:true)'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(v:false)'))
eq('Vim(call):E474: Invalid argument', exc_exec('call rubyeval(v:null)'))
end)
end)