-
Notifications
You must be signed in to change notification settings - Fork 12
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
Running tests from umbrella root #41
Comments
For reference, here's my plugin configuration : require("neotest-elixir")({
post_process_command = function(cmd)
return {
"elixir",
"-r",
"/Users/piacsek/.local/share/nvim/lazy/neotest-elixir/neotest_elixir/json_encoder.ex",
"-r",
"/Users/piacsek/.local/share/nvim/lazy/neotest-elixir/neotest_elixir/formatter.ex",
"-S",
"mix",
"cmd",
"--app",
"my_app",
"mix",
"test",
"--formatter",
"NeotestElixir.Formatter",
"--formatter",
"ExUnit.CLIFormatter",
"path/to/my/test_file.exs",
}
end,
}), |
Update: I've managed to get a working version. Here's my post_process_command = function(cmd)
local test_file_path_from_root = cmd[#cmd]
local current_umbrella_app = test_file_path_from_root:match("^apps/([^/]+)")
local umbrella_relative_path_to_test =
test_file_path_from_root:match("apps/" .. current_umbrella_app .. "/(.*)")
return {
"mix",
"cmd",
"--app",
current_umbrella_app,
"mix",
"test",
"--exit-status",
"0",
"--formatter",
"NeotestElixir.Formatter",
"--formatter",
"ExUnit.CLIFormatter",
umbrella_relative_path_to_test,
}
end, It has the unfortunate requirement to define both Previously I had tried to stick to the It's not an ideal solution, but if you're in a rush like me trying to make neotest work with a legacy codebase that has just migrated to an umbrella structure, I hope it helps 🙏 |
Where did you place the You could try Also, before #30, the mix root would be the child app directory, which I think makes it so that the tests are run from the child app. Could you try the commit before that and see if it works? |
Due to project setup constraints, I'm unable to run tests from the project root on my umbrella project, I have to cd to
apps/sub_app
and then run the test. I wonder if there's a way to configure the adapter in a way that it runs tests from the umbrella app root.I tried to do that by modifying
post_process_command
to run the test throughmix cmd --app my_app test path/to/test.exs
. Here's my version of the run command:But I when I run this command, the following output appears:
The tests pass, but the formatter fails to parse the results, making
neotest
consider the test as a failure.PS: I'm currently trying to alter my project in a way that I can run any test from the root of the project, but having that as a configuration could come in handy not just to me but to other people in a similar situation.
The text was updated successfully, but these errors were encountered: