HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //home/ubuntu/neovim/test/functional/autocmd/cursorhold_spec.lua
local t = require('test.testutil')
local n = require('test.functional.testnvim')()

local clear = n.clear
local eq = t.eq
local feed = n.feed
local retry = t.retry
local exec = n.source
local sleep = vim.uv.sleep
local api = n.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)