Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
class_id_derivation.test.cpp
Go to the documentation of this file.
1#include <gmock/gmock.h>
2#include <gtest/gtest.h>
3
21
22namespace bb::avm2::constraining {
23namespace {
24
25using ::testing::StrictMock;
26
27using tracegen::BytecodeTraceBuilder;
28using tracegen::ClassIdDerivationTraceBuilder;
29using tracegen::Poseidon2TraceBuilder;
30using tracegen::TestTraceContainer;
31
32using simulation::ClassIdDerivation;
33using simulation::ClassIdDerivationEvent;
35using simulation::EventEmitter;
36using simulation::MockExecutionIdManager;
37using simulation::MockGreaterThan;
38using simulation::NoopEventEmitter;
39using simulation::Poseidon2;
40using simulation::Poseidon2HashEvent;
41using simulation::Poseidon2PermutationEvent;
42using simulation::Poseidon2PermutationMemoryEvent;
43using simulation::PurePoseidon2;
44
46using C = Column;
47using class_id_derivation_relation = bb::avm2::class_id_derivation<FF>;
48
49ContractClassWithCommitment generate_contract_class()
50{
51 return ContractClassWithCommitment{
52 .id = FF::random_element(),
53 .artifact_hash = FF::random_element(),
54 .private_functions_root = FF::random_element(),
55 .packed_bytecode = {},
56 .public_bytecode_commitment = FF::random_element(),
57 };
58}
59
60TEST(ClassIdDerivationConstrainingTest, EmptyRow)
61{
62 check_relation<class_id_derivation_relation>(testing::empty_trace());
63}
64
65TEST(ClassIdDerivationConstrainingTest, Basic)
66{
67 TestTraceContainer trace;
68 ClassIdDerivationTraceBuilder builder;
69
70 auto klass = generate_contract_class();
71 FF class_id =
72 compute_contract_class_id(klass.artifact_hash, klass.private_functions_root, klass.public_bytecode_commitment);
73
74 builder.process({ { .class_id = class_id,
75 .artifact_hash = klass.artifact_hash,
76 .private_functions_root = klass.private_functions_root,
77 .public_bytecode_commitment = klass.public_bytecode_commitment } },
78 trace);
79
80 check_relation<class_id_derivation_relation>(trace);
81}
82
83TEST(ClassIdDerivationPoseidonTest, WithHashInteraction)
84{
85 EventEmitter<Poseidon2HashEvent> hash_event_emitter;
86 NoopEventEmitter<Poseidon2PermutationEvent> perm_event_emitter;
87 NoopEventEmitter<Poseidon2PermutationMemoryEvent> perm_mem_event_emitter;
88 StrictMock<MockExecutionIdManager> execution_id_manager;
89 StrictMock<MockGreaterThan> mock_gt;
92
93 EventEmitter<ClassIdDerivationEvent> event_emitter;
95
96 auto klass = generate_contract_class();
97 FF class_id =
98 compute_contract_class_id(klass.artifact_hash, klass.private_functions_root, klass.public_bytecode_commitment);
99 klass.id = class_id;
100
101 TestTraceContainer trace({
102 { { C::precomputed_first_row, 1 } },
103 });
104
105 ClassIdDerivationTraceBuilder builder;
106 Poseidon2TraceBuilder poseidon2_builder;
107
108 class_id_derivation.assert_derivation(klass);
109
111 builder.process({ { .class_id = klass.id,
112 .artifact_hash = klass.artifact_hash,
113 .private_functions_root = klass.private_functions_root,
114 .public_bytecode_commitment = klass.public_bytecode_commitment } },
115 trace);
116
117 check_interaction<ClassIdDerivationTraceBuilder,
120}
121
122} // namespace
123} // namespace bb::avm2::constraining
StrictMock< MockGreaterThan > mock_gt
EventEmitter< Poseidon2PermutationMemoryEvent > perm_mem_event_emitter
EventEmitter< Poseidon2PermutationEvent > perm_event_emitter
EventEmitter< Poseidon2HashEvent > hash_event_emitter
Poseidon2TraceBuilder poseidon2_builder
StrictMock< MockClassIdDerivation > class_id_derivation
void process(const simulation::EventEmitterInterface< simulation::AluEvent >::Container &events, TraceContainer &trace)
Process the ALU events and populate the ALU relevant columns in the trace.
void process_hash(const simulation::EventEmitterInterface< simulation::Poseidon2HashEvent >::Container &hash_events, TraceContainer &trace)
Processes the hash events for the Poseidon2 hash function. It populates the columns for the poseidon2...
Native Poseidon2 hash function implementation.
Definition poseidon2.hpp:22
AluTraceBuilder builder
Definition alu.test.cpp:124
ExecutionIdManager execution_id_manager
EventEmitter< DataCopyEvent > event_emitter
TestTraceContainer trace
void check_interaction(tracegen::TestTraceContainer &trace)
TEST(AvmFixedVKTests, FixedVKCommitments)
Test that the fixed VK commitments agree with the ones computed from precomputed columns.
FF compute_contract_class_id(const FF &artifact_hash, const FF &private_fn_root, const FF &public_bytecode_commitment)
TestTraceContainer empty_trace()
Definition fixtures.cpp:153
lookup_settings< lookup_class_id_derivation_class_id_poseidon2_1_settings_ > lookup_class_id_derivation_class_id_poseidon2_1_settings
lookup_settings< lookup_class_id_derivation_class_id_poseidon2_0_settings_ > lookup_class_id_derivation_class_id_poseidon2_0_settings
static field random_element(numeric::RNG *engine=nullptr) noexcept