2022-12-09 15:58:11 +00:00
|
|
|
use monero_serai::{rpc::Rpc, wallet::TransactionError, transaction::Transaction};
|
|
|
|
|
|
|
|
mod runner;
|
|
|
|
|
|
|
|
test!(
|
|
|
|
add_single_data_less_than_255,
|
|
|
|
(
|
|
|
|
|_, mut builder: Builder, addr| async move {
|
2023-01-01 09:18:23 +00:00
|
|
|
let arbitrary_data = vec![b'\0', 254];
|
2022-12-09 15:58:11 +00:00
|
|
|
|
|
|
|
// make sure we can add to tx
|
|
|
|
let result = builder.add_data(arbitrary_data.clone());
|
|
|
|
assert!(result.is_ok());
|
|
|
|
|
|
|
|
builder.add_payment(addr, 5);
|
|
|
|
(builder.build().unwrap(), (arbitrary_data,))
|
|
|
|
},
|
2023-01-01 09:18:23 +00:00
|
|
|
|rpc: Rpc, signed: Transaction, mut scanner: Scanner, data: (Vec<u8>,)| async move {
|
2022-12-09 15:58:11 +00:00
|
|
|
let tx = rpc.get_transaction(signed.hash()).await.unwrap();
|
|
|
|
let output = scanner.scan_transaction(&tx).not_locked().swap_remove(0);
|
|
|
|
assert_eq!(output.commitment().amount, 5);
|
2023-01-01 09:18:23 +00:00
|
|
|
assert_eq!(output.arbitrary_data()[0], data.0);
|
2022-12-09 15:58:11 +00:00
|
|
|
},
|
|
|
|
),
|
|
|
|
);
|
|
|
|
|
|
|
|
test!(
|
|
|
|
add_multiple_data_less_than_255,
|
|
|
|
(
|
|
|
|
|_, mut builder: Builder, addr| async move {
|
2023-01-01 09:18:23 +00:00
|
|
|
let data = vec![b'\0', 254];
|
2022-12-09 15:58:11 +00:00
|
|
|
|
2023-01-01 09:18:23 +00:00
|
|
|
// Add tx multiple times
|
2022-12-09 15:58:11 +00:00
|
|
|
for _ in 0 .. 5 {
|
2023-01-01 09:18:23 +00:00
|
|
|
let result = builder.add_data(data.clone());
|
2022-12-09 15:58:11 +00:00
|
|
|
assert!(result.is_ok());
|
|
|
|
}
|
|
|
|
|
|
|
|
builder.add_payment(addr, 5);
|
2023-01-01 09:18:23 +00:00
|
|
|
(builder.build().unwrap(), data)
|
2022-12-09 15:58:11 +00:00
|
|
|
},
|
2023-01-01 09:18:23 +00:00
|
|
|
|rpc: Rpc, signed: Transaction, mut scanner: Scanner, data: Vec<u8>| async move {
|
2022-12-09 15:58:11 +00:00
|
|
|
let tx = rpc.get_transaction(signed.hash()).await.unwrap();
|
|
|
|
let output = scanner.scan_transaction(&tx).not_locked().swap_remove(0);
|
|
|
|
assert_eq!(output.commitment().amount, 5);
|
2023-01-01 09:18:23 +00:00
|
|
|
assert_eq!(output.arbitrary_data(), vec![data; 5]);
|
2022-12-09 15:58:11 +00:00
|
|
|
},
|
|
|
|
),
|
|
|
|
);
|
|
|
|
|
|
|
|
test!(
|
|
|
|
add_single_data_more_than_255,
|
|
|
|
(
|
|
|
|
|_, mut builder: Builder, addr| async move {
|
2023-01-01 09:18:23 +00:00
|
|
|
// Make a data that is bigger than 255 bytes
|
|
|
|
let mut data = vec![b'a'; 256];
|
2022-12-09 15:58:11 +00:00
|
|
|
|
2023-01-01 09:18:23 +00:00
|
|
|
// Make sure we get an error if we try to add it to the TX
|
|
|
|
assert_eq!(builder.add_data(data.clone()), Err(TransactionError::TooMuchData));
|
2022-12-09 15:58:11 +00:00
|
|
|
|
2023-01-01 09:18:23 +00:00
|
|
|
// Reduce data size and retry. The data will now be 255 bytes long, exactly
|
|
|
|
data.pop();
|
|
|
|
assert!(builder.add_data(data.clone()).is_ok());
|
2022-12-09 15:58:11 +00:00
|
|
|
|
2023-01-01 09:18:23 +00:00
|
|
|
builder.add_payment(addr, 5);
|
|
|
|
(builder.build().unwrap(), data)
|
|
|
|
},
|
|
|
|
|rpc: Rpc, signed: Transaction, mut scanner: Scanner, data: Vec<u8>| async move {
|
|
|
|
let tx = rpc.get_transaction(signed.hash()).await.unwrap();
|
|
|
|
let output = scanner.scan_transaction(&tx).not_locked().swap_remove(0);
|
|
|
|
assert_eq!(output.commitment().amount, 5);
|
|
|
|
assert_eq!(output.arbitrary_data(), vec![data]);
|
2022-12-09 15:58:11 +00:00
|
|
|
},
|
|
|
|
),
|
|
|
|
);
|