diff options
author | Jared Morrow <jared@basho.com> | 2014-02-07 11:32:06 -0700 |
---|---|---|
committer | Jared Morrow <jared@basho.com> | 2014-02-07 11:32:06 -0700 |
commit | ec448c089429050bfecbfb9bd211510cdaf3a496 (patch) | |
tree | bf9389b79938bf3e0b2020525d1b36958c9b8244 /src | |
parent | fa679b43434020e8765f6f8ee9b7abebfb3b0109 (diff) | |
parent | 2f6991cbd7ae249e0d24f991c37b2746fd78b1d6 (diff) |
Merge pull request #223 from rebar/adt-random-suite-order
Add random_suite_order option to eunit command
Diffstat (limited to 'src')
-rw-r--r-- | src/rebar.erl | 2 | ||||
-rw-r--r-- | src/rebar_eunit.erl | 32 |
2 files changed, 33 insertions, 1 deletions
diff --git a/src/rebar.erl b/src/rebar.erl index b213e6c..833e397 100644 --- a/src/rebar.erl +++ b/src/rebar.erl @@ -369,6 +369,8 @@ eunit [suite[s]=foo] Run eunit tests in foo.erl and no such test exists, run the test whose name starts with bar in the suite's _tests module + [random_suite_order=true] Run tests in a random order, either with + [random_suite_order=Seed] a random seed for the PRNG, or a specific one. ct [suite[s]=] [case=] Run common_test suites diff --git a/src/rebar_eunit.erl b/src/rebar_eunit.erl index e04b28e..3fe1280 100644 --- a/src/rebar_eunit.erl +++ b/src/rebar_eunit.erl @@ -126,6 +126,9 @@ info_help(Description) -> " name starts with bar and, if no such test exists,~n" " run the test whose name starts with bar in the~n" " suite's _tests module)~n" + " random_suite_order=true (Run tests in random order)~n" + " random_suite_order=Seed (Run tests in random order,~n" + " with the PRNG seeded with Seed)~n" " compile_only=true (Compile but do not run tests)", [ Description, @@ -150,7 +153,7 @@ run_eunit(Config, CodePath, SrcErls) -> AllBeamFiles), OtherBeamFiles = TestBeamFiles -- [filename:rootname(N) ++ "_tests.beam" || N <- AllBeamFiles], - ModuleBeamFiles = BeamFiles ++ OtherBeamFiles, + ModuleBeamFiles = randomize_suites(Config, BeamFiles ++ OtherBeamFiles), %% Get modules to be run in eunit AllModules = [rebar_utils:beam_to_mod(?EUNIT_DIR, N) || N <- AllBeamFiles], @@ -234,6 +237,33 @@ get_suites(Config) -> end. %% +%% == randomize suites == +%% + +randomize_suites(Config, Modules) -> + case rebar_config:get_global(Config, random_suite_order, undefined) of + undefined -> + Modules; + "true" -> + Seed = crypto:rand_uniform(1, 65535), + randomize_suites1(Modules, Seed); + String -> + try list_to_integer(String) of + Seed -> + randomize_suites1(Modules, Seed) + catch + error:badarg -> + ?ERROR("Bad random seed provided: ~p~n", [String]), + ?FAIL + end + end. + +randomize_suites1(Modules, Seed) -> + random:seed(35, Seed, 1337), + ?CONSOLE("Randomizing suite order with seed ~b~n", [Seed]), + [X||{_,X} <- lists:sort([{random:uniform(), M} || M <- Modules])]. + +%% %% == get matching tests == %% get_tests(Config, SuitesProvided, ModuleBeamFiles, FilteredModules) -> |