refactor(test): testutils

This commit is contained in:
Oleksandr Smirnov 2025-02-18 16:45:43 +02:00
parent bc48bd71f2
commit 1d45a443ff
No known key found for this signature in database
6 changed files with 72 additions and 30 deletions

View file

@ -5,10 +5,34 @@ local T = MiniTest.new_set {
hooks = {
post_once = child.stop,
pre_case = function()
child.restart { "-u", "scripts/minimal_init.lua" }
child.restart { "-u", t.mininit_path }
end,
},
}
T["comment"] = MiniTest.new_set {}
T["comment"]["should add comment to package"] = function()
MiniTest.skip "come back daddy"
end
T["comment"]["should add comment to struct"] = function()
MiniTest.skip "come back daddy"
end
T["comment"]["should add comment to function"] = function()
MiniTest.skip "come back daddy"
end
T["comment"]["should add comment to method"] = function()
MiniTest.skip "come back daddy"
end
T["comment"]["should add comment to interface"] = function()
MiniTest.skip "come back daddy"
end
T["comment"]["otherwise should add // above cursor"] = function()
MiniTest.skip "come back daddy"
end
return T

View file

@ -5,10 +5,21 @@ local T = MiniTest.new_set {
hooks = {
post_once = child.stop,
pre_case = function()
child.restart { "-u", "scripts/minimal_init.lua" }
child.restart { "-u", t.mininit_path }
end,
},
}
T["gotest"] = MiniTest.new_set {}
T["gotests"] = MiniTest.new_set {}
--- NOTE: :GoTestAdd is the only place that has actual logic
--- All other parts are handled `gotests` tool itself.
T["gotests"]["should add test for function under cursor"] = function()
MiniTest.skip "come back daddy"
end
T["gotests"]["should add test for method under cursor"] = function()
MiniTest.skip "come back daddy"
end
return T

View file

@ -5,15 +5,15 @@ local T = MiniTest.new_set {
hooks = {
post_once = child.stop,
pre_case = function()
child.restart { "-u", "scripts/minimal_init.lua" }
child.restart { "-u", t.mininit_path }
end,
},
}
T["iferr"] = MiniTest.new_set {}
T["iferr"]["works"] = function()
local tmp = t.tmpfile()
local fixtures = t.fixtures.read "iferr/iferr"
t.fixtures.write(tmp, fixtures.input)
local fixtures = t.get_fixtures "iferr/iferr"
t.writefile(tmp, fixtures.input)
child.cmd("silent edit " .. tmp)
child.fn.setpos(".", { child.fn.bufnr "%", 8, 2, 0 })

View file

@ -5,30 +5,30 @@ local T = MiniTest.new_set {
hooks = {
post_once = child.stop,
pre_case = function()
child.restart { "-u", "scripts/minimal_init.lua" }
child.restart { "-u", t.mininit_path }
end,
},
}
T["impl"] = MiniTest.new_set {}
T["impl"]["works w io.Writer"] = function()
local tmp = t.tmpfile()
local fixtures = t.fixtures.read "impl/writer"
t.fixtures.write(tmp, fixtures.input)
local fixtures = t.get_fixtures "impl/writer"
t.writefile(tmp, fixtures.input)
child.cmd("silent edit " .. tmp)
child.fn.setpos(".", { child.fn.bufnr(tmp), 3, 6 })
child.cmd "GoImpl w io.Writer"
child.cmd "write"
-- since "impl" won't implement interface if it's already implemented i went with this hack
-- NOTE: since "impl" won't implement interface if it's already implemented i went with this hack
local rhs = fixtures.output:gsub("Test2", "Test")
t.eq(t.readfile(tmp), rhs)
end
T["impl"]["works r Read io.Reader"] = function()
local tmp = t.tmpfile()
local fixtures = t.fixtures.read "impl/reader"
t.fixtures.write(tmp, fixtures.input)
local fixtures = t.get_fixtures "impl/reader"
t.writefile(tmp, fixtures.input)
child.cmd("silent edit " .. tmp)
child.cmd "GoImpl r Read io.Reader"
@ -40,8 +40,8 @@ end
T["impl"]["works io.Closer"] = function()
local tmp = t.tmpfile()
local fixtures = t.fixtures.read "impl/closer"
t.fixtures.write(tmp, fixtures.input)
local fixtures = t.get_fixtures "impl/closer"
t.writefile(tmp, fixtures.input)
child.cmd("silent edit " .. tmp)
child.fn.setpos(".", { child.fn.bufnr(tmp), 3, 6 })

View file

@ -5,15 +5,15 @@ local T = MiniTest.new_set {
hooks = {
post_once = child.stop,
pre_case = function()
child.restart { "-u", "scripts/minimal_init.lua" }
child.restart { "-u", t.mininit_path }
end,
},
}
T["struct_tags"] = MiniTest.new_set {}
T["struct_tags"]["works add"] = function()
local tmp = t.tmpfile()
local fixtures = t.fixtures.read "tags/add"
t.fixtures.write(tmp, fixtures.input)
local fixtures = t.get_fixtures "tags/add"
t.writefile(tmp, fixtures.input)
child.cmd("silent edit " .. tmp)
child.fn.setpos(".", { child.fn.bufnr "%", 3, 6, 0 })
@ -24,8 +24,8 @@ end
T["struct_tags"]["works remove"] = function()
local tmp = t.tmpfile()
local fixtures = t.fixtures.read "tags/remove"
t.fixtures.write(tmp, fixtures.input)
local fixtures = t.get_fixtures "tags/remove"
t.writefile(tmp, fixtures.input)
child.cmd("silent edit " .. tmp)
child.fn.setpos(".", { child.fn.bufnr "%", 4, 6, 0 })