From 94eea5a6dc6c8d7c5827ce84c81c2525d7cdf3d2 Mon Sep 17 00:00:00 2001 From: Rahul Garg Date: Tue, 8 May 2018 13:06:59 -0700 Subject: [PATCH] add constructive attack test, WIP --- src/hbbft_bba.erl | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/src/hbbft_bba.erl b/src/hbbft_bba.erl index b930428..5f3fc87 100644 --- a/src/hbbft_bba.erl +++ b/src/hbbft_bba.erl @@ -454,4 +454,28 @@ two_dead_test() -> %% should not converge ?assertEqual(0, sets:size(ConvergedResults)), ok. + +%% https://github.com/amiller/HoneyBadgerBFT/issues/59 +%% constructive_attack_test_() -> +%% {timeout, 60, fun() -> +%% N = 7, +%% F = 2, +%% dealer:start_link(N, F+1, 'SS512'), +%% {ok, _PubKey, PrivateKeys} = dealer:deal(), +%% gen_server:stop(dealer), +%% States = [hbbft_bba:init(Sk, N, F) || Sk <- PrivateKeys], +%% StatesWithId = lists:zip(lists:seq(0, length(States) - 1), States), +%% MixedList = lists:zip([1, 1, 1, 1, 0, 0, 0], StatesWithId), +%% %% all valid members should call get_coin +%% Res = lists:map(fun({I, {J, State}}) -> +%% {NewState, Result} = input(State, I), +%% {{J, NewState}, {J, Result}} +%% end, MixedList), +%% {NewStates, Results} = lists:unzip(Res), +%% {_, ConvergedResults} = hbbft_test_utils:do_send_outer(?MODULE, Results, NewStates, sets:new()), +%% DistinctResults = sets:from_list([BVal || {result, {_, BVal}} <- sets:to_list(ConvergedResults)]), +%% ?assertEqual(N, sets:size(ConvergedResults)), +%% ?assertEqual(1, sets:size(DistinctResults)), +%% ok +%% end}. -endif.