nvim-ts-autotag/tests/closetag_spec.lua

237 lines
6.4 KiB
Lua
Raw Normal View History

2021-03-14 06:16:50 -05:00
if not _G.test_close then
return
2021-03-14 06:16:50 -05:00
end
local ts = require('nvim-treesitter.configs')
2021-03-08 06:19:01 -06:00
local helpers = {}
ts.setup({
ensure_installed = _G.ts_filetypes,
highlight = { enable = true },
})
2021-03-08 06:19:01 -06:00
local eq = assert.are.same
function helpers.feed(text, feed_opts)
feed_opts = feed_opts or 'n'
local to_feed = vim.api.nvim_replace_termcodes(text, true, false, true)
vim.api.nvim_feedkeys(to_feed, feed_opts, true)
2021-03-08 06:19:01 -06:00
end
function helpers.insert(text)
helpers.feed('a' .. text, 'x')
2021-03-08 06:19:01 -06:00
end
local data = {
{
name = '1 html close tag',
filepath = './sample/index.html',
filetype = 'html',
linenr = 10,
key = [[>]],
before = [[<div| ]],
after = [[<div>|</div>]],
},
{
name = '2 html close tag',
filepath = './sample/index.html',
filetype = 'html',
linenr = 10,
key = [[>]],
before = [[<div clas="laa"| ]],
after = [[<div clas="laa">|</div>]],
},
{
name = '3 html not close tag on close tag',
filepath = './sample/index.html',
filetype = 'html',
linenr = 10,
key = [[>]],
before = [[<div>aa</div| ]],
after = [[<div>aa</div>|]],
},
{
name = '4 html not close on input tag',
filepath = './sample/index.html',
filetype = 'html',
linenr = 10,
key = [[>]],
before = [[<input| ]],
after = [[<input>| ]],
},
{
name = '5 html not close inside quote',
filepath = './sample/index.html',
filetype = 'html',
linenr = 10,
key = [[>]],
before = [[<div class="aa|"> </div> ]],
after = [[<div class="aa>|"> </div> ]],
},
{
name = '6 html not close on exist tag',
filepath = './sample/index.html',
filetype = 'html',
linenr = 10,
key = [[>]],
before = [[<div><div|</div></div>]],
after = [[<div><div>|</div></div>]],
},
{
name = '7 typescriptreact close tag',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 12,
key = [[>]],
before = [[<Img| ]],
after = [[<Img>|</Img> ]],
},
{
name = '8 typescriptreact close',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 12,
key = [[>]],
before = [[<div class="abc"| ]],
after = [[<div class="abc">|</div> ]],
},
{
name = '9 typescriptreact not close on exist tag',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 12,
key = [[>]],
before = [[<div><div|</div></div>]],
after = [[<div><div>|</div></div>]],
},
{
name = '10 typescriptreact close on inline script',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 9,
key = [[>]],
before = [[const a = () => <div| ]],
after = [[const a = () => <div>|</div> ]],
},
{
2021-03-10 20:24:35 -06:00
name = '11 typescriptreact not close on close tag',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 12,
key = [[>]],
before = [[<button className="btn " onClick={()}> </button| ]],
after = [[<button className="btn " onClick={()}> </button>| ]],
},
{
name = '12 typescriptreact not close on expresion',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 12,
key = [[>]],
before = [[<button className="btn " onClick={(|)}> </button> ]],
after = [[<button className="btn " onClick={(>|)}> </button> ]],
},
{
name = '13 typescriptreact not close on typescript',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 6,
key = [[>]],
before = [[const data:Array<string| ]],
after = [[const data:Array<string>| ]],
},
2021-03-09 17:41:24 -06:00
{
name = '14 typescriptreact not close on script',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 6,
key = [[>]],
before = [[{(card.data | 0) && <div></div>}]],
after = [[{(card.data >| 0) && <div></div>}]],
},
{
name = '15 vue auto close tag',
filepath = './sample/index.vue',
filetype = 'vue',
linenr = 4,
key = [[>]],
before = [[<Img| ]],
after = [[<Img>|</Img>]],
},
{
name = '16 vue not close on script',
filepath = './sample/index.vue',
filetype = 'vue',
linenr = 12,
key = [[>]],
before = [[const data:Array<string| ]],
after = [[const data:Array<string>| ]],
},
{
name = '17 typescriptreact nested indentifer ',
filepath = './sample/index.tsx',
filetype = 'typescriptreact',
linenr = 12,
key = [[>]],
before = [[<Opt.Input| ]],
after = [[<Opt.Input>|</Opt.Input> ]],
},
{
name = '18 php div ',
filepath = './sample/index.php',
filetype = 'php',
linenr = 25,
key = [[>]],
before = [[<div| ]],
after = [[<div>|</div> ]],
},
-- {
-- name = '19 markdown div ',
-- filepath = './sample/index.md',
-- filetype = 'markdown',
-- linenr = 4,
-- key = [[>]],
-- before = [[<div| ]],
-- after = [[<div>|</div> ]],
-- },
{
name = '19 lit template div',
filepath = './sample/index.ts',
filetype = 'typescript',
linenr = 3,
key = [[>]],
before = [[<div| ]],
after = [[<div>|</div> ]],
},
{
name = '20 eruby template div',
filepath = './sample/index.html.erb',
filetype = 'eruby',
linenr = 10,
key = [[>]],
before = [[<div| ]],
after = [[<div>|</div> ]],
},
{
name = '20 eruby template ruby string',
filepath = './sample/index.html.erb',
filetype = 'eruby',
linenr = 10,
key = [[>]],
before = [[<%= <div| %>]],
after = [[<%= <div>| %> ]],
},
2021-03-08 06:19:01 -06:00
}
local autotag = require('nvim-ts-autotag')
autotag.test = true
local run_data = _G.Test_filter(data)
2021-03-08 06:19:01 -06:00
2021-03-08 20:26:36 -06:00
describe('[close tag]', function()
_G.Test_withfile(run_data, {
mode = 'i',
cursor_add = 0,
before_each = function(value) end,
})
2021-03-08 06:19:01 -06:00
end)