From cb5315afca9e624ce1ba1040607d6a154727d8c1 Mon Sep 17 00:00:00 2001 From: Lukasz Samson Date: Tue, 27 Feb 2024 20:51:25 +0100 Subject: [PATCH] workaround exunit bug https://github.com/elixir-lang/elixir/issues/13373 --- .../lib/debug_adapter/exunit_formatter.ex | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/apps/debug_adapter/lib/debug_adapter/exunit_formatter.ex b/apps/debug_adapter/lib/debug_adapter/exunit_formatter.ex index 7b45916a5..8c9881872 100644 --- a/apps/debug_adapter/lib/debug_adapter/exunit_formatter.ex +++ b/apps/debug_adapter/lib/debug_adapter/exunit_formatter.ex @@ -164,8 +164,20 @@ defmodule ElixirLS.DebugAdapter.ExUnitFormatter do %{state | failure_counter: state.failure_counter + 1} - {:invalid, test_module = %ExUnit.TestModule{state: {:failed, failures}}} -> + {:invalid, test_module = %ExUnit.TestModule{}} -> # Invalid (when setup_all fails) + failures = + case test_module.state do + nil -> + # workaround exunit bug + # https://github.com/elixir-lang/elixir/issues/13373 + # TODO remove when we require elixir >= 1.17 + [] + + {:failed, failures} -> + failures + end + formatter_cb = fn _key, value -> value end message =