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.
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| local helpers = require('test.functional.helpers')(after_each)
 | |
| local Screen = require('test.functional.ui.screen')
 | |
| local clear, feed, feed_command = helpers.clear, helpers.feed, helpers.feed_command
 | |
| 
 | |
| describe(":drop", function()
 | |
|   local screen
 | |
| 
 | |
|   before_each(function()
 | |
|     clear()
 | |
|     screen = Screen.new(35, 10)
 | |
|     screen:attach()
 | |
|     screen:set_default_attr_ids({
 | |
|       [0] = {bold=true, foreground=Screen.colors.Blue},
 | |
|       [1] = {bold = true, reverse = true},
 | |
|       [2] = {reverse = true},
 | |
|       [3] = {bold = true},
 | |
|     })
 | |
|     feed_command("set laststatus=2")
 | |
|   end)
 | |
| 
 | |
|   after_each(function()
 | |
|     screen:detach()
 | |
|   end)
 | |
| 
 | |
|   it("works like :e when called with only one window open", function()
 | |
|     feed_command("drop tmp1.vim")
 | |
|     screen:expect([[
 | |
|       ^                                   |
 | |
|       {0:~                                  }|
 | |
|       {0:~                                  }|
 | |
|       {0:~                                  }|
 | |
|       {0:~                                  }|
 | |
|       {0:~                                  }|
 | |
|       {0:~                                  }|
 | |
|       {0:~                                  }|
 | |
|       {1:tmp1.vim                           }|
 | |
|       "tmp1.vim" [New File]              |
 | |
|     ]])
 | |
|   end)
 | |
| 
 | |
|   it("switches to an open window showing the buffer", function()
 | |
|     feed_command("edit tmp1")
 | |
|     feed_command("vsplit")
 | |
|     feed_command("edit tmp2")
 | |
|     feed_command("drop tmp1")
 | |
|     screen:expect([[
 | |
|                     {2:|}^                    |
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {0:~             }{2:|}{0:~                   }|
 | |
|       {2:tmp2           }{1:tmp1                }|
 | |
|       :drop tmp1                         |
 | |
|     ]])
 | |
|   end)
 | |
| 
 | |
|   it("splits off a new window when a buffer can't be abandoned", function()
 | |
|     feed_command("edit tmp1")
 | |
|     feed_command("vsplit")
 | |
|     feed_command("edit tmp2")
 | |
|     feed("iABC<esc>")
 | |
|     feed_command("drop tmp3")
 | |
|     screen:expect([[
 | |
|       ^                    {2:|}              |
 | |
|       {0:~                   }{2:|}{0:~             }|
 | |
|       {0:~                   }{2:|}{0:~             }|
 | |
|       {0:~                   }{2:|}{0:~             }|
 | |
|       {1:tmp3                }{2:|}{0:~             }|
 | |
|       ABC                 {2:|}{0:~             }|
 | |
|       {0:~                   }{2:|}{0:~             }|
 | |
|       {0:~                   }{2:|}{0:~             }|
 | |
|       {2:tmp2 [+]             tmp1          }|
 | |
|       "tmp3" [New File]                  |
 | |
|     ]])
 | |
|   end)
 | |
| 
 | |
| end)
 |