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 })

View file

@ -1,9 +1,12 @@
-- NOTE: there's a probably a better way to do this
local fixtures_dir = (vim.fn.expand "%:p:h") .. "/spec/fixtures/"
local base_dir = vim.fn.expand "%:p:h"
local fixtures_dir = vim.fs.joinpath(base_dir, "/spec/fixtures/")
---@class gopher.TestUtils
local testutils = {}
testutils.mininit_path = vim.fs.joinpath(base_dir, "/scripts/minimal_init.lua")
---@generic T
---@param a T
---@param b T
@ -23,21 +26,25 @@ function testutils.readfile(path)
return vim.fn.join(vim.fn.readfile(path), "\n")
end
testutils.fixtures = {}
---@param fpath string
---@param contents string
function testutils.writefile(fpath, contents)
vim.fn.writefile(vim.split(contents, "\n"), fpath)
end
---@param path string
---@return string
function testutils.readfile_from_fixture_dir(path)
return testutils.readfile(fixtures_dir .. path)
end
---@param fixture string
---@return {input: string, output: string}
function testutils.fixtures.read(fixture)
function testutils.get_fixtures(fixture)
return {
input = testutils.readfile(fixtures_dir .. fixture .. "_input.go"),
output = testutils.readfile(fixtures_dir .. fixture .. "_output.go"),
input = testutils.readfile_from_fixture_dir(fixture .. "_input.go"),
output = testutils.readfile_from_fixture_dir(fixture .. "_output.go"),
}
end
---@param fpath string
---@param fixture string
function testutils.fixtures.write(fpath, fixture)
vim.fn.writefile(vim.split(fixture, "\n"), fpath)
end
return testutils