4#include <gmock/gmock.h>
5#include <gtest/gtest.h>
20using ::testing::IsEmpty;
21using ::testing::Return;
22using ::testing::SizeIs;
23using ::testing::StrictMock;
31using simulation::PurePoseidon2;
33TEST(AvmSimulationAddressDerivationTest, Positive)
35 EventEmitter<AddressDerivationEvent> address_derivation_event_emitter;
36 PurePoseidon2
poseidon2 = PurePoseidon2();
37 StrictMock<MockEcc> ecc;
39 AddressDerivation address_derivation(
poseidon2, ecc, address_derivation_event_emitter);
43 std::vector<FF> salted_init_hash_inputs = {
53 FF public_keys_hash = hash_public_keys(
instance.public_keys);
60 EXPECT_CALL(ecc, scalar_mul(
g1, preaddress)).WillOnce(Return(preaddress_public_key));
64 .WillOnce(Return(address_point));
66 address_derivation.assert_derivation(derived_address,
instance);
68 auto events = address_derivation_event_emitter.dump_events();
69 EXPECT_THAT(events, SizeIs(1));
71 EXPECT_EQ(events[0].salted_initialization_hash, salted_init_hash);
72 EXPECT_EQ(events[0].partial_address, partial_address);
73 EXPECT_EQ(events[0].public_keys_hash, public_keys_hash);
74 EXPECT_EQ(events[0].preaddress, preaddress);
75 EXPECT_EQ(events[0].preaddress_public_key, preaddress_public_key);
76 EXPECT_EQ(events[0].
address, derived_address);
77 EXPECT_EQ(events[0].address_point.x(), derived_address);
80 address_derivation.assert_derivation(derived_address,
instance);
81 events = address_derivation_event_emitter.dump_events();
82 EXPECT_THAT(events, IsEmpty());
85TEST(AvmSimulationAddressDerivationTest, Negative)
87 EventEmitter<AddressDerivationEvent> address_derivation_event_emitter;
88 PurePoseidon2
poseidon2 = PurePoseidon2();
89 StrictMock<MockEcc> ecc;
91 AddressDerivation address_derivation(
poseidon2, ecc, address_derivation_event_emitter);
96 std::vector<FF> salted_init_hash_inputs = {
102 instance.original_contract_class_id,
106 FF public_keys_hash = hash_public_keys(
instance.public_keys);
113 EXPECT_CALL(ecc, scalar_mul(
g1, preaddress)).WillOnce(Return(preaddress_public_key));
117 .WillOnce(Return(address_point));
120 EXPECT_THROW(address_derivation.assert_derivation(derived_address + 1,
instance), std::runtime_error);
125 public_keys_hash = hash_public_keys(
instance.public_keys);
128 preaddress_public_key =
g1 *
Fq(preaddress);
129 address_point = preaddress_public_key +
instance.public_keys.incoming_viewing_key;
131 EXPECT_CALL(ecc, scalar_mul(
g1, preaddress)).WillOnce(Return(preaddress_public_key));
133 .WillOnce(Return(address_point));
136 EXPECT_THROW(address_derivation.assert_derivation(derived_address,
instance), std::runtime_error);
137 EXPECT_THAT(address_derivation_event_emitter.dump_events(), IsEmpty());
140 EXPECT_CALL(ecc, scalar_mul(
g1, preaddress)).WillOnce(Return(preaddress_public_key));
142 .WillOnce(Return(address_point));
144 address_derivation.assert_derivation(address_point.x(),
instance);
145 EXPECT_THAT(address_derivation_event_emitter.dump_events(), SizeIs(1));
148 ContractInstance new_instance =
instance;
149 new_instance.deployer += 1;
151 EXPECT_THROW(address_derivation.assert_derivation(address_point.x(), new_instance), std::runtime_error);
152 EXPECT_THAT(address_derivation_event_emitter.dump_events(), IsEmpty());
155 address_derivation.assert_derivation(address_point.x(),
instance);
156 EXPECT_THAT(address_derivation_event_emitter.dump_events(), IsEmpty());
std::shared_ptr< Napi::ThreadSafeFunction > instance
#define DOM_SEP__SALTED_INITIALIZATION_HASH
#define DOM_SEP__PARTIAL_ADDRESS
#define DOM_SEP__CONTRACT_ADDRESS_V1
static const StandardAffinePoint & one()
Native Poseidon2 hash function implementation.
static FF hash(const std::vector< FF > &input)
Hashes a vector of field elements.
static constexpr affine_element one() noexcept
group class. Represents an elliptic curve group element. Group is parametrised by Fq and Fr
AVM range check gadget for witness generation.
ContractInstance random_contract_instance()
StandardAffinePoint< AvmFlavorSettings::EmbeddedCurve::AffineElement > EmbeddedCurvePoint
AvmFlavorSettings::G1::Fq Fq
TEST(BoomerangMegaCircuitBuilder, BasicCircuit)