aboutsummaryrefslogtreecommitdiff
path: root/test/functional/lua/loader_spec.lua
blob: 20d3a940b25c30383915ded6fda2df6f35add08c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
-- Test suite for testing interactions with API bindings
local t = require('test.testutil')
local n = require('test.functional.testnvim')()

local exec_lua = n.exec_lua
local command = n.command
local clear = n.clear
local eq = t.eq

describe('vim.loader', function()
  before_each(clear)

  it('can be disabled', function()
    exec_lua(function()
      local orig_loader = _G.loadfile
      vim.loader.enable()
      assert(orig_loader ~= _G.loadfile)
      vim.loader.enable(false)
      assert(orig_loader == _G.loadfile)
    end)
  end)

  it('works with --luamod-dev #27413', function()
    clear({ args = { '--luamod-dev' } })
    exec_lua(function()
      vim.loader.enable()

      require('vim.fs')

      -- try to load other vim submodules as well (Nvim Lua stdlib)
      for key, _ in pairs(vim._submodules) do
        local modname = 'vim.' .. key -- e.g. "vim.fs"

        local lhs = vim[key]
        local rhs = require(modname)
        assert(
          lhs == rhs,
          ('%s != require("%s"), %s != %s'):format(modname, modname, tostring(lhs), tostring(rhs))
        )
      end
    end)
  end)

  it('handles changing files #23027', function()
    exec_lua(function()
      vim.loader.enable()
    end)

    local tmp = t.tmpname()
    command('edit ' .. tmp)

    eq(
      1,
      exec_lua(function()
        vim.api.nvim_buf_set_lines(0, 0, -1, true, { '_G.TEST=1' })
        vim.cmd.write()
        loadfile(tmp)()
        return _G.TEST
      end)
    )

    -- fs latency
    vim.uv.sleep(10)

    eq(
      2,
      exec_lua(function()
        vim.api.nvim_buf_set_lines(0, 0, -1, true, { '_G.TEST=2' })
        vim.cmd.write()
        loadfile(tmp)()
        return _G.TEST
      end)
    )
  end)

  it('handles % signs in modpath #24491', function()
    exec_lua [[
      vim.loader.enable()
    ]]

    local tmp = t.tmpname(false)
    assert(t.mkdir(tmp))
    assert(t.mkdir(tmp .. '/%'))
    local tmp1 = tmp .. '/%/x'
    local tmp2 = tmp .. '/%%x'

    t.write_file(tmp1, 'return 1', true)
    t.write_file(tmp2, 'return 2', true)
    vim.uv.fs_utime(tmp1, 0, 0)
    vim.uv.fs_utime(tmp2, 0, 0)
    eq(1, exec_lua('return loadfile(...)()', tmp1))
    eq(2, exec_lua('return loadfile(...)()', tmp2))
  end)

  it('indents error message #29809', function()
    local errmsg = exec_lua [[
      vim.loader.enable()
      local _, errmsg = pcall(require, 'non_existent_module')
      return errmsg
    ]]
    local errors = vim.split(errmsg, '\n')
    eq("\tcache_loader: module 'non_existent_module' not found", errors[3])
    eq("\tcache_loader_lib: module 'non_existent_module' not found", errors[4])
  end)
end)