aboutsummaryrefslogtreecommitdiff
path: root/test/functional/autocmd/cursorhold_spec.lua
blob: fc2b65f53addfcb68e95d84e5e7997518a4355b5 (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
local helpers = require('test.functional.helpers')(after_each)

local clear = helpers.clear
local eq = helpers.eq
local feed = helpers.feed
local retry = helpers.retry
local exec = helpers.source
local sleep = vim.uv.sleep
local api = helpers.api

before_each(clear)

describe('CursorHold', function()
  before_each(function()
    exec([[
      let g:cursorhold = 0
      augroup test
        au CursorHold * let g:cursorhold += 1
      augroup END
    ]])
  end)

  it('is triggered correctly #12587', function()
    local function test_cursorhold(fn, early)
      local ut = 2
      -- if testing with small 'updatetime' fails, double its value and test again
      retry(10, nil, function()
        ut = ut * 2
        api.nvim_set_option_value('updatetime', ut, {})
        feed('0') -- reset did_cursorhold
        api.nvim_set_var('cursorhold', 0)
        sleep(ut / 4)
        fn()
        eq(0, api.nvim_get_var('cursorhold'))
        sleep(ut / 2)
        fn()
        eq(0, api.nvim_get_var('cursorhold'))
        sleep(ut / 2)
        eq(early, api.nvim_get_var('cursorhold'))
        sleep(ut / 4 * 3)
        eq(1, api.nvim_get_var('cursorhold'))
      end)
    end

    local ignore_key = api.nvim_replace_termcodes('<Ignore>', true, true, true)
    test_cursorhold(function() end, 1)
    test_cursorhold(function()
      feed('')
    end, 1)
    test_cursorhold(function()
      api.nvim_feedkeys('', 'n', true)
    end, 1)
    test_cursorhold(function()
      feed('<Ignore>')
    end, 0)
    test_cursorhold(function()
      api.nvim_feedkeys(ignore_key, 'n', true)
    end, 0)
  end)

  it("reducing 'updatetime' while waiting for CursorHold #20241", function()
    api.nvim_set_option_value('updatetime', 10000, {})
    feed('0') -- reset did_cursorhold
    api.nvim_set_var('cursorhold', 0)
    sleep(50)
    eq(0, api.nvim_get_var('cursorhold'))
    api.nvim_set_option_value('updatetime', 20, {})
    sleep(10)
    eq(1, api.nvim_get_var('cursorhold'))
  end)
end)

describe('CursorHoldI', function()
  -- NOTE: since this test uses RPC it is not necessary to trigger the initial
  --       issue (#3757) via timer's or RPC callbacks in the first place.
  it('is triggered after input', function()
    exec([[
      set updatetime=1

      let g:cursorhold = 0
      augroup test
        au CursorHoldI * let g:cursorhold += 1
      augroup END
    ]])
    feed('ifoo')
    retry(5, nil, function()
      sleep(1)
      eq(1, api.nvim_get_var('cursorhold'))
    end)
  end)
end)