mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 01:34:25 +00:00 
			
		
		
		
	This is the first installment of a multi-PR series significantly refactoring how highlights are being specified. The end goal is to have a base set of 20 ish most common highlights, and then specific files only need to add more groups to that as needed. As a complicating factor, we also want to migrate to the new default color scheme eventually. But by sharing a base set, that future PR will hopefully be a lot smaller since a lot of tests will be migrated just simply by updating the base set in place. As a first step, fix the anti-pattern than Screen defaults to ignoring highlights. Highlights are integral part of the screen state, not something "extra" which we only test "sometimes". For now, we still allow opt-out via the intentionally ugly screen._default_attr_ids = nil The end goal is to get rid of all of these eventually (which will be easier as part of the color scheme migration)
		
			
				
	
	
		
			255 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			255 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
local helpers = require('test.functional.helpers')(after_each)
 | 
						|
local Screen = require('test.functional.ui.screen')
 | 
						|
 | 
						|
local eq = helpers.eq
 | 
						|
local exec = helpers.exec
 | 
						|
local exec_capture = helpers.exec_capture
 | 
						|
local feed = helpers.feed
 | 
						|
local api = helpers.api
 | 
						|
local clear = helpers.clear
 | 
						|
local command = helpers.command
 | 
						|
local expect = helpers.expect
 | 
						|
local insert = helpers.insert
 | 
						|
local eval = helpers.eval
 | 
						|
 | 
						|
describe(':*map', function()
 | 
						|
  before_each(clear)
 | 
						|
 | 
						|
  it('are not affected by &isident', function()
 | 
						|
    api.nvim_set_var('counter', 0)
 | 
						|
    command('nnoremap <C-x> :let counter+=1<CR>')
 | 
						|
    api.nvim_set_option_value('isident', ('%u'):format(('>'):byte()), {})
 | 
						|
    command('nnoremap <C-y> :let counter+=1<CR>')
 | 
						|
    -- &isident used to disable keycode parsing here as well
 | 
						|
    feed('\24\25<C-x><C-y>')
 | 
						|
    eq(4, api.nvim_get_var('counter'))
 | 
						|
  end)
 | 
						|
 | 
						|
  it(':imap <M-">', function()
 | 
						|
    command('imap <M-"> foo')
 | 
						|
    feed('i-<M-">-')
 | 
						|
    expect('-foo-')
 | 
						|
  end)
 | 
						|
 | 
						|
  it('shows <Nop> as mapping rhs', function()
 | 
						|
    command('nmap asdf <Nop>')
 | 
						|
    eq(
 | 
						|
      [[
 | 
						|
 | 
						|
n  asdf          <Nop>]],
 | 
						|
      exec_capture('nmap asdf')
 | 
						|
    )
 | 
						|
  end)
 | 
						|
 | 
						|
  it('mappings with description can be filtered', function()
 | 
						|
    api.nvim_set_keymap('n', 'asdf1', 'qwert', { desc = 'do the one thing' })
 | 
						|
    api.nvim_set_keymap('n', 'asdf2', 'qwert', { desc = 'doesnot really do anything' })
 | 
						|
    api.nvim_set_keymap('n', 'asdf3', 'qwert', { desc = 'do the other thing' })
 | 
						|
    eq(
 | 
						|
      [[
 | 
						|
 | 
						|
n  asdf3         qwert
 | 
						|
                 do the other thing
 | 
						|
n  asdf1         qwert
 | 
						|
                 do the one thing]],
 | 
						|
      exec_capture('filter the nmap')
 | 
						|
    )
 | 
						|
  end)
 | 
						|
 | 
						|
  it('<Plug> mappings ignore nore', function()
 | 
						|
    command('let x = 0')
 | 
						|
    eq(0, api.nvim_eval('x'))
 | 
						|
    command [[
 | 
						|
      nnoremap <Plug>(Increase_x) <cmd>let x+=1<cr>
 | 
						|
      nmap increase_x_remap <Plug>(Increase_x)
 | 
						|
      nnoremap increase_x_noremap <Plug>(Increase_x)
 | 
						|
    ]]
 | 
						|
    feed('increase_x_remap')
 | 
						|
    eq(1, api.nvim_eval('x'))
 | 
						|
    feed('increase_x_noremap')
 | 
						|
    eq(2, api.nvim_eval('x'))
 | 
						|
  end)
 | 
						|
 | 
						|
  it("Doesn't auto ignore nore for keys before or after <Plug> mapping", function()
 | 
						|
    command('let x = 0')
 | 
						|
    eq(0, api.nvim_eval('x'))
 | 
						|
    command [[
 | 
						|
      nnoremap x <nop>
 | 
						|
      nnoremap <Plug>(Increase_x) <cmd>let x+=1<cr>
 | 
						|
      nmap increase_x_remap x<Plug>(Increase_x)x
 | 
						|
      nnoremap increase_x_noremap x<Plug>(Increase_x)x
 | 
						|
    ]]
 | 
						|
    insert('Some text')
 | 
						|
    eq('Some text', eval("getline('.')"))
 | 
						|
 | 
						|
    feed('increase_x_remap')
 | 
						|
    eq(1, api.nvim_eval('x'))
 | 
						|
    eq('Some text', eval("getline('.')"))
 | 
						|
    feed('increase_x_noremap')
 | 
						|
    eq(2, api.nvim_eval('x'))
 | 
						|
    eq('Some te', eval("getline('.')"))
 | 
						|
  end)
 | 
						|
 | 
						|
  it(':unmap with rhs works when lhs is in another bucket #21530', function()
 | 
						|
    command('map F <Plug>Foo')
 | 
						|
    command('unmap <Plug>Foo')
 | 
						|
    eq('\nNo mapping found', exec_capture('map F'))
 | 
						|
  end)
 | 
						|
end)
 | 
						|
 | 
						|
describe('Screen', function()
 | 
						|
  local screen
 | 
						|
  before_each(function()
 | 
						|
    clear()
 | 
						|
    screen = Screen.new(20, 5)
 | 
						|
    screen:attach()
 | 
						|
  end)
 | 
						|
 | 
						|
  it('cursor is restored after :map <expr> which calls input()', function()
 | 
						|
    command('map <expr> x input("> ")')
 | 
						|
    screen:expect([[
 | 
						|
      ^                    |
 | 
						|
      {1:~                   }|*3
 | 
						|
                          |
 | 
						|
    ]])
 | 
						|
    feed('x')
 | 
						|
    screen:expect([[
 | 
						|
                          |
 | 
						|
      {1:~                   }|*3
 | 
						|
      > ^                  |
 | 
						|
    ]])
 | 
						|
    feed('\n')
 | 
						|
    screen:expect([[
 | 
						|
      ^                    |
 | 
						|
      {1:~                   }|*3
 | 
						|
      >                   |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it('cursor is restored after :imap <expr> which calls input()', function()
 | 
						|
    command('imap <expr> x input("> ")')
 | 
						|
    feed('i')
 | 
						|
    screen:expect([[
 | 
						|
      ^                    |
 | 
						|
      {1:~                   }|*3
 | 
						|
      {5:-- INSERT --}        |
 | 
						|
    ]])
 | 
						|
    feed('x')
 | 
						|
    screen:expect([[
 | 
						|
                          |
 | 
						|
      {1:~                   }|*3
 | 
						|
      > ^                  |
 | 
						|
    ]])
 | 
						|
    feed('\n')
 | 
						|
    screen:expect([[
 | 
						|
      ^                    |
 | 
						|
      {1:~                   }|*3
 | 
						|
      {5:-- INSERT --}        |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it('cursor position does not move after empty-string :cmap <expr> #19046', function()
 | 
						|
    command([[cnoremap <expr> <F2> '']])
 | 
						|
    feed(':<F2>')
 | 
						|
    screen:expect([[
 | 
						|
                          |
 | 
						|
      {1:~                   }|*3
 | 
						|
      :^                   |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  -- oldtest: Test_expr_map_restore_cursor()
 | 
						|
  it('cursor is restored after :map <expr> which redraws statusline vim-patch:8.1.2336', function()
 | 
						|
    exec([[
 | 
						|
      call setline(1, ['one', 'two', 'three'])
 | 
						|
      2
 | 
						|
      set ls=2
 | 
						|
      hi! link StatusLine ErrorMsg
 | 
						|
      noremap <expr> <C-B> Func()
 | 
						|
      func Func()
 | 
						|
          let g:on = !get(g:, 'on', 0)
 | 
						|
          redraws
 | 
						|
          return ''
 | 
						|
      endfunc
 | 
						|
      func Status()
 | 
						|
          return get(g:, 'on', 0) ? '[on]' : ''
 | 
						|
      endfunc
 | 
						|
      set stl=%{Status()}
 | 
						|
    ]])
 | 
						|
    feed('<C-B>')
 | 
						|
    screen:expect([[
 | 
						|
      one                 |
 | 
						|
      ^two                 |
 | 
						|
      three               |
 | 
						|
      {9:[on]                }|
 | 
						|
                          |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it('error in :nmap <expr> does not mess up display vim-patch:4.2.4338', function()
 | 
						|
    screen:try_resize(40, 5)
 | 
						|
    command('nmap <expr> <F2> execute("throw 42")')
 | 
						|
    feed('<F2>')
 | 
						|
    screen:expect([[
 | 
						|
                                              |
 | 
						|
      {3:                                        }|
 | 
						|
      {9:Error detected while processing :}       |
 | 
						|
      {9:E605: Exception not caught: 42}          |
 | 
						|
      {6:Press ENTER or type command to continue}^ |
 | 
						|
    ]])
 | 
						|
    feed('<CR>')
 | 
						|
    screen:expect([[
 | 
						|
      ^                                        |
 | 
						|
      {1:~                                       }|*3
 | 
						|
                                              |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  it('error in :cmap <expr> handled correctly vim-patch:4.2.4338', function()
 | 
						|
    screen:try_resize(40, 5)
 | 
						|
    command('cmap <expr> <F2> execute("throw 42")')
 | 
						|
    feed(':echo "foo')
 | 
						|
    screen:expect([[
 | 
						|
                                              |
 | 
						|
      {1:~                                       }|*3
 | 
						|
      :echo "foo^                              |
 | 
						|
    ]])
 | 
						|
    feed('<F2>')
 | 
						|
    screen:expect([[
 | 
						|
      {3:                                        }|
 | 
						|
      :echo "foo                              |
 | 
						|
      {9:Error detected while processing :}       |
 | 
						|
      {9:E605: Exception not caught: 42}          |
 | 
						|
      :echo "foo^                              |
 | 
						|
    ]])
 | 
						|
    feed('"')
 | 
						|
    screen:expect([[
 | 
						|
      {3:                                        }|
 | 
						|
      :echo "foo                              |
 | 
						|
      {9:Error detected while processing :}       |
 | 
						|
      {9:E605: Exception not caught: 42}          |
 | 
						|
      :echo "foo"^                             |
 | 
						|
    ]])
 | 
						|
    feed('\n')
 | 
						|
    screen:expect([[
 | 
						|
      :echo "foo                              |
 | 
						|
      {9:Error detected while processing :}       |
 | 
						|
      {9:E605: Exception not caught: 42}          |
 | 
						|
      foo                                     |
 | 
						|
      {6:Press ENTER or type command to continue}^ |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
 | 
						|
  -- oldtest: Test_map_listing()
 | 
						|
  it('listing mappings clears command line vim-patch:8.2.4401', function()
 | 
						|
    screen:try_resize(40, 5)
 | 
						|
    command('nmap a b')
 | 
						|
    feed(':                      nmap a<CR>')
 | 
						|
    screen:expect([[
 | 
						|
      ^                                        |
 | 
						|
      {1:~                                       }|*3
 | 
						|
      n  a             b                      |
 | 
						|
    ]])
 | 
						|
  end)
 | 
						|
end)
 |