mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 01:34:25 +00:00 
			
		
		
		
	exepath and stdpath should respect shellslash and return path with proper file separator. Closes #13787
		
			
				
	
	
		
			722 lines
		
	
	
		
			25 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			722 lines
		
	
	
		
			25 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
local helpers = require('test.functional.helpers')(after_each)
 | 
						|
local Screen = require('test.functional.ui.screen')
 | 
						|
 | 
						|
local assert_alive = helpers.assert_alive
 | 
						|
local assert_log = helpers.assert_log
 | 
						|
local clear = helpers.clear
 | 
						|
local command = helpers.command
 | 
						|
local ok = helpers.ok
 | 
						|
local eq = helpers.eq
 | 
						|
local matches = helpers.matches
 | 
						|
local eval = helpers.eval
 | 
						|
local exec_lua = helpers.exec_lua
 | 
						|
local feed = helpers.feed
 | 
						|
local funcs = helpers.funcs
 | 
						|
local mkdir = helpers.mkdir
 | 
						|
local mkdir_p = helpers.mkdir_p
 | 
						|
local nvim_prog = helpers.nvim_prog
 | 
						|
local nvim_set = helpers.nvim_set
 | 
						|
local read_file = helpers.read_file
 | 
						|
local retry = helpers.retry
 | 
						|
local rmdir = helpers.rmdir
 | 
						|
local sleep = helpers.sleep
 | 
						|
local iswin = helpers.iswin
 | 
						|
local startswith = helpers.startswith
 | 
						|
local write_file = helpers.write_file
 | 
						|
local meths = helpers.meths
 | 
						|
local alter_slashes = helpers.alter_slashes
 | 
						|
 | 
						|
local testfile = 'Xtest_startuptime'
 | 
						|
after_each(function()
 | 
						|
  os.remove(testfile)
 | 
						|
end)
 | 
						|
 | 
						|
describe('startup', function()
 | 
						|
  it('--clean', function()
 | 
						|
    clear()
 | 
						|
    ok(string.find(alter_slashes(meths.get_option('runtimepath')), funcs.stdpath('config'), 1, true) ~= nil)
 | 
						|
    clear('--clean')
 | 
						|
    ok(string.find(alter_slashes(meths.get_option('runtimepath')), funcs.stdpath('config'), 1, true) == nil)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('--startuptime', function()
 | 
						|
    clear({ args = {'--startuptime', testfile}})
 | 
						|
    retry(nil, 1000, function()
 | 
						|
      assert_log('sourcing', testfile, 100)
 | 
						|
      assert_log("require%('vim%._editor'%)", testfile, 100)
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
end)
 | 
						|
 | 
						|
describe('startup', function()
 | 
						|
  before_each(function()
 | 
						|
    clear()
 | 
						|
    os.remove('Xtest_startup_ttyout')
 | 
						|
  end)
 | 
						|
  after_each(function()
 | 
						|
    os.remove('Xtest_startup_ttyout')
 | 
						|
  end)
 | 
						|
 | 
						|
  it('pipe at both ends: has("ttyin")==0 has("ttyout")==0', function()
 | 
						|
    -- system() puts a pipe at both ends.
 | 
						|
    local out = funcs.system({ nvim_prog, '-u', 'NONE', '-i', 'NONE', '--headless',
 | 
						|
                               '--cmd', nvim_set,
 | 
						|
                               '-c', [[echo has('ttyin') has('ttyout')]],
 | 
						|
                               '+q' })
 | 
						|
    eq('0 0', out)
 | 
						|
  end)
 | 
						|
  it('with --embed: has("ttyin")==0 has("ttyout")==0', function()
 | 
						|
    local screen = Screen.new(25, 3)
 | 
						|
    -- Remote UI connected by --embed.
 | 
						|
    screen:attach()
 | 
						|
    command([[echo has('ttyin') has('ttyout')]])
 | 
						|
    screen:expect([[
 | 
						|
      ^                         |
 | 
						|
      ~                        |
 | 
						|
      0 0                      |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
  it('in a TTY: has("ttyin")==1 has("ttyout")==1', function()
 | 
						|
    local screen = Screen.new(25, 4)
 | 
						|
    screen:attach()
 | 
						|
    if iswin() then
 | 
						|
      command([[set shellcmdflag=/s\ /c shellxquote=\"]])
 | 
						|
    end
 | 
						|
    -- Running in :terminal
 | 
						|
    command([[exe printf("terminal %s -u NONE -i NONE --cmd \"]]
 | 
						|
            ..nvim_set..[[\"]]
 | 
						|
            ..[[ -c \"echo has('ttyin') has('ttyout')\""]]
 | 
						|
            ..[[, shellescape(v:progpath))]])
 | 
						|
    screen:expect([[
 | 
						|
      ^                         |
 | 
						|
      ~                        |
 | 
						|
      1 1                      |
 | 
						|
                               |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
  it('output to pipe: has("ttyin")==1 has("ttyout")==0', function()
 | 
						|
    if iswin() then
 | 
						|
      command([[set shellcmdflag=/s\ /c shellxquote=\"]])
 | 
						|
    end
 | 
						|
    -- Running in :terminal
 | 
						|
    command([[exe printf("terminal %s -u NONE -i NONE --cmd \"]]
 | 
						|
            ..nvim_set..[[\"]]
 | 
						|
            ..[[ -c \"call writefile([has('ttyin'), has('ttyout')], 'Xtest_startup_ttyout')\"]]
 | 
						|
            ..[[ -c q | cat -v"]]  -- Output to a pipe.
 | 
						|
            ..[[, shellescape(v:progpath))]])
 | 
						|
    retry(nil, 3000, function()
 | 
						|
      sleep(1)
 | 
						|
      eq('1\n0\n',  -- stdin is a TTY, stdout is a pipe
 | 
						|
         read_file('Xtest_startup_ttyout'))
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
  it('input from pipe: has("ttyin")==0 has("ttyout")==1', function()
 | 
						|
    if iswin() then
 | 
						|
      command([[set shellcmdflag=/s\ /c shellxquote=\"]])
 | 
						|
    end
 | 
						|
    -- Running in :terminal
 | 
						|
    command([[exe printf("terminal echo foo | ]]  -- Input from a pipe.
 | 
						|
            ..[[%s -u NONE -i NONE --cmd \"]]
 | 
						|
            ..nvim_set..[[\"]]
 | 
						|
            ..[[ -c \"call writefile([has('ttyin'), has('ttyout')], 'Xtest_startup_ttyout')\"]]
 | 
						|
            ..[[ -c q -- -"]]
 | 
						|
            ..[[, shellescape(v:progpath))]])
 | 
						|
    retry(nil, 3000, function()
 | 
						|
      sleep(1)
 | 
						|
      eq('0\n1\n',  -- stdin is a pipe, stdout is a TTY
 | 
						|
         read_file('Xtest_startup_ttyout'))
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
  it('input from pipe (implicit) #7679', function()
 | 
						|
    local screen = Screen.new(25, 4)
 | 
						|
    screen:attach()
 | 
						|
    if iswin() then
 | 
						|
      command([[set shellcmdflag=/s\ /c shellxquote=\"]])
 | 
						|
    end
 | 
						|
    -- Running in :terminal
 | 
						|
    command([[exe printf("terminal echo foo | ]]  -- Input from a pipe.
 | 
						|
            ..[[%s -u NONE -i NONE --cmd \"]]
 | 
						|
            ..nvim_set..[[\"]]
 | 
						|
            ..[[ -c \"echo has('ttyin') has('ttyout')\""]]
 | 
						|
            ..[[, shellescape(v:progpath))]])
 | 
						|
    screen:expect([[
 | 
						|
      ^foo                      |
 | 
						|
      ~                        |
 | 
						|
      0 1                      |
 | 
						|
                               |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
  it('input from pipe + file args #7679', function()
 | 
						|
    eq('ohyeah\r\n0 0 bufs=3',
 | 
						|
       funcs.system({nvim_prog, '-n', '-u', 'NONE', '-i', 'NONE', '--headless',
 | 
						|
                     '+.print',
 | 
						|
                     "+echo has('ttyin') has('ttyout') 'bufs='.bufnr('$')",
 | 
						|
                     '+qall!',
 | 
						|
                     '-',
 | 
						|
                     'test/functional/fixtures/tty-test.c',
 | 
						|
                     'test/functional/fixtures/shell-test.c',
 | 
						|
                    },
 | 
						|
                    { 'ohyeah', '' }))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('if stdin is empty: selects buffer 2, deletes buffer 1 #8561', function()
 | 
						|
    eq('\r\n  2 %a   "file1"                        line 0\r\n  3      "file2"                        line 0',
 | 
						|
       funcs.system({nvim_prog, '-n', '-u', 'NONE', '-i', 'NONE', '--headless',
 | 
						|
                     '+ls!',
 | 
						|
                     '+qall!',
 | 
						|
                     '-',
 | 
						|
                     'file1',
 | 
						|
                     'file2',
 | 
						|
                    },
 | 
						|
                    { '' }))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('-e/-E interactive #7679', function()
 | 
						|
    clear('-e')
 | 
						|
    local screen = Screen.new(25, 3)
 | 
						|
    screen:attach()
 | 
						|
    feed("put ='from -e'<CR>")
 | 
						|
    screen:expect([[
 | 
						|
      :put ='from -e'          |
 | 
						|
      from -e                  |
 | 
						|
      :^                        |
 | 
						|
    ]])
 | 
						|
 | 
						|
    clear('-E')
 | 
						|
    screen = Screen.new(25, 3)
 | 
						|
    screen:attach()
 | 
						|
    feed("put ='from -E'<CR>")
 | 
						|
    screen:expect([[
 | 
						|
      :put ='from -E'          |
 | 
						|
      from -E                  |
 | 
						|
      :^                        |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it('stdin with -es/-Es #7679', function()
 | 
						|
    local input = { 'append', 'line1', 'line2', '.', '%print', '' }
 | 
						|
    local inputstr = table.concat(input, '\n')
 | 
						|
 | 
						|
    --
 | 
						|
    -- -Es: read stdin as text
 | 
						|
    --
 | 
						|
    eq('partylikeits1999\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-u', 'NONE', '-i', 'NONE', '-Es', '+.print', 'test/functional/fixtures/tty-test.c' },
 | 
						|
                    { 'partylikeits1999', '' }))
 | 
						|
    eq(inputstr,
 | 
						|
       funcs.system({nvim_prog, '-i', 'NONE', '-Es', '+%print', '-' },
 | 
						|
                    input))
 | 
						|
    -- with `-u NORC`
 | 
						|
    eq('thepartycontinues\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-u', 'NORC', '-Es', '+.print' },
 | 
						|
                    { 'thepartycontinues', '' }))
 | 
						|
    -- without `-u`
 | 
						|
    eq('thepartycontinues\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-Es', '+.print' },
 | 
						|
                    { 'thepartycontinues', '' }))
 | 
						|
 | 
						|
    --
 | 
						|
    -- -es: read stdin as ex-commands
 | 
						|
    --
 | 
						|
    eq('  encoding=utf-8\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-u', 'NONE', '-i', 'NONE', '-es', 'test/functional/fixtures/tty-test.c' },
 | 
						|
                    { 'set encoding', '' }))
 | 
						|
    eq('line1\nline2\n',
 | 
						|
       funcs.system({nvim_prog, '-i', 'NONE', '-es', '-' },
 | 
						|
                    input))
 | 
						|
    -- with `-u NORC`
 | 
						|
    eq('  encoding=utf-8\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-u', 'NORC', '-es' },
 | 
						|
                    { 'set encoding', '' }))
 | 
						|
    -- without `-u`
 | 
						|
    eq('  encoding=utf-8\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-es' },
 | 
						|
                    { 'set encoding', '' }))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('-es/-Es disables swapfile, user config #8540', function()
 | 
						|
    for _,arg in ipairs({'-es', '-Es'}) do
 | 
						|
      local out = funcs.system({nvim_prog, arg,
 | 
						|
                                '+set swapfile? updatecount? shada?',
 | 
						|
                                "+put =execute('scriptnames')", '+%print'})
 | 
						|
      local line1 = string.match(out, '^.-\n')
 | 
						|
      -- updatecount=0 means swapfile was disabled.
 | 
						|
      eq("  swapfile  updatecount=0  shada=!,'100,<50,s10,h\n", line1)
 | 
						|
      -- Standard plugins were loaded, but not user config.
 | 
						|
      eq('health.vim', string.match(out, 'health.vim'))
 | 
						|
      eq(nil, string.match(out, 'init.vim'))
 | 
						|
    end
 | 
						|
  end)
 | 
						|
 | 
						|
  it('-e sets ex mode', function()
 | 
						|
    local screen = Screen.new(25, 3)
 | 
						|
    clear('-e')
 | 
						|
    screen:attach()
 | 
						|
    -- Verify we set the proper mode both before and after :vi.
 | 
						|
    feed("put =mode(1)<CR>vi<CR>:put =mode(1)<CR>")
 | 
						|
    screen:expect([[
 | 
						|
      cv                       |
 | 
						|
      ^n                        |
 | 
						|
      :put =mode(1)            |
 | 
						|
    ]])
 | 
						|
 | 
						|
    eq('cv\n',
 | 
						|
       funcs.system({nvim_prog, '-n', '-es' },
 | 
						|
                    { 'put =mode(1)', 'print', '' }))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('fails on --embed with -es/-Es', function()
 | 
						|
    matches('nvim[.exe]*: %-%-embed conflicts with %-es/%-Es',
 | 
						|
      funcs.system({nvim_prog, '--embed', '-es' }))
 | 
						|
    matches('nvim[.exe]*: %-%-embed conflicts with %-es/%-Es',
 | 
						|
      funcs.system({nvim_prog, '--embed', '-Es' }))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('does not crash if --embed is given twice', function()
 | 
						|
    clear{args={'--embed'}}
 | 
						|
    assert_alive()
 | 
						|
  end)
 | 
						|
 | 
						|
  it('does not crash when expanding cdpath during early_init', function()
 | 
						|
    clear{env={CDPATH='~doesnotexist'}}
 | 
						|
    assert_alive()
 | 
						|
    eq(',~doesnotexist', eval('&cdpath'))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('ENTER dismisses early message #7967', function()
 | 
						|
    local screen
 | 
						|
    screen = Screen.new(60, 6)
 | 
						|
    screen:attach()
 | 
						|
    command([[let g:id = termopen('"]]..nvim_prog..
 | 
						|
    [[" -u NONE -i NONE --cmd "set noruler" --cmd "let g:foo = g:bar"')]])
 | 
						|
    screen:expect([[
 | 
						|
      ^                                                            |
 | 
						|
                                                                  |
 | 
						|
      Error detected while processing pre-vimrc command line:     |
 | 
						|
      E121: Undefined variable: g:bar                             |
 | 
						|
      Press ENTER or type command to continue                     |
 | 
						|
                                                                  |
 | 
						|
    ]])
 | 
						|
    command([[call chansend(g:id, "\n")]])
 | 
						|
    screen:expect([[
 | 
						|
      ^                                                            |
 | 
						|
      ~                                                           |
 | 
						|
      ~                                                           |
 | 
						|
      [No Name]                                                   |
 | 
						|
                                                                  |
 | 
						|
                                                                  |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("sets 'shortmess' when loading other tabs", function()
 | 
						|
    clear({args={'-p', 'a', 'b', 'c'}})
 | 
						|
    local screen = Screen.new(25, 4)
 | 
						|
    screen:attach()
 | 
						|
    screen:expect({grid=[[
 | 
						|
        {1: a }{2: b  c }{3:               }{2:X}|
 | 
						|
        ^                         |
 | 
						|
        {4:~                        }|
 | 
						|
                                 |
 | 
						|
          ]],
 | 
						|
      attr_ids={
 | 
						|
        [1] = {bold = true},
 | 
						|
        [2] = {background = Screen.colors.LightGrey, underline = true},
 | 
						|
        [3] = {reverse = true},
 | 
						|
        [4] = {bold = true, foreground = Screen.colors.Blue1},
 | 
						|
    }})
 | 
						|
  end)
 | 
						|
 | 
						|
  it('fixed hang issue with --headless (#11386)', function()
 | 
						|
    local expected = ''
 | 
						|
    local period = 100
 | 
						|
    for i = 1, period - 1 do
 | 
						|
      expected = expected .. i .. '\r\n'
 | 
						|
    end
 | 
						|
    expected = expected .. period
 | 
						|
    eq(
 | 
						|
      expected,
 | 
						|
      -- FIXME(codehex): We should really set a timeout for the system function.
 | 
						|
      -- If this test fails, there will be a waiting input state.
 | 
						|
      funcs.system({nvim_prog, '-u', 'NONE', '-c',
 | 
						|
        'for i in range(1, 100) | echo i | endfor | quit',
 | 
						|
        '--headless'
 | 
						|
      })
 | 
						|
    )
 | 
						|
  end)
 | 
						|
 | 
						|
  it("get command line arguments from v:argv", function()
 | 
						|
    local out = funcs.system({ nvim_prog, '-u', 'NONE', '-i', 'NONE', '--headless',
 | 
						|
                               '--cmd', nvim_set,
 | 
						|
                               '-c', [[echo v:argv[-1:] len(v:argv) > 1]],
 | 
						|
                               '+q' })
 | 
						|
    eq('[\'+q\'] 1', out)
 | 
						|
  end)
 | 
						|
 | 
						|
  local function pack_clear(cmd)
 | 
						|
    -- add packages after config dir in rtp but before config/after
 | 
						|
    clear{args={'--cmd', 'set packpath=test/functional/fixtures', '--cmd', 'let paths=split(&rtp, ",")', '--cmd', 'let &rtp = paths[0]..",test/functional/fixtures,test/functional/fixtures/middle,"..join(paths[1:],",")', '--cmd', cmd}, env={XDG_CONFIG_HOME='test/functional/fixtures/'}}
 | 
						|
  end
 | 
						|
 | 
						|
 | 
						|
  it("handles &packpath during startup", function()
 | 
						|
    pack_clear [[
 | 
						|
      let g:x = bar#test()
 | 
						|
      let g:y = leftpad#pad("heyya")
 | 
						|
    ]]
 | 
						|
    eq(-3, eval 'g:x')
 | 
						|
    eq("  heyya", eval 'g:y')
 | 
						|
 | 
						|
    pack_clear [[ lua _G.y = require'bar'.doit() _G.z = require'leftpad''howdy' ]]
 | 
						|
    eq({9003, '\thowdy'}, exec_lua [[ return { _G.y, _G.z } ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles require from &packpath in an async handler", function()
 | 
						|
      -- NO! you cannot just speed things up by calling async functions during startup!
 | 
						|
      -- It doesn't make anything actually faster! NOOOO!
 | 
						|
    pack_clear [[ lua require'async_leftpad'('brrrr', 'async_res') ]]
 | 
						|
 | 
						|
    -- haha, async leftpad go brrrrr
 | 
						|
    eq('\tbrrrr', exec_lua [[ return _G.async_res ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles :packadd during startup", function()
 | 
						|
    -- control group: opt/bonus is not available by default
 | 
						|
    pack_clear [[
 | 
						|
      try
 | 
						|
        let g:x = bonus#secret()
 | 
						|
      catch
 | 
						|
        let g:err = v:exception
 | 
						|
      endtry
 | 
						|
    ]]
 | 
						|
    eq('Vim(let):E117: Unknown function: bonus#secret', eval 'g:err')
 | 
						|
 | 
						|
    pack_clear [[ lua _G.test = {pcall(function() require'bonus'.launch() end)} ]]
 | 
						|
    eq({false, [[[string ":lua"]:1: module 'bonus' not found:]]},
 | 
						|
       exec_lua [[ _G.test[2] = string.gsub(_G.test[2], '[\r\n].*', '') return _G.test ]])
 | 
						|
 | 
						|
    -- ok, time to launch the nukes:
 | 
						|
    pack_clear [[ packadd! bonus | let g:x = bonus#secret() ]]
 | 
						|
    eq('halloj', eval 'g:x')
 | 
						|
 | 
						|
    pack_clear [[ packadd! bonus | lua _G.y = require'bonus'.launch() ]]
 | 
						|
    eq('CPE 1704 TKS', exec_lua [[ return _G.y ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with start packages and after/", function()
 | 
						|
    pack_clear [[ lua _G.test_loadorder = {} vim.cmd "runtime! filen.lua" ]]
 | 
						|
    eq({'ordinary', 'FANCY', 'mittel', 'FANCY after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with start packages and after/ after startup", function()
 | 
						|
    pack_clear [[ lua _G.test_loadorder = {} ]]
 | 
						|
    command [[ runtime! filen.lua ]]
 | 
						|
    eq({'ordinary', 'FANCY', 'mittel', 'FANCY after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with globpath(&rtp, ...)", function()
 | 
						|
    pack_clear [[ set loadplugins | lua _G.test_loadorder = {} ]]
 | 
						|
    command [[
 | 
						|
      for x in globpath(&rtp, "filen.lua",1,1)
 | 
						|
        call v:lua.dofile(x)
 | 
						|
      endfor
 | 
						|
    ]]
 | 
						|
    eq({'ordinary', 'FANCY', 'mittel', 'FANCY after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
 | 
						|
    local rtp = meths.get_option'rtp'
 | 
						|
    ok(startswith(rtp, 'test/functional/fixtures/nvim,test/functional/fixtures/pack/*/start/*,test/functional/fixtures/start/*,test/functional/fixtures,test/functional/fixtures/middle,'),
 | 
						|
      'startswith(…)', 'rtp='..rtp)
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with opt packages and after/", function()
 | 
						|
    pack_clear [[ lua _G.test_loadorder = {} vim.cmd "packadd! superspecial\nruntime! filen.lua" ]]
 | 
						|
    eq({'ordinary', 'SuperSpecial', 'FANCY', 'mittel', 'FANCY after', 'SuperSpecial after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with opt packages and after/ after startup", function()
 | 
						|
    pack_clear [[ lua _G.test_loadorder = {} ]]
 | 
						|
    command [[
 | 
						|
      packadd! superspecial
 | 
						|
      runtime! filen.lua
 | 
						|
    ]]
 | 
						|
    eq({'ordinary', 'SuperSpecial', 'FANCY', 'mittel', 'FANCY after', 'SuperSpecial after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with opt packages and globpath(&rtp, ...)", function()
 | 
						|
    pack_clear [[ set loadplugins | lua _G.test_loadorder = {} ]]
 | 
						|
    command [[
 | 
						|
      packadd! superspecial
 | 
						|
      for x in globpath(&rtp, "filen.lua",1,1)
 | 
						|
        call v:lua.dofile(x)
 | 
						|
      endfor
 | 
						|
    ]]
 | 
						|
    eq({'ordinary', 'SuperSpecial', 'FANCY', 'mittel', 'SuperSpecial after', 'FANCY after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order with a package that changes packpath", function()
 | 
						|
    pack_clear [[ lua _G.test_loadorder = {} vim.cmd "packadd! funky\nruntime! filen.lua" ]]
 | 
						|
    eq({'ordinary', 'funky!', 'FANCY', 'mittel', 'FANCY after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
    eq({'ordinary', 'funky!', 'mittel', 'ordinary after'}, exec_lua [[ return _G.nested_order ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it("handles the correct order when prepending packpath", function()
 | 
						|
    clear{args={'--cmd', 'set packpath^=test/functional/fixtures',  '--cmd', [[ lua _G.test_loadorder = {} vim.cmd "runtime! filen.lua" ]]}, env={XDG_CONFIG_HOME='test/functional/fixtures/'}}
 | 
						|
    eq({'ordinary', 'FANCY', 'FANCY after', 'ordinary after'}, exec_lua [[ return _G.test_loadorder ]])
 | 
						|
  end)
 | 
						|
end)
 | 
						|
 | 
						|
describe('sysinit', function()
 | 
						|
  local xdgdir = 'Xxdg'
 | 
						|
  local vimdir = 'Xvim'
 | 
						|
  local xhome = 'Xhome'
 | 
						|
  local pathsep = helpers.get_pathsep()
 | 
						|
 | 
						|
  before_each(function()
 | 
						|
    rmdir(xdgdir)
 | 
						|
    rmdir(vimdir)
 | 
						|
    rmdir(xhome)
 | 
						|
 | 
						|
    mkdir(xdgdir)
 | 
						|
    mkdir(xdgdir .. pathsep .. 'nvim')
 | 
						|
    write_file(table.concat({xdgdir, 'nvim', 'sysinit.vim'}, pathsep), [[
 | 
						|
      let g:loaded = get(g:, "loaded", 0) + 1
 | 
						|
      let g:xdg = 1
 | 
						|
    ]])
 | 
						|
 | 
						|
    mkdir(vimdir)
 | 
						|
    write_file(table.concat({vimdir, 'sysinit.vim'}, pathsep), [[
 | 
						|
      let g:loaded = get(g:, "loaded", 0) + 1
 | 
						|
      let g:vim = 1
 | 
						|
    ]])
 | 
						|
 | 
						|
    mkdir(xhome)
 | 
						|
  end)
 | 
						|
  after_each(function()
 | 
						|
    rmdir(xdgdir)
 | 
						|
    rmdir(vimdir)
 | 
						|
    rmdir(xhome)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('prefers XDG_CONFIG_DIRS over VIM', function()
 | 
						|
    clear{args={'--cmd', 'set nomore undodir=. directory=. belloff='},
 | 
						|
          args_rm={'-u', '--cmd'},
 | 
						|
          env={ HOME=xhome,
 | 
						|
                XDG_CONFIG_DIRS=xdgdir,
 | 
						|
                VIM=vimdir }}
 | 
						|
    eq('loaded 1 xdg 1 vim 0',
 | 
						|
       eval('printf("loaded %d xdg %d vim %d", g:loaded, get(g:, "xdg", 0), get(g:, "vim", 0))'))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('uses VIM if XDG_CONFIG_DIRS unset', function()
 | 
						|
    clear{args={'--cmd', 'set nomore undodir=. directory=. belloff='},
 | 
						|
          args_rm={'-u', '--cmd'},
 | 
						|
          env={ HOME=xhome,
 | 
						|
                XDG_CONFIG_DIRS='',
 | 
						|
                VIM=vimdir }}
 | 
						|
    eq('loaded 1 xdg 0 vim 1',
 | 
						|
       eval('printf("loaded %d xdg %d vim %d", g:loaded, get(g:, "xdg", 0), get(g:, "vim", 0))'))
 | 
						|
  end)
 | 
						|
 | 
						|
  it('fixed hang issue with -D (#12647)', function()
 | 
						|
    local screen
 | 
						|
    screen = Screen.new(60, 7)
 | 
						|
    screen:attach()
 | 
						|
    command([[let g:id = termopen('"]]..nvim_prog..
 | 
						|
    [[" -u NONE -i NONE --cmd "set noruler" -D')]])
 | 
						|
    screen:expect([[
 | 
						|
      ^                                                            |
 | 
						|
      Entering Debug mode.  Type "cont" to continue.              |
 | 
						|
      nvim_exec()                                                 |
 | 
						|
      cmd: aunmenu *                                              |
 | 
						|
      >                                                           |
 | 
						|
      <" -u NONE -i NONE --cmd "set noruler" -D 1,1            All|
 | 
						|
                                                                  |
 | 
						|
    ]])
 | 
						|
    command([[call chansend(g:id, "cont\n")]])
 | 
						|
    screen:expect([[
 | 
						|
      ^                                                            |
 | 
						|
      ~                                                           |
 | 
						|
      ~                                                           |
 | 
						|
      [No Name]                                                   |
 | 
						|
                                                                  |
 | 
						|
      <" -u NONE -i NONE --cmd "set noruler" -D 1,0-1          All|
 | 
						|
                                                                  |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
end)
 | 
						|
 | 
						|
describe('user config init', function()
 | 
						|
  local xhome = 'Xhome'
 | 
						|
  local pathsep = helpers.get_pathsep()
 | 
						|
  local xconfig = xhome .. pathsep .. 'Xconfig'
 | 
						|
  local xdata = xhome .. pathsep .. 'Xdata'
 | 
						|
  local init_lua_path = table.concat({xconfig, 'nvim', 'init.lua'}, pathsep)
 | 
						|
  local xenv = { XDG_CONFIG_HOME=xconfig, XDG_DATA_HOME=xdata }
 | 
						|
 | 
						|
  before_each(function()
 | 
						|
    rmdir(xhome)
 | 
						|
 | 
						|
    mkdir_p(xconfig .. pathsep .. 'nvim')
 | 
						|
    mkdir_p(xdata)
 | 
						|
 | 
						|
    write_file(init_lua_path, [[
 | 
						|
      vim.g.lua_rc = 1
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  after_each(function()
 | 
						|
    rmdir(xhome)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('loads init.lua from XDG config home by default', function()
 | 
						|
    clear{ args_rm={'-u' }, env=xenv }
 | 
						|
 | 
						|
    eq(1, eval('g:lua_rc'))
 | 
						|
    eq(funcs.fnamemodify(init_lua_path, ':p'), eval('$MYVIMRC'))
 | 
						|
  end)
 | 
						|
 | 
						|
  describe 'with explicitly provided config'(function()
 | 
						|
    local custom_lua_path = table.concat({xhome, 'custom.lua'}, pathsep)
 | 
						|
    before_each(function()
 | 
						|
      write_file(custom_lua_path, [[
 | 
						|
      vim.g.custom_lua_rc = 1
 | 
						|
      ]])
 | 
						|
    end)
 | 
						|
 | 
						|
    it('loads custom lua config and does not set $MYVIMRC', function()
 | 
						|
      clear{ args={'-u', custom_lua_path }, env=xenv }
 | 
						|
      eq(1, eval('g:custom_lua_rc'))
 | 
						|
      eq('', eval('$MYVIMRC'))
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
 | 
						|
  describe 'VIMRC also exists'(function()
 | 
						|
    before_each(function()
 | 
						|
      write_file(table.concat({xconfig, 'nvim', 'init.vim'}, pathsep), [[
 | 
						|
      let g:vim_rc = 1
 | 
						|
      ]])
 | 
						|
    end)
 | 
						|
 | 
						|
    it('loads default lua config, but shows an error', function()
 | 
						|
      clear{ args_rm={'-u'}, env=xenv }
 | 
						|
      feed('<cr><c-c>')  -- Dismiss "Conflicting config …" message.
 | 
						|
      eq(1, eval('g:lua_rc'))
 | 
						|
      matches('^E5422: Conflicting configs', meths.exec('messages', true))
 | 
						|
    end)
 | 
						|
  end)
 | 
						|
end)
 | 
						|
 | 
						|
describe('runtime:', function()
 | 
						|
  local xhome = 'Xhome'
 | 
						|
  local pathsep = helpers.get_pathsep()
 | 
						|
  local xconfig = xhome .. pathsep .. 'Xconfig'
 | 
						|
  local xdata = xhome .. pathsep .. 'Xdata'
 | 
						|
  local xenv = { XDG_CONFIG_HOME=xconfig, XDG_DATA_HOME=xdata }
 | 
						|
 | 
						|
  setup(function()
 | 
						|
    rmdir(xhome)
 | 
						|
    mkdir_p(xconfig .. pathsep .. 'nvim')
 | 
						|
    mkdir_p(xdata)
 | 
						|
  end)
 | 
						|
 | 
						|
  teardown(function()
 | 
						|
    rmdir(xhome)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('loads plugin/*.lua from XDG config home', function()
 | 
						|
    local plugin_folder_path = table.concat({xconfig, 'nvim', 'plugin'}, pathsep)
 | 
						|
    local plugin_file_path = table.concat({plugin_folder_path, 'plugin.lua'}, pathsep)
 | 
						|
    mkdir_p(plugin_folder_path)
 | 
						|
    write_file(plugin_file_path, [[ vim.g.lua_plugin = 1 ]])
 | 
						|
 | 
						|
    clear{ args_rm={'-u'}, env=xenv }
 | 
						|
 | 
						|
    eq(1, eval('g:lua_plugin'))
 | 
						|
    rmdir(plugin_folder_path)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('loads plugin/*.lua from start packages', function()
 | 
						|
    local plugin_path = table.concat({xconfig, 'nvim', 'pack', 'catagory',
 | 
						|
    'start', 'test_plugin'}, pathsep)
 | 
						|
    local plugin_folder_path = table.concat({plugin_path, 'plugin'}, pathsep)
 | 
						|
    local plugin_file_path = table.concat({plugin_folder_path, 'plugin.lua'},
 | 
						|
    pathsep)
 | 
						|
    local profiler_file = 'test_startuptime.log'
 | 
						|
 | 
						|
    mkdir_p(plugin_folder_path)
 | 
						|
    write_file(plugin_file_path, [[vim.g.lua_plugin = 2]])
 | 
						|
 | 
						|
    clear{ args_rm={'-u'}, args={'--startuptime', profiler_file}, env=xenv }
 | 
						|
 | 
						|
    eq(2, eval('g:lua_plugin'))
 | 
						|
    -- Check if plugin_file_path is listed in :scriptname
 | 
						|
    local scripts = meths.exec(':scriptnames', true)
 | 
						|
    assert(scripts:find(plugin_file_path))
 | 
						|
 | 
						|
    -- Check if plugin_file_path is listed in startup profile
 | 
						|
    local profile_reader = io.open(profiler_file, 'r')
 | 
						|
    local profile_log = profile_reader:read('*a')
 | 
						|
    profile_reader:close()
 | 
						|
    assert(profile_log:find(plugin_file_path))
 | 
						|
 | 
						|
    os.remove(profiler_file)
 | 
						|
    rmdir(plugin_path)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('loads plugin/*.lua from site packages', function()
 | 
						|
    local nvimdata = iswin() and "nvim-data" or "nvim"
 | 
						|
    local plugin_path = table.concat({xdata, nvimdata, 'site', 'pack', 'xa', 'start', 'yb'}, pathsep)
 | 
						|
    local plugin_folder_path = table.concat({plugin_path, 'plugin'}, pathsep)
 | 
						|
    local plugin_after_path = table.concat({plugin_path, 'after', 'plugin'}, pathsep)
 | 
						|
    local plugin_file_path = table.concat({plugin_folder_path, 'plugin.lua'}, pathsep)
 | 
						|
    local plugin_after_file_path = table.concat({plugin_after_path, 'helloo.lua'}, pathsep)
 | 
						|
 | 
						|
    mkdir_p(plugin_folder_path)
 | 
						|
    write_file(plugin_file_path, [[table.insert(_G.lista, "unos")]])
 | 
						|
    mkdir_p(plugin_after_path)
 | 
						|
    write_file(plugin_after_file_path, [[table.insert(_G.lista, "dos")]])
 | 
						|
 | 
						|
    clear{ args_rm={'-u'}, args={'--cmd', 'lua _G.lista = {}'}, env=xenv }
 | 
						|
 | 
						|
    eq({'unos', 'dos'}, exec_lua "return _G.lista")
 | 
						|
 | 
						|
    rmdir(plugin_path)
 | 
						|
  end)
 | 
						|
 | 
						|
 | 
						|
  it('loads ftdetect/*.lua', function()
 | 
						|
    local ftdetect_folder = table.concat({xconfig, 'nvim', 'ftdetect'}, pathsep)
 | 
						|
    local ftdetect_file = table.concat({ftdetect_folder , 'new-ft.lua'}, pathsep)
 | 
						|
    mkdir_p(ftdetect_folder)
 | 
						|
    write_file(ftdetect_file , [[vim.g.lua_ftdetect = 1]])
 | 
						|
 | 
						|
    clear{ args_rm={'-u'}, env=xenv }
 | 
						|
 | 
						|
    eq(1, eval('g:lua_ftdetect'))
 | 
						|
    rmdir(ftdetect_folder)
 | 
						|
  end)
 | 
						|
end)
 | 
						|
 | 
						|
describe('user session', function()
 | 
						|
  local xhome = 'Xhome'
 | 
						|
  local pathsep = helpers.get_pathsep()
 | 
						|
  local session_file = table.concat({xhome, 'session.lua'}, pathsep)
 | 
						|
 | 
						|
  before_each(function()
 | 
						|
    rmdir(xhome)
 | 
						|
 | 
						|
    mkdir(xhome)
 | 
						|
    write_file(session_file, [[
 | 
						|
      vim.g.lua_session = 1
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  after_each(function()
 | 
						|
    rmdir(xhome)
 | 
						|
  end)
 | 
						|
 | 
						|
  it('loads session from the provided lua file', function()
 | 
						|
    clear{ args={'-S', session_file }, env={ HOME=xhome }}
 | 
						|
    eq(1, eval('g:lua_session'))
 | 
						|
  end)
 | 
						|
end)
 |