Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
contract_instance_retrieval_trace.test.cpp
Go to the documentation of this file.
1#include <gmock/gmock.h>
2#include <gtest/gtest.h>
3
4#include <cstdint>
5#include <memory>
6#include <vector>
7
15
16namespace bb::avm2::tracegen {
17namespace {
18
19using C = Column;
20using simulation::ContractInstanceRetrievalEvent;
21
22// Helper to create a test contract instance with all fields populated
23ContractInstance create_test_contract_instance(uint32_t salt_value = 123)
24{
25 return ContractInstance{
26 .salt = FF(salt_value),
27 .deployer = FF(0x123456789ULL),
28 .current_contract_class_id = FF(0xdeadbeefULL),
29 .original_contract_class_id = FF(0xcafebabeULL),
30 .initialization_hash = FF(0x11111111ULL),
31 .immutables_hash = FF(0x22222222ULL),
32 .public_keys =
33 PublicKeys{
34 .nullifier_key_hash = FF(0x100),
35 .incoming_viewing_key = { FF(0x200), FF(0x201) },
36 .outgoing_viewing_key_hash = FF(0x300),
37 .tagging_key_hash = FF(0x400),
38 .message_signing_key_hash = FF(0x500),
39 .fallback_key_hash = FF(0x600),
40 },
41 };
42}
43
44TEST(ContractInstanceRetrievalTraceGenTest, EmptyEvents)
45{
46 TestTraceContainer trace;
47 ContractInstanceRetrievalTraceBuilder builder;
48
50
51 // When there are no events, the trace sets selector to 0 at row 0
52 // But since TraceContainer doesn't store zero values, get_num_rows() returns 0
53 // We verify that reading row 0 returns 0 for the selector
54 EXPECT_EQ(trace.get(C::contract_instance_retrieval_sel, 0), 0);
55}
56
57TEST(ContractInstanceRetrievalTraceGenTest, SingleEvent)
58{
59 TestTraceContainer trace;
60 ContractInstanceRetrievalTraceBuilder builder;
61
62 // Test constants
63 const auto contract_address = FF(0xabcdef123456ULL);
64 const auto nullifier_tree_root = FF(0x9999);
65 const auto public_data_tree_root = FF(0x8888);
66 const auto deployment_nullifier = FF(0x7777);
67 const auto expected_rows = 2;
68
69 auto contract_instance = create_test_contract_instance();
70
72 {
73 ContractInstanceRetrievalEvent{
74 .address = contract_address,
75 .contract_instance = contract_instance,
76 .nullifier_tree_root = nullifier_tree_root,
77 .public_data_tree_root = public_data_tree_root,
78 .deployment_nullifier = deployment_nullifier,
79 .exists = true,
80 },
81 },
82 trace);
83
84 auto rows = trace.as_rows();
85
86 // Skippable gadget row + 1 event row
87 ASSERT_EQ(rows.size(), expected_rows);
88
89 // Check skippable gadget row
90 EXPECT_THAT(rows.at(0), ROW_FIELD_EQ(contract_instance_retrieval_sel, 0));
91
92 // Check event row
93 EXPECT_THAT(rows.at(1),
94 AllOf(ROW_FIELD_EQ(contract_instance_retrieval_sel, 1),
95 ROW_FIELD_EQ(contract_instance_retrieval_address, contract_address),
96 ROW_FIELD_EQ(contract_instance_retrieval_exists, 1),
97
98 // Contract instance members
99 ROW_FIELD_EQ(contract_instance_retrieval_salt, 123),
100 ROW_FIELD_EQ(contract_instance_retrieval_deployer_addr, 0x123456789ULL),
101 ROW_FIELD_EQ(contract_instance_retrieval_current_class_id, 0xdeadbeefULL),
102 ROW_FIELD_EQ(contract_instance_retrieval_original_class_id, 0xcafebabeULL),
103 ROW_FIELD_EQ(contract_instance_retrieval_init_hash, 0x11111111ULL),
104 ROW_FIELD_EQ(contract_instance_retrieval_immutables_hash, 0x22222222ULL),
105
106 // Public keys (ivpk_m as a point, others as hashes)
107 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_key_hash, 0x100),
108 ROW_FIELD_EQ(contract_instance_retrieval_incoming_viewing_key_x, 0x200),
109 ROW_FIELD_EQ(contract_instance_retrieval_incoming_viewing_key_y, 0x201),
110 ROW_FIELD_EQ(contract_instance_retrieval_outgoing_viewing_key_hash, 0x300),
111 ROW_FIELD_EQ(contract_instance_retrieval_tagging_key_hash, 0x400),
112 ROW_FIELD_EQ(contract_instance_retrieval_message_signing_key_hash, 0x500),
113 ROW_FIELD_EQ(contract_instance_retrieval_fallback_key_hash, 0x600),
114
115 // Tree context
116 ROW_FIELD_EQ(contract_instance_retrieval_public_data_tree_root, public_data_tree_root),
117 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_tree_root, nullifier_tree_root),
118
119 // Deployer protocol contract address
120 ROW_FIELD_EQ(contract_instance_retrieval_deployer_protocol_contract_address,
122}
123
124TEST(ContractInstanceRetrievalTraceGenTest, MultipleEvents)
125{
126 TestTraceContainer trace;
127 ContractInstanceRetrievalTraceBuilder builder;
128
129 // Test constants
130 const auto num_events = 5;
131 const auto base_address = 0x1000;
132 const auto base_nullifier_tree_root = 0x2000;
133 const auto base_public_data_tree_root = 0x3000;
134 const auto base_deployment_nullifier = 0x4000;
135 const auto base_salt = 1000;
136 const auto expected_rows = num_events + 1; // +1 for skippable gadget row
137
139
140 // Create events with different data
141 for (uint32_t i = 0; i < num_events; i++) {
142 auto contract_instance = create_test_contract_instance(base_salt + i);
143
144 events.push_back(ContractInstanceRetrievalEvent{
145 .address = FF(base_address + i),
146 .contract_instance = contract_instance,
147 .nullifier_tree_root = FF(base_nullifier_tree_root + i),
148 .public_data_tree_root = FF(base_public_data_tree_root + i),
149 .deployment_nullifier = FF(base_deployment_nullifier + i),
150 .exists = (i % 2 == 0), // Alternate true/false
151 });
152 }
153
154 builder.process(events, trace);
155 auto rows = trace.as_rows();
156
157 ASSERT_EQ(rows.size(), expected_rows);
158
159 // Check each event row
160 for (uint32_t i = 0; i < num_events; i++) {
161 EXPECT_THAT(
162 rows.at(i + 1),
163 AllOf(ROW_FIELD_EQ(contract_instance_retrieval_sel, 1),
164 ROW_FIELD_EQ(contract_instance_retrieval_address, base_address + i),
165 ROW_FIELD_EQ(contract_instance_retrieval_exists, i % 2 == 0 ? 1 : 0),
166 ROW_FIELD_EQ(contract_instance_retrieval_salt, base_salt + i),
167 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_tree_root, base_nullifier_tree_root + i),
168 ROW_FIELD_EQ(contract_instance_retrieval_public_data_tree_root, base_public_data_tree_root + i),
169 ROW_FIELD_EQ(contract_instance_retrieval_deployer_protocol_contract_address,
171 }
172}
173
174} // namespace
175} // namespace bb::avm2::tracegen
#define CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS
void process(const simulation::EventEmitterInterface< simulation::AluEvent >::Container &events, TraceContainer &trace)
Process the ALU events and populate the ALU relevant columns in the trace.
std::vector< AvmFullRowConstRef > as_rows() const
const FF & get(Column col, uint32_t row) const
AluTraceBuilder builder
Definition alu.test.cpp:124
TestTraceContainer trace
#define ROW_FIELD_EQ(field_name, expression)
Definition macros.hpp:7
AvmFlavorSettings::FF FF
Definition field.hpp:10
TEST(BoomerangMegaCircuitBuilder, BasicCircuit)
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13