diff options
author | feld <feld@feld.me> | 2024-09-16 20:13:10 +0000 |
---|---|---|
committer | feld <feld@feld.me> | 2024-09-16 20:13:10 +0000 |
commit | e7176bb998a7e20f2bb3c9f32e1e2dfe8c3cd818 (patch) | |
tree | 902c179c947643e520579d49b80480eef86e2495 /lib | |
parent | 3a0d4e98374d77fd6721034362677984b97d2cab (diff) | |
parent | e24e107f3d3ae6024068c6509a7cb0582ea4bf02 (diff) | |
download | pleroma-e7176bb998a7e20f2bb3c9f32e1e2dfe8c3cd818.tar.gz pleroma-e7176bb998a7e20f2bb3c9f32e1e2dfe8c3cd818.zip |
Merge branch 'retry-tests' into 'develop'
Reapply "Custom mix task to retry failed tests once in CI pipeline"
See merge request pleroma/pleroma!4267
Diffstat (limited to 'lib')
-rw-r--r-- | lib/mix/tasks/pleroma/test_runner.ex | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/mix/tasks/pleroma/test_runner.ex b/lib/mix/tasks/pleroma/test_runner.ex new file mode 100644 index 000000000..69fefb001 --- /dev/null +++ b/lib/mix/tasks/pleroma/test_runner.ex @@ -0,0 +1,25 @@ +defmodule Mix.Tasks.Pleroma.TestRunner do + @shortdoc "Retries tests once if they fail" + + use Mix.Task + + def run(args \\ []) do + case System.cmd("mix", ["test"] ++ args, into: IO.stream(:stdio, :line)) do + {_, 0} -> + :ok + + _ -> + retry(args) + end + end + + def retry(args) do + case System.cmd("mix", ["test", "--failed"] ++ args, into: IO.stream(:stdio, :line)) do + {_, 0} -> + :ok + + _ -> + exit(1) + end + end +end |