From d98b47fa990c2de085e5edf4866822e57739555e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jo=C3=A3o=20Santos=20Reis?= Date: Wed, 20 Dec 2023 09:28:24 +0000 Subject: [PATCH] Add slot_chain_end tests and other fixes to integration test --- .../{slot_tx_end_test.ml => slot_end_test.ml} | 78 ++++++++++++------- ...slot_tx_end_test.mli => slot_end_test.mli} | 0 src/app/test_executive/test_executive.ml | 2 +- 3 files changed, 49 insertions(+), 31 deletions(-) rename src/app/test_executive/{slot_tx_end_test.ml => slot_end_test.ml} (70%) rename src/app/test_executive/{slot_tx_end_test.mli => slot_end_test.mli} (100%) diff --git a/src/app/test_executive/slot_tx_end_test.ml b/src/app/test_executive/slot_end_test.ml similarity index 70% rename from src/app/test_executive/slot_tx_end_test.ml rename to src/app/test_executive/slot_end_test.ml index 05f62d42b645..f463a6f5d57c 100644 --- a/src/app/test_executive/slot_tx_end_test.ml +++ b/src/app/test_executive/slot_end_test.ml @@ -28,13 +28,13 @@ module Make (Inputs : Intf.Test.Inputs_intf) = struct { default with requires_graphql = true ; genesis_ledger = - [ { Test_Account.account_name = "bp-receiver-key" + [ { Test_Account.account_name = "receiver-key" ; balance = "9999999" ; timing = Untimed } - ; { account_name = "bp-sender-key-1"; balance = "0"; timing = Untimed } - ; { account_name = "bp-sender-key-2"; balance = "0"; timing = Untimed } - ; { account_name = "bp-sender-key-3"; balance = "0"; timing = Untimed } + ; { account_name = "sender-1-key"; balance = "0"; timing = Untimed } + ; { account_name = "sender-2-key"; balance = "0"; timing = Untimed } + ; { account_name = "sender-3-key"; balance = "0"; timing = Untimed } ; { account_name = "snark-node-key"; balance = "0"; timing = Untimed } ] @ List.init num_extra_keys ~f:(fun i -> @@ -44,10 +44,10 @@ module Make (Inputs : Intf.Test.Inputs_intf) = struct ; timing = Untimed } ) ; block_producers = - [ { node_name = "bp-receiver"; account_name = "bp-receiver-key" } - ; { node_name = "bp-sender-1"; account_name = "bp-sender-key-1" } - ; { node_name = "bp-sender-2"; account_name = "bp-sender-key-2" } - ; { node_name = "bp-sender-3"; account_name = "bp-sender-key-3" } + [ { node_name = "receiver"; account_name = "receiver-key" } + ; { node_name = "sender-1"; account_name = "sender-1-key" } + ; { node_name = "sender-2"; account_name = "sender-2-key" } + ; { node_name = "sender-3"; account_name = "sender-3-key" } ] ; snark_coordinator = Some @@ -88,11 +88,11 @@ module Make (Inputs : Intf.Test.Inputs_intf) = struct Mina_numbers.Global_slot.to_int slot + 5 in let receiver = - String.Map.find_exn (Network.block_producers network) "bp-receiver" + String.Map.find_exn (Network.block_producers network) "receiver" in let%bind receiver_pub_key = pub_key_of_node receiver in let bp_senders = - String.Map.remove (Network.block_producers network) "bp-receiver" + String.Map.remove (Network.block_producers network) "receiver" |> String.Map.data in let sender_kps = @@ -153,7 +153,8 @@ module Make (Inputs : Intf.Test.Inputs_intf) = struct >>| const () ) in let%bind () = - section "wait for payments to be processed" + section + (Printf.sprintf "wait until slot %d" num_slots) Async.(at end_t >>= const Malleable_error.ok_unit) in let ok_if_true s = @@ -166,10 +167,22 @@ module Make (Inputs : Intf.Test.Inputs_intf) = struct (Network.Node.get_ingress_uri receiver) in let%bind () = - section "check blocks after slot_tx_end" - (Malleable_error.List.iter blocks ~f:(fun block -> - Option.value_map slot_tx_end ~default:Malleable_error.ok_unit - ~f:(fun slot_tx_end -> + section "non-empty blocks produced before slot_tx_end" + (Option.value_map slot_tx_end ~default:Malleable_error.ok_unit + ~f:(fun slot_tx_end -> + ok_if_true "only empty blocks were produced before slot_tx_end" + @@ List.exists blocks ~f:(fun block -> + Mina_numbers.Global_slot.( + of_uint32 block.slot_since_genesis < slot_tx_end ) + && ( block.command_transaction_count <> 0 + || block.snark_work_count <> 0 + || block.coinbase <> 0 ) ) ) ) + in + let%bind () = + section "only empty blocks produced after slot_tx_end" + (Option.value_map slot_tx_end ~default:Malleable_error.ok_unit + ~f:(fun slot_tx_end -> + Malleable_error.List.iter blocks ~f:(fun block -> let msg = Printf.sprintf "block with transactions after slot_tx_end. block slot \ @@ -182,23 +195,28 @@ module Make (Inputs : Intf.Test.Inputs_intf) = struct in ok_if_true msg ( Mina_numbers.Global_slot.( - of_uint32 block.slot_since_genesis < slot_tx_end) + of_uint32 block.slot_since_genesis < slot_tx_end ) || block.command_transaction_count = 0 && block.snark_work_count = 0 && block.coinbase = 0 ) ) ) ) in - section "check for blocks after slot_chain_end" - (Malleable_error.List.iter blocks ~f:(fun block -> - Option.value_map slot_chain_end ~default:Malleable_error.ok_unit - ~f:(fun slot_chain_end -> - let msg = - Printf.sprintf - "block produced for slot %s after slot_chain_end (%s)" - (Mina_numbers.Global_slot.to_string - block.slot_since_genesis ) - (Mina_numbers.Global_slot.to_string slot_chain_end) - in - ok_if_true msg - Mina_numbers.Global_slot.( - of_uint32 block.slot_since_genesis < slot_chain_end) ) ) ) + let%bind () = + section "blocks produced before slot_chain_end" + (Option.value_map slot_chain_end ~default:Malleable_error.ok_unit + ~f:(fun slot_chain_end -> + ok_if_true "no block produced before slot_chain_end" + @@ List.exists blocks ~f:(fun block -> + Mina_numbers.Global_slot.( + of_uint32 block.slot_since_genesis < slot_chain_end ) ) ) + ) + in + section "no blocks produced after slot_chain_end" + (Option.value_map slot_chain_end ~default:Malleable_error.ok_unit + ~f:(fun slot_chain_end -> + ok_if_true "blocks produced after slot_chain_end" + @@ not + @@ List.exists blocks ~f:(fun block -> + Mina_numbers.Global_slot.( + of_uint32 block.slot_since_genesis >= slot_chain_end ) ) ) + ) end diff --git a/src/app/test_executive/slot_tx_end_test.mli b/src/app/test_executive/slot_end_test.mli similarity index 100% rename from src/app/test_executive/slot_tx_end_test.mli rename to src/app/test_executive/slot_end_test.mli diff --git a/src/app/test_executive/test_executive.ml b/src/app/test_executive/test_executive.ml index 05c5cef465c1..d06fda861da6 100644 --- a/src/app/test_executive/test_executive.ml +++ b/src/app/test_executive/test_executive.ml @@ -61,7 +61,7 @@ let tests : test list = ; ("medium-bootstrap", (module Medium_bootstrap.Make : Intf.Test.Functor_intf)) ; ( "block-prod-prio" , (module Block_production_priority.Make : Intf.Test.Functor_intf) ) - ; ("slot-tx-end", (module Slot_tx_end_test.Make : Intf.Test.Functor_intf)) + ; ("slot-end", (module Slot_end_test.Make : Intf.Test.Functor_intf)) ] let report_test_errors ~log_error_set ~internal_error_set =