123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354 |
- local helpers = require('test.functional.helpers')(after_each)
- local clear, nvim = helpers.clear, helpers.nvim
- local Screen = require('test.functional.ui.screen')
- local eq, eval = helpers.eq, helpers.eval
- local command = helpers.command
- local exec_capture = helpers.exec_capture
- local meths = helpers.meths
- local funcs = helpers.funcs
- local pcall_err = helpers.pcall_err
- local ok = helpers.ok
- local assert_alive = helpers.assert_alive
- describe('API: highlight',function()
- local expected_rgb = {
- background = Screen.colors.Yellow,
- foreground = Screen.colors.Red,
- special = Screen.colors.Blue,
- bold = true,
- }
- local expected_cterm = {
- background = 10,
- underline = true,
- }
- local expected_rgb2 = {
- background = Screen.colors.Yellow,
- foreground = Screen.colors.Red,
- special = Screen.colors.Blue,
- bold = true,
- italic = true,
- reverse = true,
- underline = true,
- underlineline = true,
- undercurl = true,
- underdot = true,
- underdash = true,
- strikethrough = true,
- }
- before_each(function()
- clear()
- command("hi NewHighlight cterm=underline ctermbg=green guifg=red guibg=yellow guisp=blue gui=bold")
- end)
- it("nvim_get_hl_by_id", function()
- local hl_id = eval("hlID('NewHighlight')")
- eq(expected_cterm, nvim("get_hl_by_id", hl_id, false))
- hl_id = eval("hlID('NewHighlight')")
- -- Test valid id.
- eq(expected_rgb, nvim("get_hl_by_id", hl_id, true))
- -- Test invalid id.
- local err, emsg = pcall(meths.get_hl_by_id, 30000, false)
- eq(false, err)
- eq('Invalid highlight id: 30000', string.match(emsg, 'Invalid.*'))
- -- Test all highlight properties.
- command('hi NewHighlight gui=underline,bold,underlineline,undercurl,underdot,underdash,italic,reverse,strikethrough')
- eq(expected_rgb2, nvim("get_hl_by_id", hl_id, true))
- -- Test nil argument.
- err, emsg = pcall(meths.get_hl_by_id, { nil }, false)
- eq(false, err)
- eq('Wrong type for argument 1 when calling nvim_get_hl_by_id, expecting Integer',
- string.match(emsg, 'Wrong.*'))
- -- Test 0 argument.
- err, emsg = pcall(meths.get_hl_by_id, 0, false)
- eq(false, err)
- eq('Invalid highlight id: 0',
- string.match(emsg, 'Invalid.*'))
- -- Test -1 argument.
- err, emsg = pcall(meths.get_hl_by_id, -1, false)
- eq(false, err)
- eq('Invalid highlight id: -1',
- string.match(emsg, 'Invalid.*'))
- -- Test highlight group without ctermbg value.
- command('hi Normal ctermfg=red ctermbg=yellow')
- command('hi NewConstant ctermfg=green guifg=white guibg=blue')
- hl_id = eval("hlID('NewConstant')")
- eq({foreground = 10,}, meths.get_hl_by_id(hl_id, false))
- -- Test highlight group without ctermfg value.
- command('hi clear NewConstant')
- command('hi NewConstant ctermbg=Magenta guifg=white guibg=blue')
- eq({background = 13,}, meths.get_hl_by_id(hl_id, false))
- -- Test highlight group with ctermfg and ctermbg values.
- command('hi clear NewConstant')
- command('hi NewConstant ctermfg=green ctermbg=Magenta guifg=white guibg=blue')
- eq({foreground = 10, background = 13,}, meths.get_hl_by_id(hl_id, false))
- end)
- it("nvim_get_hl_by_name", function()
- local expected_normal = { background = Screen.colors.Yellow,
- foreground = Screen.colors.Red }
- -- Test `Normal` default values.
- eq({}, nvim("get_hl_by_name", 'Normal', true))
- eq(expected_cterm, nvim("get_hl_by_name", 'NewHighlight', false))
- eq(expected_rgb, nvim("get_hl_by_name", 'NewHighlight', true))
- -- Test `Normal` modified values.
- command('hi Normal guifg=red guibg=yellow')
- eq(expected_normal, nvim("get_hl_by_name", 'Normal', true))
- -- Test invalid name.
- local err, emsg = pcall(meths.get_hl_by_name , 'unknown_highlight', false)
- eq(false, err)
- eq('Invalid highlight name: unknown_highlight',
- string.match(emsg, 'Invalid.*'))
- -- Test nil argument.
- err, emsg = pcall(meths.get_hl_by_name , { nil }, false)
- eq(false, err)
- eq('Wrong type for argument 1 when calling nvim_get_hl_by_name, expecting String',
- string.match(emsg, 'Wrong.*'))
- -- Test empty string argument.
- err, emsg = pcall(meths.get_hl_by_name , '', false)
- eq(false, err)
- eq('Invalid highlight name: ',
- string.match(emsg, 'Invalid.*'))
- -- Test "standout" attribute. #8054
- eq({ underline = true, },
- meths.get_hl_by_name('cursorline', 0));
- command('hi CursorLine cterm=standout,underline term=standout,underline gui=standout,underline')
- command('set cursorline')
- eq({ underline = true, standout = true, },
- meths.get_hl_by_name('cursorline', 0));
- -- Test cterm & Normal values. #18024 (tail) & #18980
- -- Ensure Normal, and groups that match Normal return their fg & bg cterm values
- meths.set_hl(0, 'Normal', {ctermfg = 17, ctermbg = 213})
- meths.set_hl(0, 'NotNormal', {ctermfg = 17, ctermbg = 213})
- -- Note colors are "cterm" values, not rgb-as-ints
- eq({foreground = 17, background = 213}, nvim("get_hl_by_name", 'Normal', false))
- eq({foreground = 17, background = 213}, nvim("get_hl_by_name", 'NotNormal', false))
- end)
- it('nvim_get_hl_id_by_name', function()
- -- precondition: use a hl group that does not yet exist
- eq('Invalid highlight name: Shrubbery', pcall_err(meths.get_hl_by_name, "Shrubbery", true))
- eq(0, funcs.hlID("Shrubbery"))
- local hl_id = meths.get_hl_id_by_name("Shrubbery")
- ok(hl_id > 0)
- eq(hl_id, funcs.hlID("Shrubbery"))
- command('hi Shrubbery guifg=#888888 guibg=#888888')
- eq({foreground=tonumber("0x888888"), background=tonumber("0x888888")},
- meths.get_hl_by_id(hl_id, true))
- eq({foreground=tonumber("0x888888"), background=tonumber("0x888888")},
- meths.get_hl_by_name("Shrubbery", true))
- end)
- it("nvim_buf_add_highlight to other buffer doesn't crash if undo is disabled #12873", function()
- command('vsplit file')
- local err, _ = pcall(meths.buf_set_option, 1, 'undofile', false)
- eq(true, err)
- err, _ = pcall(meths.buf_set_option, 1, 'undolevels', -1)
- eq(true, err)
- err, _ = pcall(meths.buf_add_highlight, 1, -1, 'Question', 0, 0, -1)
- eq(true, err)
- assert_alive()
- end)
- end)
- describe("API: set highlight", function()
- local highlight_color = {
- fg = tonumber('0xff0000'),
- bg = tonumber('0x0032aa'),
- ctermfg = 8,
- ctermbg = 15,
- }
- local highlight1 = {
- background = highlight_color.bg,
- foreground = highlight_color.fg,
- bold = true,
- italic = true,
- }
- local highlight2_config = {
- ctermbg = highlight_color.ctermbg,
- ctermfg = highlight_color.ctermfg,
- underline = true,
- reverse = true,
- }
- local highlight2_result = {
- background = highlight_color.ctermbg,
- foreground = highlight_color.ctermfg,
- underline = true,
- reverse = true,
- }
- local highlight3_config = {
- background = highlight_color.bg,
- foreground = highlight_color.fg,
- ctermbg = highlight_color.ctermbg,
- ctermfg = highlight_color.ctermfg,
- bold = true,
- italic = true,
- reverse = true,
- undercurl = true,
- underline = true,
- underdash = true,
- underdot = true,
- underlineline = true,
- strikethrough = true,
- cterm = {
- italic = true,
- reverse = true,
- undercurl = true,
- strikethrough = true,
- }
- }
- local highlight3_result_gui = {
- background = highlight_color.bg,
- foreground = highlight_color.fg,
- bold = true,
- italic = true,
- reverse = true,
- undercurl = true,
- underline = true,
- underdash = true,
- underdot = true,
- underlineline = true,
- strikethrough = true,
- }
- local highlight3_result_cterm = {
- background = highlight_color.ctermbg,
- foreground = highlight_color.ctermfg,
- italic = true,
- reverse = true,
- undercurl = true,
- strikethrough = true,
- }
- local function get_ns()
- local ns = meths.create_namespace('Test_set_hl')
- meths._set_hl_ns(ns)
- return ns
- end
- before_each(clear)
- it ("can set gui highlight", function()
- local ns = get_ns()
- meths.set_hl(ns, 'Test_hl', highlight1)
- eq(highlight1, meths.get_hl_by_name('Test_hl', true))
- end)
- it ("can set cterm highlight", function()
- local ns = get_ns()
- meths.set_hl(ns, 'Test_hl', highlight2_config)
- eq(highlight2_result, meths.get_hl_by_name('Test_hl', false))
- end)
- it ("can set empty cterm attr", function()
- local ns = get_ns()
- meths.set_hl(ns, 'Test_hl', { cterm = {} })
- eq({}, meths.get_hl_by_name('Test_hl', false))
- end)
- it ("cterm attr defaults to gui attr", function()
- local ns = get_ns()
- meths.set_hl(ns, 'Test_hl', highlight1)
- eq({
- bold = true,
- italic = true,
- }, meths.get_hl_by_name('Test_hl', false))
- end)
- it ("can overwrite attr for cterm", function()
- local ns = get_ns()
- meths.set_hl(ns, 'Test_hl', highlight3_config)
- eq(highlight3_result_gui, meths.get_hl_by_name('Test_hl', true))
- eq(highlight3_result_cterm, meths.get_hl_by_name('Test_hl', false))
- end)
- it ("can set a highlight in the global namespace", function()
- meths.set_hl(0, 'Test_hl', highlight2_config)
- eq('Test_hl xxx cterm=underline,reverse ctermfg=8 ctermbg=15 gui=underline,reverse',
- exec_capture('highlight Test_hl'))
- meths.set_hl(0, 'Test_hl', { background = highlight_color.bg })
- eq('Test_hl xxx guibg=#0032aa',
- exec_capture('highlight Test_hl'))
- meths.set_hl(0, 'Test_hl2', highlight3_config)
- eq('Test_hl2 xxx cterm=undercurl,italic,reverse,strikethrough ctermfg=8 ctermbg=15 gui=bold,underline,underlineline,undercurl,underdot,underdash,italic,reverse,strikethrough guifg=#ff0000 guibg=#0032aa',
- exec_capture('highlight Test_hl2'))
- -- Colors are stored exactly as they are defined.
- meths.set_hl(0, 'Test_hl3', { bg = 'reD', fg = 'bLue'})
- eq('Test_hl3 xxx guifg=bLue guibg=reD',
- exec_capture('highlight Test_hl3'))
- end)
- it ("can modify a highlight in the global namespace", function()
- meths.set_hl(0, 'Test_hl3', { bg = 'red', fg = 'blue'})
- eq('Test_hl3 xxx guifg=blue guibg=red',
- exec_capture('highlight Test_hl3'))
- meths.set_hl(0, 'Test_hl3', { bg = 'red' })
- eq('Test_hl3 xxx guibg=red',
- exec_capture('highlight Test_hl3'))
- meths.set_hl(0, 'Test_hl3', { ctermbg = 9, ctermfg = 12})
- eq('Test_hl3 xxx ctermfg=12 ctermbg=9',
- exec_capture('highlight Test_hl3'))
- meths.set_hl(0, 'Test_hl3', { ctermbg = 'red' , ctermfg = 'blue'})
- eq('Test_hl3 xxx ctermfg=12 ctermbg=9',
- exec_capture('highlight Test_hl3'))
- meths.set_hl(0, 'Test_hl3', { ctermbg = 9 })
- eq('Test_hl3 xxx ctermbg=9',
- exec_capture('highlight Test_hl3'))
- eq("'redd' is not a valid color",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {fg='redd'}))
- eq("'bleu' is not a valid color",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {ctermfg='bleu'}))
- meths.set_hl(0, 'Test_hl3', {fg='#FF00FF'})
- eq('Test_hl3 xxx guifg=#FF00FF',
- exec_capture('highlight Test_hl3'))
- eq("'#FF00FF' is not a valid color",
- pcall_err(meths.set_hl, 0, 'Test_hl3', {ctermfg='#FF00FF'}))
- for _, fg_val in ipairs{ nil, 'NONE', 'nOnE', '', -1 } do
- meths.set_hl(0, 'Test_hl3', {fg = fg_val})
- eq('Test_hl3 xxx cleared',
- exec_capture('highlight Test_hl3'))
- end
- meths.set_hl(0, 'Test_hl3', {fg='#FF00FF', blend=50})
- eq('Test_hl3 xxx guifg=#FF00FF blend=50',
- exec_capture('highlight Test_hl3'))
- end)
- it ("correctly sets 'Normal' internal properties", function()
- -- Normal has some special handling internally. #18024
- meths.set_hl(0, 'Normal', {fg='#000083', bg='#0000F3'})
- eq({foreground = 131, background = 243}, nvim("get_hl_by_name", 'Normal', true))
- end)
- end)
|