aboutsummaryrefslogtreecommitdiff
path: root/test/functional
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional')
-rw-r--r--test/functional/ui/screen_basic_spec.lua38
-rw-r--r--test/functional/ui/tabline_spec.lua10
-rw-r--r--test/functional/viml/completion_spec.lua4
3 files changed, 39 insertions, 13 deletions
diff --git a/test/functional/ui/screen_basic_spec.lua b/test/functional/ui/screen_basic_spec.lua
index d9cb3d7b6f..d6aa1aa993 100644
--- a/test/functional/ui/screen_basic_spec.lua
+++ b/test/functional/ui/screen_basic_spec.lua
@@ -6,7 +6,7 @@ local insert = helpers.insert
local eq = helpers.eq
local eval = helpers.eval
-describe('Initial screen', function()
+describe('screen', function()
local screen
local nvim_argv = {helpers.nvim_prog, '-u', 'NONE', '-i', 'NONE', '-N',
'--cmd', 'set shortmess+=I background=light noswapfile belloff= noshowcmd noruler',
@@ -27,7 +27,7 @@ describe('Initial screen', function()
screen:detach()
end)
- it('is the default initial screen', function()
+ it('default initial screen', function()
screen:expect([[
^ |
{0:~ }|
@@ -565,12 +565,40 @@ describe('Screen', function()
]])
end)
end)
+end)
- it('nvim_ui_attach() handles very large width/height #2180', function()
- screen:detach()
- screen = Screen.new(999, 999)
+describe('nvim_ui_attach()', function()
+ before_each(function()
+ clear()
+ end)
+ it('handles very large width/height #2180', function()
+ local screen = Screen.new(999, 999)
screen:attach()
eq(999, eval('&lines'))
eq(999, eval('&columns'))
end)
+ it('"ui_ext" widgets', function()
+ local screen = Screen.new()
+ screen:attach({ui_ext={
+ 'cmdline',
+ 'popupmenu',
+ 'tabline',
+ 'wildmenu',
+ }})
+ end)
+ it('invalid "ui_ext" returns error', function()
+ local screen = Screen.new()
+
+ local status, rv = pcall(function() screen:attach({ui_ext={'foo'}}) end)
+ eq(false, status)
+ eq('ui_ext: unknown widget: foo', rv:match("ui_ext:.*"))
+
+ status, rv = pcall(function() screen:attach({ui_ext={'cmdline','foo'}}) end)
+ eq(false, status)
+ eq('ui_ext: unknown widget: foo', rv:match("ui_ext:.*"))
+
+ status, rv = pcall(function() screen:attach({ui_ext={'cmdline',1}}) end)
+ eq(false, status)
+ eq('ui_ext: item must be a String', rv:match("ui_ext:.*"))
+ end)
end)
diff --git a/test/functional/ui/tabline_spec.lua b/test/functional/ui/tabline_spec.lua
index 018e008e4a..c62dd0c94b 100644
--- a/test/functional/ui/tabline_spec.lua
+++ b/test/functional/ui/tabline_spec.lua
@@ -2,16 +2,14 @@ local helpers = require('test.functional.helpers')(after_each)
local Screen = require('test.functional.ui.screen')
local clear, feed, eq = helpers.clear, helpers.feed, helpers.eq
-if helpers.pending_win32(pending) then return end
-
-describe('External tab line', function()
+describe('ui/tabline', function()
local screen
local tabs, curtab
before_each(function()
clear()
screen = Screen.new(25, 5)
- screen:attach({rgb=true, tabline_external=true})
+ screen:attach({rgb=true, ui_ext={'tabline'}})
screen:set_on_event_handler(function(name, data)
if name == "tabline_update" then
curtab, tabs = unpack(data)
@@ -23,8 +21,8 @@ describe('External tab line', function()
screen:detach()
end)
- describe("'tabline'", function()
- it('tabline', function()
+ describe('externalized', function()
+ it('publishes UI events', function()
local expected = {
{1, {['name'] = '[No Name]'}},
{2, {['name'] = '[No Name]'}},
diff --git a/test/functional/viml/completion_spec.lua b/test/functional/viml/completion_spec.lua
index b35e8d4f94..5f5e9437dc 100644
--- a/test/functional/viml/completion_spec.lua
+++ b/test/functional/viml/completion_spec.lua
@@ -868,13 +868,13 @@ describe('completion', function()
end)
end)
-describe('External completion popupmenu', function()
+describe('ui/externalized/popupmenu', function()
local screen
local items, selected, anchor
before_each(function()
clear()
screen = Screen.new(60, 8)
- screen:attach({rgb=true, popupmenu_external=true})
+ screen:attach({rgb=true, ui_ext={'popupmenu'}})
screen:set_default_attr_ids({
[1] = {bold=true, foreground=Screen.colors.Blue},
[2] = {bold = true},