refactor(test): testutils
This commit is contained in:
parent
bc48bd71f2
commit
1d45a443ff
6 changed files with 72 additions and 30 deletions
|
|
@ -5,10 +5,34 @@ local T = MiniTest.new_set {
|
||||||
hooks = {
|
hooks = {
|
||||||
post_once = child.stop,
|
post_once = child.stop,
|
||||||
pre_case = function()
|
pre_case = function()
|
||||||
child.restart { "-u", "scripts/minimal_init.lua" }
|
child.restart { "-u", t.mininit_path }
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
T["comment"] = MiniTest.new_set {}
|
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
|
return T
|
||||||
|
|
|
||||||
|
|
@ -5,10 +5,21 @@ local T = MiniTest.new_set {
|
||||||
hooks = {
|
hooks = {
|
||||||
post_once = child.stop,
|
post_once = child.stop,
|
||||||
pre_case = function()
|
pre_case = function()
|
||||||
child.restart { "-u", "scripts/minimal_init.lua" }
|
child.restart { "-u", t.mininit_path }
|
||||||
end,
|
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
|
return T
|
||||||
|
|
|
||||||
|
|
@ -5,15 +5,15 @@ local T = MiniTest.new_set {
|
||||||
hooks = {
|
hooks = {
|
||||||
post_once = child.stop,
|
post_once = child.stop,
|
||||||
pre_case = function()
|
pre_case = function()
|
||||||
child.restart { "-u", "scripts/minimal_init.lua" }
|
child.restart { "-u", t.mininit_path }
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
T["iferr"] = MiniTest.new_set {}
|
T["iferr"] = MiniTest.new_set {}
|
||||||
T["iferr"]["works"] = function()
|
T["iferr"]["works"] = function()
|
||||||
local tmp = t.tmpfile()
|
local tmp = t.tmpfile()
|
||||||
local fixtures = t.fixtures.read "iferr/iferr"
|
local fixtures = t.get_fixtures "iferr/iferr"
|
||||||
t.fixtures.write(tmp, fixtures.input)
|
t.writefile(tmp, fixtures.input)
|
||||||
|
|
||||||
child.cmd("silent edit " .. tmp)
|
child.cmd("silent edit " .. tmp)
|
||||||
child.fn.setpos(".", { child.fn.bufnr "%", 8, 2, 0 })
|
child.fn.setpos(".", { child.fn.bufnr "%", 8, 2, 0 })
|
||||||
|
|
|
||||||
|
|
@ -5,30 +5,30 @@ local T = MiniTest.new_set {
|
||||||
hooks = {
|
hooks = {
|
||||||
post_once = child.stop,
|
post_once = child.stop,
|
||||||
pre_case = function()
|
pre_case = function()
|
||||||
child.restart { "-u", "scripts/minimal_init.lua" }
|
child.restart { "-u", t.mininit_path }
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
T["impl"] = MiniTest.new_set {}
|
T["impl"] = MiniTest.new_set {}
|
||||||
T["impl"]["works w io.Writer"] = function()
|
T["impl"]["works w io.Writer"] = function()
|
||||||
local tmp = t.tmpfile()
|
local tmp = t.tmpfile()
|
||||||
local fixtures = t.fixtures.read "impl/writer"
|
local fixtures = t.get_fixtures "impl/writer"
|
||||||
t.fixtures.write(tmp, fixtures.input)
|
t.writefile(tmp, fixtures.input)
|
||||||
|
|
||||||
child.cmd("silent edit " .. tmp)
|
child.cmd("silent edit " .. tmp)
|
||||||
child.fn.setpos(".", { child.fn.bufnr(tmp), 3, 6 })
|
child.fn.setpos(".", { child.fn.bufnr(tmp), 3, 6 })
|
||||||
child.cmd "GoImpl w io.Writer"
|
child.cmd "GoImpl w io.Writer"
|
||||||
child.cmd "write"
|
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")
|
local rhs = fixtures.output:gsub("Test2", "Test")
|
||||||
t.eq(t.readfile(tmp), rhs)
|
t.eq(t.readfile(tmp), rhs)
|
||||||
end
|
end
|
||||||
|
|
||||||
T["impl"]["works r Read io.Reader"] = function()
|
T["impl"]["works r Read io.Reader"] = function()
|
||||||
local tmp = t.tmpfile()
|
local tmp = t.tmpfile()
|
||||||
local fixtures = t.fixtures.read "impl/reader"
|
local fixtures = t.get_fixtures "impl/reader"
|
||||||
t.fixtures.write(tmp, fixtures.input)
|
t.writefile(tmp, fixtures.input)
|
||||||
|
|
||||||
child.cmd("silent edit " .. tmp)
|
child.cmd("silent edit " .. tmp)
|
||||||
child.cmd "GoImpl r Read io.Reader"
|
child.cmd "GoImpl r Read io.Reader"
|
||||||
|
|
@ -40,8 +40,8 @@ end
|
||||||
|
|
||||||
T["impl"]["works io.Closer"] = function()
|
T["impl"]["works io.Closer"] = function()
|
||||||
local tmp = t.tmpfile()
|
local tmp = t.tmpfile()
|
||||||
local fixtures = t.fixtures.read "impl/closer"
|
local fixtures = t.get_fixtures "impl/closer"
|
||||||
t.fixtures.write(tmp, fixtures.input)
|
t.writefile(tmp, fixtures.input)
|
||||||
|
|
||||||
child.cmd("silent edit " .. tmp)
|
child.cmd("silent edit " .. tmp)
|
||||||
child.fn.setpos(".", { child.fn.bufnr(tmp), 3, 6 })
|
child.fn.setpos(".", { child.fn.bufnr(tmp), 3, 6 })
|
||||||
|
|
|
||||||
|
|
@ -5,15 +5,15 @@ local T = MiniTest.new_set {
|
||||||
hooks = {
|
hooks = {
|
||||||
post_once = child.stop,
|
post_once = child.stop,
|
||||||
pre_case = function()
|
pre_case = function()
|
||||||
child.restart { "-u", "scripts/minimal_init.lua" }
|
child.restart { "-u", t.mininit_path }
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
T["struct_tags"] = MiniTest.new_set {}
|
T["struct_tags"] = MiniTest.new_set {}
|
||||||
T["struct_tags"]["works add"] = function()
|
T["struct_tags"]["works add"] = function()
|
||||||
local tmp = t.tmpfile()
|
local tmp = t.tmpfile()
|
||||||
local fixtures = t.fixtures.read "tags/add"
|
local fixtures = t.get_fixtures "tags/add"
|
||||||
t.fixtures.write(tmp, fixtures.input)
|
t.writefile(tmp, fixtures.input)
|
||||||
|
|
||||||
child.cmd("silent edit " .. tmp)
|
child.cmd("silent edit " .. tmp)
|
||||||
child.fn.setpos(".", { child.fn.bufnr "%", 3, 6, 0 })
|
child.fn.setpos(".", { child.fn.bufnr "%", 3, 6, 0 })
|
||||||
|
|
@ -24,8 +24,8 @@ end
|
||||||
|
|
||||||
T["struct_tags"]["works remove"] = function()
|
T["struct_tags"]["works remove"] = function()
|
||||||
local tmp = t.tmpfile()
|
local tmp = t.tmpfile()
|
||||||
local fixtures = t.fixtures.read "tags/remove"
|
local fixtures = t.get_fixtures "tags/remove"
|
||||||
t.fixtures.write(tmp, fixtures.input)
|
t.writefile(tmp, fixtures.input)
|
||||||
|
|
||||||
child.cmd("silent edit " .. tmp)
|
child.cmd("silent edit " .. tmp)
|
||||||
child.fn.setpos(".", { child.fn.bufnr "%", 4, 6, 0 })
|
child.fn.setpos(".", { child.fn.bufnr "%", 4, 6, 0 })
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,12 @@
|
||||||
-- NOTE: there's a probably a better way to do this
|
-- 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
|
---@class gopher.TestUtils
|
||||||
local testutils = {}
|
local testutils = {}
|
||||||
|
|
||||||
|
testutils.mininit_path = vim.fs.joinpath(base_dir, "/scripts/minimal_init.lua")
|
||||||
|
|
||||||
---@generic T
|
---@generic T
|
||||||
---@param a T
|
---@param a T
|
||||||
---@param b T
|
---@param b T
|
||||||
|
|
@ -23,21 +26,25 @@ function testutils.readfile(path)
|
||||||
return vim.fn.join(vim.fn.readfile(path), "\n")
|
return vim.fn.join(vim.fn.readfile(path), "\n")
|
||||||
end
|
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
|
---@param fixture string
|
||||||
---@return {input: string, output: string}
|
---@return {input: string, output: string}
|
||||||
function testutils.fixtures.read(fixture)
|
function testutils.get_fixtures(fixture)
|
||||||
return {
|
return {
|
||||||
input = testutils.readfile(fixtures_dir .. fixture .. "_input.go"),
|
input = testutils.readfile_from_fixture_dir(fixture .. "_input.go"),
|
||||||
output = testutils.readfile(fixtures_dir .. fixture .. "_output.go"),
|
output = testutils.readfile_from_fixture_dir(fixture .. "_output.go"),
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
---@param fpath string
|
|
||||||
---@param fixture string
|
|
||||||
function testutils.fixtures.write(fpath, fixture)
|
|
||||||
vim.fn.writefile(vim.split(fixture, "\n"), fpath)
|
|
||||||
end
|
|
||||||
|
|
||||||
return testutils
|
return testutils
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue