aboutsummaryrefslogtreecommitdiff
path: root/test/functional/ui/statuscolumn_spec.lua
diff options
context:
space:
mode:
authorluukvbaal <31730729+luukvbaal@users.noreply.github.com>2023-03-18 12:44:44 +0100
committerGitHub <noreply@github.com>2023-03-18 11:44:44 +0000
commit204a8b17c8ebab1619cc47a920a06dcc348d75f7 (patch)
treeea7b0a6f6fce8513b3eea7826772af3f1c08845d /test/functional/ui/statuscolumn_spec.lua
parent8916669d50243f6d4cdfb9480ef1b4e7ccdcfbb6 (diff)
downloadrneovim-204a8b17c8ebab1619cc47a920a06dcc348d75f7.tar.gz
rneovim-204a8b17c8ebab1619cc47a920a06dcc348d75f7.tar.bz2
rneovim-204a8b17c8ebab1619cc47a920a06dcc348d75f7.zip
fix(column): rebuild status column when sign column is invalidated (#22690)
* fix(column): rebuild status column when sign column is invalidated Problem: When implementing a custom sign column through `'statuscolumn'`, the status column is not properly rebuilt when the sign column width changes. Solution: Force a rebuild of the status column when the sign column width is invalidated. * test(column): 'statuscolumn' has correct width when (un)placing signs
Diffstat (limited to 'test/functional/ui/statuscolumn_spec.lua')
-rw-r--r--test/functional/ui/statuscolumn_spec.lua36
1 files changed, 36 insertions, 0 deletions
diff --git a/test/functional/ui/statuscolumn_spec.lua b/test/functional/ui/statuscolumn_spec.lua
index d9385ef221..0a253455ad 100644
--- a/test/functional/ui/statuscolumn_spec.lua
+++ b/test/functional/ui/statuscolumn_spec.lua
@@ -557,4 +557,40 @@ describe('statuscolumn', function()
|
]])
end)
+
+ it("has correct width with custom sign column when (un)placing signs", function()
+ screen:try_resize(screen._width, 6)
+ exec_lua([[
+ vim.cmd.norm('gg')
+ vim.o.signcolumn = 'no'
+ vim.fn.sign_define('sign', { text = 'ss' })
+ _G.StatusCol = function()
+ local s = vim.fn.sign_getplaced(1)[1].signs
+ local sign = ''
+ if #s > 0 then
+ sign = vim.v.lnum == 5 and 'ss' or ' '
+ end
+ return vim.v.lnum .. '%=' .. sign
+ end
+ vim.o.statuscolumn = "%!v:lua.StatusCol()"
+ vim.fn.sign_place(0, '', 'sign', 1, { lnum = 5 })
+ ]])
+ screen:expect([[
+ 1 ^aaaaa |
+ 2 aaaaa |
+ 3 aaaaa |
+ 4 aaaaa |
+ 5 ssaaaaa |
+ |
+ ]])
+ command('sign unplace 1')
+ screen:expect([[
+ 1 ^aaaaa |
+ 2 aaaaa |
+ 3 aaaaa |
+ 4 aaaaa |
+ 5 aaaaa |
+ |
+ ]])
+ end)
end)