mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 12:27:24 +00:00 
			
		
		
		
	 65fb622000
			
		
	
	65fb622000
	
	
	
		
			
			Hope this will make people using feed_command less likely: this hides bugs. Already found at least two: 1. msgpackparse() will show internal error: hash_add() in case of duplicate keys, though it will still work correctly. Currently silenced. 2. ttimeoutlen was spelled incorrectly, resulting in option not being set when expected. Test was still functioning somehow though. Currently fixed.
		
			
				
	
	
		
			39 lines
		
	
	
		
			933 B
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			933 B
		
	
	
	
		
			Lua
		
	
	
	
	
	
| local helpers = require('test.functional.helpers')(after_each)
 | |
| 
 | |
| local eq = helpers.eq
 | |
| local clear = helpers.clear
 | |
| local insert = helpers.insert
 | |
| local feed = helpers.feed
 | |
| local expect = helpers.expect
 | |
| local feed_command = helpers.feed_command
 | |
| local exc_exec = helpers.exc_exec
 | |
| 
 | |
| describe(':undojoin command', function()
 | |
|   before_each(function()
 | |
|     clear()
 | |
|     insert([[
 | |
|     Line of text 1
 | |
|     Line of text 2]])
 | |
|     feed_command('goto 1')
 | |
|   end)
 | |
|   it('joins changes in a buffer', function()
 | |
|     feed_command('undojoin | delete')
 | |
|     expect([[
 | |
|     Line of text 2]])
 | |
|     feed('u')
 | |
|     expect([[
 | |
|     ]])
 | |
|   end)
 | |
|   it('does not corrupt undolist when connected with redo', function()
 | |
|     feed('ixx<esc>')
 | |
|     feed_command('undojoin | redo')
 | |
|     expect([[
 | |
|     xxLine of text 1
 | |
|     Line of text 2]])
 | |
|   end)
 | |
|   it('does not raise an error when called twice', function()
 | |
|     local ret = exc_exec('undojoin | undojoin')
 | |
|     eq(0, ret)
 | |
|   end)
 | |
| end)
 |