From 50e6ebe7732557eda692ea378ae78754b2ee6ac6 Mon Sep 17 00:00:00 2001 From: Fredrik Averpil Date: Sat, 30 Nov 2024 13:03:11 +0100 Subject: [PATCH] feat: warn more prominently about 'go list' error --- lua/neotest-golang/lib/cmd.lua | 4 ++-- lua/neotest-golang/process.lua | 16 +++++++++++----- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/lua/neotest-golang/lib/cmd.lua b/lua/neotest-golang/lib/cmd.lua index 92c6f153..81cf121e 100644 --- a/lua/neotest-golang/lib/cmd.lua +++ b/lua/neotest-golang/lib/cmd.lua @@ -25,7 +25,7 @@ function M.golist_data(cwd) if result.stdout ~= nil and result.stderr ~= "" then err = err .. " " .. result.stderr end - logger.debug({ "Go list error: ", err }) + logger.warn({ "Go list error: ", err }) end local output = result.stdout or "" @@ -42,7 +42,7 @@ function M.golist_command() go_list_args = go_list_args() end vim.list_extend(cmd, go_list_args or {}) - vim.list_extend(cmd, { "./..." }) + vim.list_extend(cmd, { "foo" }) return cmd end diff --git a/lua/neotest-golang/process.lua b/lua/neotest-golang/process.lua index cd5b5555..f4b2d41d 100644 --- a/lua/neotest-golang/process.lua +++ b/lua/neotest-golang/process.lua @@ -79,6 +79,12 @@ function M.test_results(spec, result, tree) --- @type table local gotest_output = lib.json.decode_from_table(runner_raw_output, true) + -- detect go list error + local golist_failed = false + if context.errors ~= nil and #context.errors > 0 then + golist_failed = true + end + -- detect build error local build_failed = M.detect_build_errors(result, raw_output) local build_failure_lookup = {} @@ -94,8 +100,8 @@ function M.test_results(spec, result, tree) logger.debug({ "Final internal test result data", res }) - -- show various warnings - if not build_failed then + -- show various warnings, unless `go list` failed or build failed. + if not golist_failed and not build_failed then M.show_warnings(res) end @@ -117,14 +123,14 @@ function M.test_results(spec, result, tree) if build_failed then -- mark as failed if the build failed. result_status = "failed" + elseif context.errors ~= nil and #context.errors > 0 then + -- mark as failed if a non-gotest error occurred. + result_status = "failed" elseif neotest_result[pos.id] and neotest_result[pos.id].status == "skipped" then -- keep the status if it was already decided to be skipped. result_status = "skipped" - elseif context.errors ~= nil and #context.errors > 0 then - -- mark as failed if a non-gotest error occurred. - result_status = "failed" elseif result.code > 0 then -- mark as failed if the go test command failed. result_status = "failed"