Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: testify test suite support #58

Merged
merged 28 commits into from
Jul 11, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
ffd87a3
feat(poc): support running testify suite test function
fredrikaverpil Jul 3, 2024
b104f7a
fix(treesitter): use nvim-treesitter instead of vim.treesitter
fredrikaverpil Jul 7, 2024
fe5e7f1
feat: rebuild neotest tree, remove hacks
fredrikaverpil Jul 7, 2024
fea4463
fix: set namespace type, merge namespaces
fredrikaverpil Jul 7, 2024
182ef50
fix(E565): Not allowed to change text or change window
fredrikaverpil Jul 8, 2024
9129da8
fix: receiver method detection as opt-in
fredrikaverpil Jul 8, 2024
79f651f
fix: provide output for namespace execution
fredrikaverpil Jul 8, 2024
54be433
feat: support alternative receiver/suite syntax
fredrikaverpil Jul 8, 2024
9d555b9
feat: cleanup queries
fredrikaverpil Jul 8, 2024
2d44a0a
fix: remove
fredrikaverpil Jul 8, 2024
69452b8
fix: typo
fredrikaverpil Jul 8, 2024
dc69d04
fix: documentation
fredrikaverpil Jul 8, 2024
75de935
fix: do not confuse regular test functions with suites
fredrikaverpil Jul 9, 2024
05aaca4
refactor: break into modules
fredrikaverpil Jul 9, 2024
c280c7d
docs: add types/docs
fredrikaverpil Jul 10, 2024
cb309fc
fix: warning
fredrikaverpil Jul 10, 2024
0ebab3a
refactor: break out inner functions
fredrikaverpil Jul 10, 2024
3ae360c
docs: add types, docs
fredrikaverpil Jul 10, 2024
8b9ddfe
fix: docs and improvements to treesitter querying
fredrikaverpil Jul 10, 2024
5cc1e3c
refactor: move query module into testify feature
fredrikaverpil Jul 10, 2024
fcb12d4
refactor: do not return early
fredrikaverpil Jul 10, 2024
641f40a
fix: add match for ^Test in query
fredrikaverpil Jul 10, 2024
e76cc55
fix: allow multiple suite structs per file
fredrikaverpil Jul 10, 2024
c947f7e
fix: do not detect test methods unless testify is enabled
fredrikaverpil Jul 11, 2024
92a0f4d
test: testify suites
fredrikaverpil Jul 11, 2024
d7500ca
test: testify lookup
fredrikaverpil Jul 11, 2024
f44809b
fix(option): testify -> testify_enabled
fredrikaverpil Jul 11, 2024
c108e31
docs: update readme
fredrikaverpil Jul 11, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,7 @@ return {
| `go_test_args` | `{ "-v", "-race", "-count=1" }` | Arguments to pass into `go test`. |
| `dap_go_enabled` | `false` | Leverage [leoluz/nvim-dap-go](https://github.com/leoluz/nvim-dap-go) for debugging tests. |
| `dap_go_opts` | `{}` | Options to pass into `require("dap-go").setup()`. |
| `testify` | `false` | Enable support for [stretchr/testify](https://github.com/stretchr/testify) suites. |
| `warn_test_name_dupes` | `true` | Warn about duplicate test names within the same Go package. |
| `warn_test_not_executed` | `true` | Warn if test was not executed. |

Expand Down
32 changes: 23 additions & 9 deletions lua/neotest-golang/ast.lua
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,12 @@

local lib = require("neotest.lib")

local options = require("neotest-golang.options")
local testify = require("neotest-golang.testify")

local M = {}

--- Detect test names in Go *._test.go files.
--- @param file_path string
function M.detect_tests(file_path)
local test_function = [[
M.test_function = [[
; query for test function
((function_declaration
name: (identifier) @test.name) (#match? @test.name "^(Test|Example)"))
Expand All @@ -21,13 +21,13 @@ function M.detect_tests(file_path)
@test.definition
]]

local test_method = [[
M.test_method = [[
; query for test method
(method_declaration
name: (field_identifier) @test.name (#match? @test.name "^(Test|Example)")) @test.definition
]]

local table_tests = [[
M.table_tests = [[
;; query for list table tests
(block
(short_var_declaration
Expand Down Expand Up @@ -127,13 +127,27 @@ function M.detect_tests(file_path)
(#eq? @test.key.name @test.key.name1))))))))
]]

local query = test_function .. test_method .. table_tests
--- Detect test names in Go *._test.go files.
--- @param file_path string
function M.detect_tests(file_path)
local opts = { nested_tests = true }
local query = M.test_function .. M.test_method .. M.table_tests

if options.get().testify == true then
-- only detect receiver methods if testify is enabled, to avoid confusion
query = query .. testify.namespace_query
end

---@type neotest.Tree
local positions = lib.treesitter.parse_positions(file_path, query, opts)
local tree = lib.treesitter.parse_positions(file_path, query, opts)

if options.get().testify == true then
local tree_modified_for_testify =
testify.modify_neotest_tree(file_path, tree)
return tree_modified_for_testify
end

return positions
return tree
end

return M
17 changes: 17 additions & 0 deletions lua/neotest-golang/init.lua
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@ local options = require("neotest-golang.options")
local ast = require("neotest-golang.ast")
local runspec_dir = require("neotest-golang.runspec_dir")
local runspec_file = require("neotest-golang.runspec_file")
local runspec_namespace = require("neotest-golang.runspec_namespace")
local runspec_test = require("neotest-golang.runspec_test")
local parse = require("neotest-golang.parse")
local testify = require("neotest-golang.testify")

local M = {}

Expand All @@ -15,6 +17,11 @@ local M = {}
--- @field name string
M.Adapter = {
name = "neotest-golang",
init = function()
if options.get().testify == true then
testify.generate_lookup_map()
end
end,
}

--- Find the project root directory given a current directory to work from.
Expand Down Expand Up @@ -115,6 +122,10 @@ function M.Adapter.build_spec(args)
-- A runspec is to be created, based on on running all tests in the given
-- file.
return runspec_file.build(pos, tree)
elseif pos.type == "namespace" then
-- A runspec is to be created, based on running all tests in the given
-- namespace.
return runspec_namespace.build(pos)
elseif pos.type == "test" then
-- A runspec is to be created, based on on running the given test.
return runspec_test.build(pos, args.strategy)
Expand Down Expand Up @@ -148,6 +159,12 @@ function M.Adapter.results(spec, result, tree)
local results = parse.test_results(spec, result, tree)
M.workaround_neotest_issue_391(result)
return results
elseif spec.context.pos_type == "namespace" then
-- A test command executed a single test and the output/status must now be
-- processed.
local results = parse.test_results(spec, result, tree)
M.workaround_neotest_issue_391(result)
return results
elseif spec.context.pos_type == "test" then
-- A test command executed a single test and the output/status must now be
-- processed.
Expand Down
38 changes: 38 additions & 0 deletions lua/neotest-golang/inspect.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
local M = {}

function M.deep(t, indent, done)
done = done or {}
indent = indent or ""
local output = {}

for k, v in pairs(t) do
if type(v) == "table" and not done[v] then
done[v] = true
table.insert(
output,
indent .. tostring(k) .. ":\n" .. M.deep(v, indent .. " ", done)
)
else
table.insert(output, indent .. tostring(k) .. ": " .. tostring(v))
end
end

return table.concat(output, "\n")
end

function M.dump(o)
if type(o) == "table" then
local s = "{ "
for k, v in pairs(o) do
if type(k) ~= "number" then
k = '"' .. k .. '"'
end
s = s .. "[" .. k .. "] = " .. M.dump(v) .. ","
end
return s .. "} "
else
return tostring(o)
end
end

return M
1 change: 1 addition & 0 deletions lua/neotest-golang/options.lua
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ local opts = {
dap_go_opts = {},
warn_test_name_dupes = true,
warn_test_not_executed = true,
testify = false,

-- experimental, for now undocumented, options
runner = "go", -- or "gotestsum"
Expand Down
46 changes: 46 additions & 0 deletions lua/neotest-golang/runspec_namespace.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
--- Helpers to build the command and context around running a single test.

local convert = require("neotest-golang.convert")
local cmd = require("neotest-golang.cmd")

local M = {}

--- Build runspec for a single test
--- @param pos neotest.Position
--- @return neotest.RunSpec | neotest.RunSpec[] | nil
function M.build(pos)
--- @type string
local test_folder_absolute_path = string.match(pos.path, "(.+)/")
local golist_data = cmd.golist_data(test_folder_absolute_path)

--- @type string
local test_name = convert.to_gotest_test_name(pos.id)
test_name = convert.to_gotest_regex_pattern(test_name)

local test_cmd, json_filepath = cmd.test_command_in_package_with_regexp(
test_folder_absolute_path,
test_name
)

vim.notify(vim.inspect(test_cmd))

--- @type RunspecContext
local context = {
pos_id = pos.id,
pos_type = "namespace",
golist_data = golist_data,
parse_test_results = true,
test_output_json_filepath = json_filepath,
}

--- @type neotest.RunSpec
local run_spec = {
command = test_cmd,
cwd = test_folder_absolute_path,
context = context,
}

return run_spec
end

return M
Loading
Loading