Merge pull request #12591 from thalesmg/dev-cls-m-20240226

test: make `clear_screen` safer
This commit is contained in:
Thales Macedo Garitezi 2024-02-26 13:40:16 -03:00 committed by GitHub
commit 9ca5684b34
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 17 additions and 7 deletions

View File

@ -1060,14 +1060,24 @@ expand_node_specs(Specs, CommonOpts) ->
Specs
).
%% is useful when iterating on the tests in a loop, to get rid of all
%% the garbaged printed before the test itself beings.
%% Useful when iterating on the tests in a loop, to get rid of all the garbaged printed
%% before the test itself beings.
%% Only actually does anything if the environment variable `CLEAR_SCREEN' is set to `true'
%% and only clears the screen the screen the first time it's encountered, so it's harmless
%% otherwise.
clear_screen() ->
Key = {?MODULE, clear_screen},
case {os:getenv("CLEAR_SCREEN"), persistent_term:get(Key, false)} of
{"true", false} ->
io:format(standard_io, "\033[H\033[2J", []),
io:format(standard_error, "\033[H\033[2J", []),
io:format(standard_io, "\033[H\033[3J", []),
io:format(standard_error, "\033[H\033[3J", []),
ok.
persistent_term:put(Key, true),
ok;
_ ->
ok
end.
with_mock(Mod, FnName, MockedFn, Fun) ->
ok = meck:new(Mod, [non_strict, no_link, no_history, passthrough]),