mirror of
https://github.com/monero-project/monero.git
synced 2024-12-04 23:51:08 +02:00
more get_output_enote_proposals tests
This commit is contained in:
parent
36cb2e5846
commit
d02c1040ed
@ -893,6 +893,103 @@ TEST(carrot_core, main_address_coinbase_scan_completeness)
|
|||||||
enote.onetime_address));
|
enote.onetime_address));
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------------------------
|
||||||
|
TEST(carrot_core, main2main_transfer_2out_completeness)
|
||||||
|
{
|
||||||
|
const mock_carrot_keys alice = mock_carrot_keys::generate();
|
||||||
|
const mock_carrot_keys bob = mock_carrot_keys::generate();
|
||||||
|
|
||||||
|
CarrotDestinationV1 alice_address;
|
||||||
|
make_carrot_main_address_v1(alice.account_spend_pubkey,
|
||||||
|
alice.main_address_view_pubkey,
|
||||||
|
alice_address);
|
||||||
|
|
||||||
|
CarrotDestinationV1 bob_address;
|
||||||
|
make_carrot_main_address_v1(bob.account_spend_pubkey,
|
||||||
|
bob.main_address_view_pubkey,
|
||||||
|
bob_address);
|
||||||
|
|
||||||
|
const crypto::key_image tx_first_key_image = rct::rct2ki(rct::pkGen());
|
||||||
|
input_context_t input_context;
|
||||||
|
make_carrot_input_context(tx_first_key_image, input_context);
|
||||||
|
|
||||||
|
const CarrotPaymentProposalV1 bob_payment_proposal = CarrotPaymentProposalV1{
|
||||||
|
.destination = bob_address,
|
||||||
|
.amount = crypto::rand_idx<rct::xmr_amount>(1000000),
|
||||||
|
.randomness = gen_janus_anchor()
|
||||||
|
};
|
||||||
|
|
||||||
|
const CarrotPaymentProposalSelfSendV1 alice_payment_proposal = CarrotPaymentProposalSelfSendV1{
|
||||||
|
.destination_address_spend_pubkey = alice_address.address_spend_pubkey,
|
||||||
|
.amount = crypto::rand_idx<rct::xmr_amount>(1000000),
|
||||||
|
.enote_type = CarrotEnoteType::CHANGE,
|
||||||
|
.enote_ephemeral_pubkey = get_enote_ephemeral_pubkey(bob_payment_proposal, input_context)
|
||||||
|
};
|
||||||
|
|
||||||
|
std::vector<RCTOutputEnoteProposal> enote_proposals;
|
||||||
|
encrypted_payment_id_t encrypted_payment_id;
|
||||||
|
get_output_enote_proposals({bob_payment_proposal},
|
||||||
|
{alice_payment_proposal},
|
||||||
|
alice.s_view_balance_dev,
|
||||||
|
tx_first_key_image,
|
||||||
|
enote_proposals,
|
||||||
|
encrypted_payment_id);
|
||||||
|
|
||||||
|
ASSERT_EQ(2, enote_proposals.size()); // 2-out tx
|
||||||
|
|
||||||
|
// collect enotes
|
||||||
|
std::vector<CarrotEnoteV1> enotes;
|
||||||
|
for (const RCTOutputEnoteProposal &enote_proposal : enote_proposals)
|
||||||
|
enotes.push_back(enote_proposal.enote);
|
||||||
|
|
||||||
|
// check that alice scanned 1 enote
|
||||||
|
std::vector<unittest_carrot_scan_result_t> alice_scan_vec;
|
||||||
|
unittest_scan_enote_set(enotes, encrypted_payment_id, alice, alice_scan_vec);
|
||||||
|
ASSERT_EQ(1, alice_scan_vec.size());
|
||||||
|
unittest_carrot_scan_result_t alice_scan = alice_scan_vec.front();
|
||||||
|
|
||||||
|
// check that bob scanned 1 enote
|
||||||
|
std::vector<unittest_carrot_scan_result_t> bob_scan_vec;
|
||||||
|
unittest_scan_enote_set(enotes, encrypted_payment_id, bob, bob_scan_vec);
|
||||||
|
ASSERT_EQ(1, bob_scan_vec.size());
|
||||||
|
unittest_carrot_scan_result_t bob_scan = bob_scan_vec.front();
|
||||||
|
|
||||||
|
// set named references to enotes
|
||||||
|
ASSERT_TRUE((alice_scan.output_index == 0 && bob_scan.output_index == 1) ||
|
||||||
|
(alice_scan.output_index == 1 && bob_scan.output_index == 0));
|
||||||
|
const CarrotEnoteV1 &alice_enote = enotes.at(alice_scan.output_index);
|
||||||
|
const CarrotEnoteV1 &bob_enote = enotes.at(bob_scan.output_index);
|
||||||
|
|
||||||
|
// check Alice's recovered data
|
||||||
|
EXPECT_EQ(alice_payment_proposal.destination_address_spend_pubkey, alice_scan.address_spend_pubkey);
|
||||||
|
EXPECT_EQ(alice_payment_proposal.amount, alice_scan.amount);
|
||||||
|
EXPECT_EQ(alice_enote.amount_commitment, rct::commit(alice_scan.amount, rct::sk2rct(alice_scan.amount_blinding_factor)));
|
||||||
|
EXPECT_EQ(null_payment_id, alice_scan.payment_id);
|
||||||
|
EXPECT_EQ(alice_payment_proposal.enote_type, alice_scan.enote_type);
|
||||||
|
|
||||||
|
// check Bob's recovered data
|
||||||
|
EXPECT_EQ(bob_payment_proposal.destination.address_spend_pubkey, bob_scan.address_spend_pubkey);
|
||||||
|
EXPECT_EQ(bob_payment_proposal.amount, bob_scan.amount);
|
||||||
|
EXPECT_EQ(bob_enote.amount_commitment, rct::commit(bob_scan.amount, rct::sk2rct(bob_scan.amount_blinding_factor)));
|
||||||
|
EXPECT_EQ(null_payment_id, bob_scan.payment_id);
|
||||||
|
EXPECT_EQ(CarrotEnoteType::PAYMENT, bob_scan.enote_type);
|
||||||
|
|
||||||
|
// check Alice spendability
|
||||||
|
EXPECT_TRUE(can_open_fcmp_onetime_address(alice.k_prove_spend,
|
||||||
|
alice.k_generate_image,
|
||||||
|
crypto::secret_key{{1}},
|
||||||
|
alice_scan.sender_extension_g,
|
||||||
|
alice_scan.sender_extension_t,
|
||||||
|
alice_enote.onetime_address));
|
||||||
|
|
||||||
|
// check Bob spendability
|
||||||
|
EXPECT_TRUE(can_open_fcmp_onetime_address(bob.k_prove_spend,
|
||||||
|
bob.k_generate_image,
|
||||||
|
crypto::secret_key{{1}},
|
||||||
|
bob_scan.sender_extension_g,
|
||||||
|
bob_scan.sender_extension_t,
|
||||||
|
bob_enote.onetime_address));
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------------------------------------------------
|
||||||
TEST(carrot_core, sub2sub_transfer_2out_completeness)
|
TEST(carrot_core, sub2sub_transfer_2out_completeness)
|
||||||
{
|
{
|
||||||
const mock_carrot_keys alice = mock_carrot_keys::generate();
|
const mock_carrot_keys alice = mock_carrot_keys::generate();
|
||||||
@ -1026,3 +1123,101 @@ TEST(carrot_core, sub2sub_transfer_2out_completeness)
|
|||||||
bob_enote.onetime_address));
|
bob_enote.onetime_address));
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------------------------
|
||||||
|
TEST(carrot_core, main2integ_transfer_2out_completeness)
|
||||||
|
{
|
||||||
|
const mock_carrot_keys alice = mock_carrot_keys::generate();
|
||||||
|
const mock_carrot_keys bob = mock_carrot_keys::generate();
|
||||||
|
|
||||||
|
CarrotDestinationV1 alice_address;
|
||||||
|
make_carrot_main_address_v1(alice.account_spend_pubkey,
|
||||||
|
alice.main_address_view_pubkey,
|
||||||
|
alice_address);
|
||||||
|
|
||||||
|
CarrotDestinationV1 bob_address;
|
||||||
|
make_carrot_integrated_address_v1(bob.account_spend_pubkey,
|
||||||
|
bob.main_address_view_pubkey,
|
||||||
|
gen_payment_id(),
|
||||||
|
bob_address);
|
||||||
|
|
||||||
|
const crypto::key_image tx_first_key_image = rct::rct2ki(rct::pkGen());
|
||||||
|
input_context_t input_context;
|
||||||
|
make_carrot_input_context(tx_first_key_image, input_context);
|
||||||
|
|
||||||
|
const CarrotPaymentProposalV1 bob_payment_proposal = CarrotPaymentProposalV1{
|
||||||
|
.destination = bob_address,
|
||||||
|
.amount = crypto::rand_idx<rct::xmr_amount>(1000000),
|
||||||
|
.randomness = gen_janus_anchor()
|
||||||
|
};
|
||||||
|
|
||||||
|
const CarrotPaymentProposalSelfSendV1 alice_payment_proposal = CarrotPaymentProposalSelfSendV1{
|
||||||
|
.destination_address_spend_pubkey = alice_address.address_spend_pubkey,
|
||||||
|
.amount = crypto::rand_idx<rct::xmr_amount>(1000000),
|
||||||
|
.enote_type = CarrotEnoteType::CHANGE,
|
||||||
|
.enote_ephemeral_pubkey = get_enote_ephemeral_pubkey(bob_payment_proposal, input_context)
|
||||||
|
};
|
||||||
|
|
||||||
|
std::vector<RCTOutputEnoteProposal> enote_proposals;
|
||||||
|
encrypted_payment_id_t encrypted_payment_id;
|
||||||
|
get_output_enote_proposals({bob_payment_proposal},
|
||||||
|
{alice_payment_proposal},
|
||||||
|
alice.s_view_balance_dev,
|
||||||
|
tx_first_key_image,
|
||||||
|
enote_proposals,
|
||||||
|
encrypted_payment_id);
|
||||||
|
|
||||||
|
ASSERT_EQ(2, enote_proposals.size()); // 2-out tx
|
||||||
|
|
||||||
|
// collect enotes
|
||||||
|
std::vector<CarrotEnoteV1> enotes;
|
||||||
|
for (const RCTOutputEnoteProposal &enote_proposal : enote_proposals)
|
||||||
|
enotes.push_back(enote_proposal.enote);
|
||||||
|
|
||||||
|
// check that alice scanned 1 enote
|
||||||
|
std::vector<unittest_carrot_scan_result_t> alice_scan_vec;
|
||||||
|
unittest_scan_enote_set(enotes, encrypted_payment_id, alice, alice_scan_vec);
|
||||||
|
ASSERT_EQ(1, alice_scan_vec.size());
|
||||||
|
unittest_carrot_scan_result_t alice_scan = alice_scan_vec.front();
|
||||||
|
|
||||||
|
// check that bob scanned 1 enote
|
||||||
|
std::vector<unittest_carrot_scan_result_t> bob_scan_vec;
|
||||||
|
unittest_scan_enote_set(enotes, encrypted_payment_id, bob, bob_scan_vec);
|
||||||
|
ASSERT_EQ(1, bob_scan_vec.size());
|
||||||
|
unittest_carrot_scan_result_t bob_scan = bob_scan_vec.front();
|
||||||
|
|
||||||
|
// set named references to enotes
|
||||||
|
ASSERT_TRUE((alice_scan.output_index == 0 && bob_scan.output_index == 1) ||
|
||||||
|
(alice_scan.output_index == 1 && bob_scan.output_index == 0));
|
||||||
|
const CarrotEnoteV1 &alice_enote = enotes.at(alice_scan.output_index);
|
||||||
|
const CarrotEnoteV1 &bob_enote = enotes.at(bob_scan.output_index);
|
||||||
|
|
||||||
|
// check Alice's recovered data
|
||||||
|
EXPECT_EQ(alice_payment_proposal.destination_address_spend_pubkey, alice_scan.address_spend_pubkey);
|
||||||
|
EXPECT_EQ(alice_payment_proposal.amount, alice_scan.amount);
|
||||||
|
EXPECT_EQ(alice_enote.amount_commitment, rct::commit(alice_scan.amount, rct::sk2rct(alice_scan.amount_blinding_factor)));
|
||||||
|
EXPECT_EQ(null_payment_id, alice_scan.payment_id);
|
||||||
|
EXPECT_EQ(alice_payment_proposal.enote_type, alice_scan.enote_type);
|
||||||
|
|
||||||
|
// check Bob's recovered data
|
||||||
|
EXPECT_EQ(bob_payment_proposal.destination.address_spend_pubkey, bob_scan.address_spend_pubkey);
|
||||||
|
EXPECT_EQ(bob_payment_proposal.amount, bob_scan.amount);
|
||||||
|
EXPECT_EQ(bob_enote.amount_commitment, rct::commit(bob_scan.amount, rct::sk2rct(bob_scan.amount_blinding_factor)));
|
||||||
|
EXPECT_EQ(bob_address.payment_id, bob_scan.payment_id); // DIFFERENT FROM MAIN
|
||||||
|
EXPECT_EQ(CarrotEnoteType::PAYMENT, bob_scan.enote_type);
|
||||||
|
|
||||||
|
// check Alice spendability
|
||||||
|
EXPECT_TRUE(can_open_fcmp_onetime_address(alice.k_prove_spend,
|
||||||
|
alice.k_generate_image,
|
||||||
|
crypto::secret_key{{1}},
|
||||||
|
alice_scan.sender_extension_g,
|
||||||
|
alice_scan.sender_extension_t,
|
||||||
|
alice_enote.onetime_address));
|
||||||
|
|
||||||
|
// check Bob spendability
|
||||||
|
EXPECT_TRUE(can_open_fcmp_onetime_address(bob.k_prove_spend,
|
||||||
|
bob.k_generate_image,
|
||||||
|
crypto::secret_key{{1}},
|
||||||
|
bob_scan.sender_extension_g,
|
||||||
|
bob_scan.sender_extension_t,
|
||||||
|
bob_enote.onetime_address));
|
||||||
|
}
|
||||||
|
//----------------------------------------------------------------------------------------------------------------------
|
||||||
|
Loading…
Reference in New Issue
Block a user