Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
address_derivation_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
16
17namespace bb::avm2::tracegen {
18namespace {
19
20using ::testing::ElementsAre;
21
23
24TEST(AddressDerivationTraceGenTest, TraceGeneration)
25{
26 TestTraceContainer trace;
27 AddressDerivationTraceBuilder builder;
28
30
31 EmbeddedCurvePoint preaddress_public_key = EmbeddedCurvePoint::one() * Fq(56);
32 EmbeddedCurvePoint address_point = EmbeddedCurvePoint::one() * Fq(67);
33
34 simulation::AddressDerivationEvent addr_event{ .address = FF(0xdeadbeef),
35 .instance = instance,
36 .salted_initialization_hash = FF(12),
37 .partial_address = FF(23),
38 .incoming_viewing_key_hash = FF(56),
39 .public_keys_hash = FF(34),
40 .preaddress = FF(45),
41 .preaddress_public_key = preaddress_public_key,
42 .address_point = address_point };
43 builder.process({ { addr_event } }, trace);
44
45 EXPECT_THAT(
46 trace.as_rows(),
47 ElementsAre(
48 // Only one row.
49 AllOf(
50 ROW_FIELD_EQ(address_derivation_sel, 1),
51 ROW_FIELD_EQ(address_derivation_address, FF(0xdeadbeef)),
52 ROW_FIELD_EQ(address_derivation_salt, instance.salt),
53 ROW_FIELD_EQ(address_derivation_deployer_addr, instance.deployer),
54 ROW_FIELD_EQ(address_derivation_class_id, instance.original_contract_class_id),
55 ROW_FIELD_EQ(address_derivation_init_hash, instance.initialization_hash),
56 ROW_FIELD_EQ(address_derivation_immutables_hash, instance.immutables_hash),
57 ROW_FIELD_EQ(address_derivation_nullifier_key_hash, instance.public_keys.nullifier_key_hash),
58 ROW_FIELD_EQ(address_derivation_incoming_viewing_key_x, instance.public_keys.incoming_viewing_key.x),
59 ROW_FIELD_EQ(address_derivation_incoming_viewing_key_y, instance.public_keys.incoming_viewing_key.y),
60 ROW_FIELD_EQ(address_derivation_outgoing_viewing_key_hash,
61 instance.public_keys.outgoing_viewing_key_hash),
62 ROW_FIELD_EQ(address_derivation_tagging_key_hash, instance.public_keys.tagging_key_hash),
63 ROW_FIELD_EQ(address_derivation_message_signing_key_hash,
64 instance.public_keys.message_signing_key_hash),
65 ROW_FIELD_EQ(address_derivation_fallback_key_hash, instance.public_keys.fallback_key_hash),
66 ROW_FIELD_EQ(address_derivation_salted_init_hash, FF(12)),
67 ROW_FIELD_EQ(address_derivation_partial_address, FF(23)),
68 ROW_FIELD_EQ(address_derivation_incoming_viewing_key_hash, FF(56)),
69 ROW_FIELD_EQ(address_derivation_public_keys_hash, FF(34)),
70 ROW_FIELD_EQ(address_derivation_preaddress, FF(45)),
71 ROW_FIELD_EQ(address_derivation_preaddress_public_key_x, preaddress_public_key.x()),
72 ROW_FIELD_EQ(address_derivation_preaddress_public_key_y, preaddress_public_key.y()),
73 ROW_FIELD_EQ(address_derivation_address_y, address_point.y()),
74 ROW_FIELD_EQ(address_derivation_salted_init_hash_domain_separator, DOM_SEP__SALTED_INITIALIZATION_HASH),
75 ROW_FIELD_EQ(address_derivation_partial_address_domain_separator, DOM_SEP__PARTIAL_ADDRESS),
76 ROW_FIELD_EQ(address_derivation_single_public_key_hash_domain_separator,
78 ROW_FIELD_EQ(address_derivation_public_keys_hash_domain_separator, DOM_SEP__PUBLIC_KEYS_HASH),
79 ROW_FIELD_EQ(address_derivation_preaddress_domain_separator, DOM_SEP__CONTRACT_ADDRESS_V2),
80 ROW_FIELD_EQ(address_derivation_g1_x, EmbeddedCurvePoint::one().x()),
81 ROW_FIELD_EQ(address_derivation_g1_y, EmbeddedCurvePoint::one().y()),
82 ROW_FIELD_EQ(address_derivation_const_two, 2),
83 ROW_FIELD_EQ(address_derivation_const_three, 3),
84 ROW_FIELD_EQ(address_derivation_const_five, 5),
85 ROW_FIELD_EQ(address_derivation_const_seven, 7))));
86}
87
88} // namespace
89} // namespace bb::avm2::tracegen
std::shared_ptr< Napi::ThreadSafeFunction > instance
#define DOM_SEP__SALTED_INITIALIZATION_HASH
#define DOM_SEP__SINGLE_PUBLIC_KEY_HASH
#define DOM_SEP__CONTRACT_ADDRESS_V2
#define DOM_SEP__PARTIAL_ADDRESS
#define DOM_SEP__PUBLIC_KEYS_HASH
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
AluTraceBuilder builder
Definition alu.test.cpp:124
TestTraceContainer trace
#define ROW_FIELD_EQ(field_name, expression)
Definition macros.hpp:7
ContractInstance random_contract_instance()
Definition fixtures.cpp:159
AvmFlavorSettings::FF FF
Definition field.hpp:10
StandardAffinePoint< AvmFlavorSettings::EmbeddedCurve::AffineElement > EmbeddedCurvePoint
Definition field.hpp:12
AvmFlavorSettings::G1::Fq Fq
Definition field.hpp:11
TEST(BoomerangMegaCircuitBuilder, BasicCircuit)