aboutsummaryrefslogtreecommitdiff
path: root/test/functional/api/window_spec.lua
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2019-03-03 17:30:58 +0100
committerGitHub <noreply@github.com>2019-03-03 17:30:58 +0100
commitbcbb96e31b88eff7a1629c7c8a5f1d4eacb32829 (patch)
treec25dbfefa127a5f8fc30a4900856a788173819e5 /test/functional/api/window_spec.lua
parent8e54847fdf3c4e3c9ed1b4ae8a026b452419c6bf (diff)
parentc8f310825cf92da2feb25a7298998fcd1da5a769 (diff)
downloadrneovim-bcbb96e31b88eff7a1629c7c8a5f1d4eacb32829.tar.gz
rneovim-bcbb96e31b88eff7a1629c7c8a5f1d4eacb32829.tar.bz2
rneovim-bcbb96e31b88eff7a1629c7c8a5f1d4eacb32829.zip
Merge pull request #9667 from bfredl/winclose
api: add nvim_win_close() to close window by id
Diffstat (limited to 'test/functional/api/window_spec.lua')
-rw-r--r--test/functional/api/window_spec.lua37
1 files changed, 37 insertions, 0 deletions
diff --git a/test/functional/api/window_spec.lua b/test/functional/api/window_spec.lua
index 4496e1f644..4ff299cd18 100644
--- a/test/functional/api/window_spec.lua
+++ b/test/functional/api/window_spec.lua
@@ -286,4 +286,41 @@ describe('API/win', function()
ok(not window('is_valid', win))
end)
end)
+
+ describe('close', function()
+ it('can close current window', function()
+ local oldwin = meths.get_current_win()
+ command('split')
+ local newwin = meths.get_current_win()
+ meths.win_close(newwin,false)
+ eq({oldwin}, meths.list_wins())
+ end)
+
+ it('can close noncurrent window', function()
+ local oldwin = meths.get_current_win()
+ command('split')
+ local newwin = meths.get_current_win()
+ meths.win_close(oldwin,false)
+ eq({newwin}, meths.list_wins())
+ end)
+
+ it('handles changed buffer', function()
+ local oldwin = meths.get_current_win()
+ insert('text')
+ command('new')
+ local newwin = meths.get_current_win()
+ eq({false,"Vim:E37: No write since last change (add ! to override)"},
+ meth_pcall(meths.win_close, oldwin,false))
+ eq({newwin,oldwin}, meths.list_wins())
+ end)
+
+ it('handles changed buffer with force', function()
+ local oldwin = meths.get_current_win()
+ insert('text')
+ command('new')
+ local newwin = meths.get_current_win()
+ meths.win_close(oldwin,true)
+ eq({newwin}, meths.list_wins())
+ end)
+ end)
end)