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_addr = FF(0x123456789ULL),
28 .current_class_id = FF(0xdeadbeefULL),
29 .original_class_id = FF(0xcafebabeULL),
30 .initialisation_hash = FF(0x11111111ULL),
31 .public_keys =
32 PublicKeys{
33 .nullifier_key = { FF(0x100), FF(0x101) },
34 .incoming_viewing_key = { FF(0x200), FF(0x201) },
35 .outgoing_viewing_key = { FF(0x300), FF(0x301) },
36 .tagging_key = { FF(0x400), FF(0x401) },
37 },
38 };
39}
40
41TEST(ContractInstanceRetrievalTraceGenTest, EmptyEvents)
42{
43 TestTraceContainer trace;
44 ContractInstanceRetrievalTraceBuilder builder;
45
47
48 // When there are no events, the trace sets selector to 0 at row 0
49 // But since TraceContainer doesn't store zero values, get_num_rows() returns 0
50 // We verify that reading row 0 returns 0 for the selector
51 EXPECT_EQ(trace.get(C::contract_instance_retrieval_sel, 0), 0);
52}
53
54TEST(ContractInstanceRetrievalTraceGenTest, SingleEvent)
55{
56 TestTraceContainer trace;
57 ContractInstanceRetrievalTraceBuilder builder;
58
59 // Test constants
60 const auto contract_address = FF(0xabcdef123456ULL);
61 const auto nullifier_tree_root = FF(0x9999);
62 const auto public_data_tree_root = FF(0x8888);
63 const auto deployment_nullifier = FF(0x7777);
64 const auto expected_rows = 2;
65
66 auto contract_instance = create_test_contract_instance();
67
69 {
70 ContractInstanceRetrievalEvent{
71 .address = contract_address,
72 .contract_instance = contract_instance,
73 .nullifier_tree_root = nullifier_tree_root,
74 .public_data_tree_root = public_data_tree_root,
75 .deployment_nullifier = deployment_nullifier,
76 .exists = true,
77 },
78 },
79 trace);
80
81 auto rows = trace.as_rows();
82
83 // Skippable gadget row + 1 event row
84 ASSERT_EQ(rows.size(), expected_rows);
85
86 // Check skippable gadget row
87 EXPECT_THAT(rows.at(0), ROW_FIELD_EQ(contract_instance_retrieval_sel, 0));
88
89 // Check event row
90 EXPECT_THAT(rows.at(1),
91 AllOf(ROW_FIELD_EQ(contract_instance_retrieval_sel, 1),
92 ROW_FIELD_EQ(contract_instance_retrieval_address, contract_address),
93 ROW_FIELD_EQ(contract_instance_retrieval_exists, 1),
94
95 // Contract instance members
96 ROW_FIELD_EQ(contract_instance_retrieval_salt, 123),
97 ROW_FIELD_EQ(contract_instance_retrieval_deployer_addr, 0x123456789ULL),
98 ROW_FIELD_EQ(contract_instance_retrieval_current_class_id, 0xdeadbeefULL),
99 ROW_FIELD_EQ(contract_instance_retrieval_original_class_id, 0xcafebabeULL),
100 ROW_FIELD_EQ(contract_instance_retrieval_init_hash, 0x11111111ULL),
101
102 // Public keys
103 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_key_x, 0x100),
104 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_key_y, 0x101),
105 ROW_FIELD_EQ(contract_instance_retrieval_incoming_viewing_key_x, 0x200),
106 ROW_FIELD_EQ(contract_instance_retrieval_incoming_viewing_key_y, 0x201),
107 ROW_FIELD_EQ(contract_instance_retrieval_outgoing_viewing_key_x, 0x300),
108 ROW_FIELD_EQ(contract_instance_retrieval_outgoing_viewing_key_y, 0x301),
109 ROW_FIELD_EQ(contract_instance_retrieval_tagging_key_x, 0x400),
110 ROW_FIELD_EQ(contract_instance_retrieval_tagging_key_y, 0x401),
111
112 // Tree context
113 ROW_FIELD_EQ(contract_instance_retrieval_public_data_tree_root, public_data_tree_root),
114 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_tree_root, nullifier_tree_root),
115
116 // Deployer protocol contract address
117 ROW_FIELD_EQ(contract_instance_retrieval_deployer_protocol_contract_address,
119}
120
121TEST(ContractInstanceRetrievalTraceGenTest, MultipleEvents)
122{
123 TestTraceContainer trace;
124 ContractInstanceRetrievalTraceBuilder builder;
125
126 // Test constants
127 const auto num_events = 5;
128 const auto base_address = 0x1000;
129 const auto base_nullifier_tree_root = 0x2000;
130 const auto base_public_data_tree_root = 0x3000;
131 const auto base_deployment_nullifier = 0x4000;
132 const auto base_salt = 1000;
133 const auto expected_rows = num_events + 1; // +1 for skippable gadget row
134
136
137 // Create events with different data
138 for (uint32_t i = 0; i < num_events; i++) {
139 auto contract_instance = create_test_contract_instance(base_salt + i);
140
141 events.push_back(ContractInstanceRetrievalEvent{
142 .address = FF(base_address + i),
143 .contract_instance = contract_instance,
144 .nullifier_tree_root = FF(base_nullifier_tree_root + i),
145 .public_data_tree_root = FF(base_public_data_tree_root + i),
146 .deployment_nullifier = FF(base_deployment_nullifier + i),
147 .exists = (i % 2 == 0), // Alternate true/false
148 });
149 }
150
151 builder.process(events, trace);
152 auto rows = trace.as_rows();
153
154 ASSERT_EQ(rows.size(), expected_rows);
155
156 // Check each event row
157 for (uint32_t i = 0; i < num_events; i++) {
158 EXPECT_THAT(
159 rows.at(i + 1),
160 AllOf(ROW_FIELD_EQ(contract_instance_retrieval_sel, 1),
161 ROW_FIELD_EQ(contract_instance_retrieval_address, base_address + i),
162 ROW_FIELD_EQ(contract_instance_retrieval_exists, i % 2 == 0 ? 1 : 0),
163 ROW_FIELD_EQ(contract_instance_retrieval_salt, base_salt + i),
164 ROW_FIELD_EQ(contract_instance_retrieval_nullifier_tree_root, base_nullifier_tree_root + i),
165 ROW_FIELD_EQ(contract_instance_retrieval_public_data_tree_root, base_public_data_tree_root + i),
166 ROW_FIELD_EQ(contract_instance_retrieval_deployer_protocol_contract_address,
168 }
169}
170
171} // namespace
172} // namespace bb::avm2::tracegen
#define CONTRACT_INSTANCE_REGISTRY_CONTRACT_ADDRESS
void process(const simulation::EventEmitterInterface< simulation::AluEvent >::Container &events, TraceContainer &trace)
std::vector< AvmFullRowConstRef > as_rows() const
const FF & get(Column col, uint32_t row) const
AluTraceBuilder builder
Definition alu.test.cpp:123
TestTraceContainer trace
#define ROW_FIELD_EQ(field_name, expression)
Definition macros.hpp:15
TEST(EmitUnencryptedLogTest, Basic)
AvmFlavorSettings::FF FF
Definition field.hpp:10
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13