2017-04-12 20:53:23 +04:00
|
|
|
(**************************************************************************)
|
|
|
|
(* *)
|
2017-11-14 03:36:14 +04:00
|
|
|
(* Copyright (c) 2014 - 2017. *)
|
2017-04-12 20:53:23 +04:00
|
|
|
(* Dynamic Ledger Solutions, Inc. <contact@tezos.com> *)
|
|
|
|
(* *)
|
|
|
|
(* All rights reserved. No warranty, explicit or implicit, provided. *)
|
|
|
|
(* *)
|
|
|
|
(**************************************************************************)
|
|
|
|
|
2018-01-29 04:06:47 +04:00
|
|
|
open Proto_alpha
|
|
|
|
open Tezos_context
|
2017-04-12 20:53:23 +04:00
|
|
|
open Proto_alpha_helpers
|
|
|
|
|
|
|
|
let demo_protocol =
|
|
|
|
Protocol_hash.of_b58check_exn
|
|
|
|
"ProtoDemoDemoDemoDemoDemoDemoDemoDemoDemoDemoD3c8k9"
|
|
|
|
|
|
|
|
let print_level head =
|
|
|
|
level (`Hash head) >>=? fun lvl ->
|
|
|
|
return @@ Format.eprintf "voting_period = %a.%ld@."
|
|
|
|
Voting_period.pp lvl.voting_period lvl.voting_period_position
|
|
|
|
|
2017-04-27 03:01:05 +04:00
|
|
|
let run_change_to_demo_proto block
|
|
|
|
({ b1 ; b2 ; b3 ; b4 ; b5 } : Account.bootstrap_accounts) =
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake block b1 [] >>=? fun head ->
|
2017-04-12 20:53:23 +04:00
|
|
|
Format.eprintf "Entering `Proposal` voting period@.";
|
2017-04-20 13:07:50 +04:00
|
|
|
Assert.check_voting_period_kind ~msg:__LOC__ ~block:(`Hash head)
|
|
|
|
Voting_period.Proposal >>=? fun () ->
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b2 [] >>=? fun head ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
|
|
|
(* 1. Propose the 'demo' protocol as b1 (during the Proposal period) *)
|
2017-04-17 22:53:23 +04:00
|
|
|
Protocol.proposals
|
2017-04-12 20:53:23 +04:00
|
|
|
~block:(`Hash head)
|
|
|
|
~src:b1
|
2017-04-17 22:53:23 +04:00
|
|
|
[demo_protocol] >>=? fun op ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
|
|
|
(* Mine blocks to switch to next vote period (Testing_vote) *)
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b3 [op] >>=? fun head ->
|
2017-04-12 20:53:23 +04:00
|
|
|
Format.eprintf "Entering `Testing_vote` voting period@.";
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b4 [] >>=? fun head ->
|
2017-04-20 13:07:50 +04:00
|
|
|
Assert.check_voting_period_kind ~msg:__LOC__ ~block:(`Hash head)
|
|
|
|
Voting_period.Testing_vote >>=? fun () ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
|
|
|
(* 2. Vote unanimously for a proposal *)
|
|
|
|
|
|
|
|
let vote_for_demo ~src ~block ballot =
|
2017-04-17 22:53:23 +04:00
|
|
|
Protocol.ballot
|
2017-04-12 20:53:23 +04:00
|
|
|
~block
|
|
|
|
~src
|
|
|
|
~proposal:demo_protocol
|
|
|
|
ballot
|
|
|
|
in
|
|
|
|
let all_accounts = [b1; b2; b3; b4; b5] in
|
|
|
|
|
|
|
|
map_s (fun src -> vote_for_demo ~src ~block:(`Hash head) Vote.Yay)
|
|
|
|
all_accounts >>=? fun operations ->
|
|
|
|
|
|
|
|
(* Mine blocks to switch to next vote period (Testing) *)
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b5 operations >>=? fun head ->
|
2017-04-12 20:53:23 +04:00
|
|
|
Format.eprintf "Entering `Testing` voting period@.";
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b1 [] >>=? fun head ->
|
2017-04-20 13:07:50 +04:00
|
|
|
Assert.check_voting_period_kind ~msg:__LOC__ ~block:(`Hash head)
|
|
|
|
Voting_period.Testing >>=? fun () ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
|
|
|
(* 3. Test the proposed protocol *)
|
|
|
|
|
2017-04-27 03:01:05 +04:00
|
|
|
(* Mine blocks to switch to next vote period (Promote_vote) *)
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b2 [] >>=? fun head ->
|
2017-04-27 03:01:05 +04:00
|
|
|
Format.eprintf "Entering `Promote_vote` voting period@.";
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b3 [] >>=? fun head ->
|
2017-04-20 13:07:50 +04:00
|
|
|
Assert.check_voting_period_kind ~msg:__LOC__ ~block:(`Hash head)
|
|
|
|
Voting_period.Promotion_vote >>=? fun () ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
|
|
|
(* 4. Vote unanimously for promoting the protocol *)
|
|
|
|
map_s (fun src -> vote_for_demo ~src ~block:(`Hash head) Vote.Yay)
|
|
|
|
all_accounts >>=? fun operations ->
|
|
|
|
|
|
|
|
(* Mine blocks to switch to end the vote cycle (back to Proposal) *)
|
|
|
|
Format.eprintf "Switching to `demo` protocol@.";
|
2017-11-20 06:37:06 +04:00
|
|
|
Baking.bake (`Hash head) b4 operations >>=? fun head ->
|
|
|
|
Baking.bake (`Hash head) b5 [] >>=? fun head ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
2017-04-27 03:01:05 +04:00
|
|
|
Assert.check_protocol
|
|
|
|
~msg:__LOC__ ~block:(`Hash head) demo_protocol >>=? fun () ->
|
2017-04-12 20:53:23 +04:00
|
|
|
|
|
|
|
return (`Hash head)
|
|
|
|
|
|
|
|
let change_to_demo_proto () =
|
2017-10-28 22:32:39 +04:00
|
|
|
init ~sandbox:"sandbox-vote.json" ~rpc_port:18400 () >>=? fun (_node_pid, hash) ->
|
2017-04-12 20:53:23 +04:00
|
|
|
run_change_to_demo_proto (`Hash hash) Account.bootstrap_accounts >>=? fun _blkh ->
|
|
|
|
return ()
|
|
|
|
|
|
|
|
let tests = [
|
|
|
|
"change_to_demo_proto", (fun _ -> change_to_demo_proto ()) ;
|
|
|
|
]
|
|
|
|
|
|
|
|
let () =
|
2018-02-02 19:26:02 +04:00
|
|
|
let module Test = Tezos_test_helpers.Test.Make(Error_monad) in
|
2017-04-12 20:53:23 +04:00
|
|
|
Test.run "amendment." tests
|