diff --git a/Makefile b/Makefile index 60edb9118..96875a9f2 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,4 @@ -.PHONY: compile rel cover test dialyzer +.PHONY: compile rel cover test dialyzer eqc REBAR=./rebar3 compile: @@ -7,11 +7,12 @@ compile: clean: $(REBAR) clean -cover: test +cover: + $(REBAR) eunit --cover $(REBAR) cover test: compile - $(REBAR) as test do eunit + $(REBAR) eunit dialyzer: $(REBAR) dialyzer @@ -19,4 +20,8 @@ dialyzer: xref: $(REBAR) xref +eqc: + $(REBAR) as test eqc --testing_budget 120 + $(REBAR) as eqc eunit + check: test dialyzer xref diff --git a/rebar.config b/rebar.config index 2b60b22b2..bc4c60fac 100644 --- a/rebar.config +++ b/rebar.config @@ -36,5 +36,5 @@ {profiles, [ {test, [{deps, [meck]}, {erl_opts, [nowarn_export_all]}]}, - {eqc, [{deps, [meck]}, {erl_opts, [nowarn_export_all]}]} + {eqc, [{deps, [meck]}, {erl_opts, [{d, 'EQC'}, nowarn_export_all]}]} ]}. diff --git a/src/hashtree.erl b/src/hashtree.erl index f5ed2d345..846ac3bea 100644 --- a/src/hashtree.erl +++ b/src/hashtree.erl @@ -154,16 +154,14 @@ run_multiple/2, run_remote/0, run_remote/1]). --endif. % TEST -ifdef(EQC). -export([prop_correct/0, prop_sha/0, prop_est/0]). -include_lib("eqc/include/eqc.hrl"). -endif. --ifdef(TEST). -include_lib("eunit/include/eunit.hrl"). --endif. +-endif. %% TEST -define(NUM_SEGMENTS, (1024*1024)). -define(WIDTH, 1024). @@ -1584,6 +1582,7 @@ opened_closed_test() -> %%% EQC %%%=================================================================== +-ifdef(TEST). -ifdef(EQC). prop_sha() -> %% NOTE: Generating 1MB (1024 * 1024) size binaries is incredibly slow @@ -1692,3 +1691,4 @@ prop_est() -> true end). -endif. +-endif. diff --git a/test/riak_core_claim_statem.erl b/test/riak_core_claim_statem.erl index 6e9c84ee6..fd3b9f3c6 100644 --- a/test/riak_core_claim_statem.erl +++ b/test/riak_core_claim_statem.erl @@ -244,6 +244,9 @@ weight(_, _, _, _) -> -define(QC_OUT(P), eqc:on_output(fun(Str, Args) -> io:format(user, Str, Args) end, P)). +claim_test() -> + eqc:quickcheck(?QC_OUT(prop_claim(with_ring_size(5)))). + eqc_check(File, Prop) -> {ok, Bytes} = file:read_file(File), CE = binary_to_term(Bytes),