Compare commits

..

6 commits

Author SHA1 Message Date
hinto.janai
d816a0100c
clsag bulletproofs plus tx test
Some checks are pending
Audit / audit (push) Waiting to run
Deny / audit (push) Waiting to run
2024-09-30 21:04:50 -04:00
hinto.janai
10558c05d4
clsag bulletproofs tx test 2024-09-30 20:50:10 -04:00
hinto.janai
208039bc35
add tx_v1, tx_rct_3 test 2024-09-30 20:44:43 -04:00
hinto.janai
4b98bb2e56
add ringct types 2024-09-30 20:08:15 -04:00
hinto.janai
c3481dc393
add block value tests 2024-09-30 16:43:50 -04:00
hinto.janai
cc078b693b
fix tx timelock 2024-09-30 16:21:02 -04:00
4 changed files with 1308 additions and 640 deletions

1
Cargo.lock generated
View file

@ -891,6 +891,7 @@ dependencies = [
"cuprate-helper", "cuprate-helper",
"curve25519-dalek", "curve25519-dalek",
"hex", "hex",
"hex-literal",
"monero-serai", "monero-serai",
"paste", "paste",
"pretty_assertions", "pretty_assertions",

View file

@ -34,6 +34,7 @@ proptest = { workspace = true, optional = true }
proptest-derive = { workspace = true, optional = true } proptest-derive = { workspace = true, optional = true }
[dev-dependencies] [dev-dependencies]
hex-literal = { workspace = true }
pretty_assertions = { workspace = true } pretty_assertions = { workspace = true }
serde_json = { workspace = true, features = ["std"] } serde_json = { workspace = true, features = ["std"] }

View file

@ -117,12 +117,10 @@ impl TryFrom<transaction::Transaction> for MinerTransaction {
.collect(); .collect();
let unlock_time = match prefix.additional_timelock { let unlock_time = match prefix.additional_timelock {
transaction::Timelock::None => height, transaction::Timelock::None => 0,
transaction::Timelock::Block(height_lock) => height + usize_to_u64(height_lock), transaction::Timelock::Block(x) => usize_to_u64(x),
transaction::Timelock::Time(seconds) => { transaction::Timelock::Time(x) => x,
height + (seconds / usize_to_u64(monero_serai::BLOCK_TIME)) };
}
} + usize_to_u64(monero_serai::DEFAULT_LOCK_WINDOW);
Ok(MinerTransactionPrefix { Ok(MinerTransactionPrefix {
version, version,
@ -203,217 +201,159 @@ pub struct Gen {
#[cfg(test)] #[cfg(test)]
mod test { mod test {
use hex_literal::hex;
use pretty_assertions::assert_eq; use pretty_assertions::assert_eq;
use super::*; use super::*;
const BLOCK_300000_JSON: &str = r#"{ #[expect(clippy::needless_pass_by_value)]
"major_version": 1, fn test(block: Block, block_json: &'static str) {
"minor_version": 0,
"timestamp": 1415690591,
"prev_id": "e97a0ab6307de9b9f9a9872263ef3e957976fb227eb9422c6854e989e5d5d34c",
"nonce": 2147484616,
"miner_tx": {
"version": 1,
"unlock_time": 300060,
"vin": [
{
"gen": {
"height": 300000
}
}
],
"vout": [
{
"amount": 47019296802,
"target": {
"key": "3c1dcbf5b485987ecef4596bb700e32cbc7bd05964e3888ffc05f8a46bf5fc33"
}
},
{
"amount": 200000000000,
"target": {
"key": "5810afc7a1b01a1c913eb6aab15d4a851cbc4a8cf0adf90bb80ac1a7ca9928aa"
}
},
{
"amount": 3000000000000,
"target": {
"key": "520f49c5f2ce8456dc1a565f35ed3a5ccfff3a1210b340870a57d2749a81a2df"
}
},
{
"amount": 10000000000000,
"target": {
"key": "44d7705e62c76c2e349a474df6724aa1d9932092002b03a94f9c19d9d12b9427"
}
}
],
"extra": [
1,
251,
8,
189,
254,
12,
213,
173,
108,
61,
156,
198,
144,
151,
31,
130,
141,
211,
120,
55,
81,
98,
32,
247,
111,
127,
254,
170,
170,
240,
124,
190,
223,
2,
8,
0,
0,
0,
64,
184,
115,
46,
246
],
"signatures": []
},
"tx_hashes": []
}"#;
const BLOCK_3245409_JSON: &str = r#"{
"major_version": 16,
"minor_version": 16,
"timestamp": 1727293028,
"prev_id": "41b56c273d69def3294e56179de71c61808042d54c1e085078d21dbe99e81b6f",
"nonce": 311,
"miner_tx": {
"version": 2,
"unlock_time": 3245469,
"vin": [
{
"gen": {
"height": 3245409
}
}
],
"vout": [
{
"amount": 601012280000,
"target": {
"tagged_key": {
"key": "8c0b16c6df02b9944b49f375d96a958a0fc5431c048879bb5bf25f64a1163b9e",
"view_tag": "88"
}
}
}
],
"extra": [
1,
39,
23,
182,
203,
58,
48,
15,
217,
9,
13,
147,
104,
133,
206,
176,
185,
56,
237,
179,
136,
72,
84,
129,
113,
98,
206,
4,
18,
50,
130,
162,
94,
2,
17,
73,
18,
21,
33,
32,
112,
5,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0
],
"rct_signatures": {
"type": 0
}
},
"tx_hashes": [
"eab76986a0cbcae690d8499f0f616f783fd2c89c6f611417f18011950dbdab2e",
"57b19aa8c2cdbb6836cf13dd1e321a67860965c12e4418f3c30f58c8899a851e",
"5340185432ab6b74fb21379f7e8d8f0e37f0882b2a7121fd7c08736f079e2edc",
"01dc6d31db56d68116f5294c1b4f80b33b048b5cdfefcd904f23e6c0de3daff5",
"c9fb6a2730678203948fef2a49fa155b63f35a3649f3d32ed405a6806f3bbd56",
"af965cdd2a2315baf1d4a3d242f44fe07b1fd606d5f4853c9ff546ca6c12a5af",
"97bc9e047d25fae8c14ce6ec882224e7b722f5e79b62a2602a6bacebdac8547b",
"28c46992eaf10dc0cceb313c30572d023432b7bd26e85e679bc8fe419533a7bf",
"c32e3acde2ff2885c9cc87253b40d6827d167dfcc3022c72f27084fd98788062",
"19e66a47f075c7cccde8a7b52803119e089e33e3a4847cace0bd1d17b0d22bab",
"8e8ac560e77a1ee72e82a5eb6887adbe5979a10cd29cb2c2a3720ce87db43a70",
"b7ff5141524b5cca24de6780a5dbfdf71e7de1e062fd85f557fb3b43b8e285dc",
"f09df0f113763ef9b9a2752ac293b478102f7cab03ef803a3d9db7585aea8912"
]
}"#;
fn test(block_json: &'static str) {
let json = serde_json::from_str::<Block>(block_json).unwrap(); let json = serde_json::from_str::<Block>(block_json).unwrap();
let string = serde_json::to_string_pretty(&json).unwrap(); assert_eq!(block, json);
let string = serde_json::to_string(&json).unwrap();
assert_eq!(block_json, &string); assert_eq!(block_json, &string);
} }
#[test] #[test]
fn block_300000() { fn block_300000() {
test(BLOCK_300000_JSON); const JSON: &str = r#"{"major_version":1,"minor_version":0,"timestamp":1415690591,"prev_id":"e97a0ab6307de9b9f9a9872263ef3e957976fb227eb9422c6854e989e5d5d34c","nonce":2147484616,"miner_tx":{"version":1,"unlock_time":300060,"vin":[{"gen":{"height":300000}}],"vout":[{"amount":47019296802,"target":{"key":"3c1dcbf5b485987ecef4596bb700e32cbc7bd05964e3888ffc05f8a46bf5fc33"}},{"amount":200000000000,"target":{"key":"5810afc7a1b01a1c913eb6aab15d4a851cbc4a8cf0adf90bb80ac1a7ca9928aa"}},{"amount":3000000000000,"target":{"key":"520f49c5f2ce8456dc1a565f35ed3a5ccfff3a1210b340870a57d2749a81a2df"}},{"amount":10000000000000,"target":{"key":"44d7705e62c76c2e349a474df6724aa1d9932092002b03a94f9c19d9d12b9427"}}],"extra":[1,251,8,189,254,12,213,173,108,61,156,198,144,151,31,130,141,211,120,55,81,98,32,247,111,127,254,170,170,240,124,190,223,2,8,0,0,0,64,184,115,46,246],"signatures":[]},"tx_hashes":[]}"#;
let block = Block {
major_version: 1,
minor_version: 0,
timestamp: 1415690591,
prev_id: HexBytes32(hex!(
"e97a0ab6307de9b9f9a9872263ef3e957976fb227eb9422c6854e989e5d5d34c"
)),
nonce: 2147484616,
miner_tx: MinerTransaction::V1 {
prefix: MinerTransactionPrefix {
version: 1,
unlock_time: 300060,
vin: [Input {
r#gen: Gen { height: 300000 },
}],
vout: vec![
Output {
amount: 47019296802,
target: Target::Key {
key: HexBytes32(hex!("3c1dcbf5b485987ecef4596bb700e32cbc7bd05964e3888ffc05f8a46bf5fc33")),
}
},
Output {
amount: 200000000000,
target: Target::Key {
key: HexBytes32(hex!("5810afc7a1b01a1c913eb6aab15d4a851cbc4a8cf0adf90bb80ac1a7ca9928aa")),
}
},
Output {
amount: 3000000000000,
target: Target::Key {
key: HexBytes32(hex!("520f49c5f2ce8456dc1a565f35ed3a5ccfff3a1210b340870a57d2749a81a2df")),
}
},
Output {
amount: 10000000000000,
target: Target::Key {
key: HexBytes32(hex!("44d7705e62c76c2e349a474df6724aa1d9932092002b03a94f9c19d9d12b9427")),
}
}
],
extra: vec![
1, 251, 8, 189, 254, 12, 213, 173, 108, 61, 156, 198, 144, 151, 31, 130,
141, 211, 120, 55, 81, 98, 32, 247, 111, 127, 254, 170, 170, 240, 124, 190,
223, 2, 8, 0, 0, 0, 64, 184, 115, 46, 246,
],
},
signatures: [],
},
tx_hashes: vec![],
};
test(block, JSON);
} }
#[test] #[test]
fn block_3245409() { fn block_3245409() {
test(BLOCK_3245409_JSON); const JSON: &str = r#"{"major_version":16,"minor_version":16,"timestamp":1727293028,"prev_id":"41b56c273d69def3294e56179de71c61808042d54c1e085078d21dbe99e81b6f","nonce":311,"miner_tx":{"version":2,"unlock_time":3245469,"vin":[{"gen":{"height":3245409}}],"vout":[{"amount":601012280000,"target":{"tagged_key":{"key":"8c0b16c6df02b9944b49f375d96a958a0fc5431c048879bb5bf25f64a1163b9e","view_tag":"88"}}}],"extra":[1,39,23,182,203,58,48,15,217,9,13,147,104,133,206,176,185,56,237,179,136,72,84,129,113,98,206,4,18,50,130,162,94,2,17,73,18,21,33,32,112,5,0,0,0,0,0,0,0,0,0,0],"rct_signatures":{"type":0}},"tx_hashes":["eab76986a0cbcae690d8499f0f616f783fd2c89c6f611417f18011950dbdab2e","57b19aa8c2cdbb6836cf13dd1e321a67860965c12e4418f3c30f58c8899a851e","5340185432ab6b74fb21379f7e8d8f0e37f0882b2a7121fd7c08736f079e2edc","01dc6d31db56d68116f5294c1b4f80b33b048b5cdfefcd904f23e6c0de3daff5","c9fb6a2730678203948fef2a49fa155b63f35a3649f3d32ed405a6806f3bbd56","af965cdd2a2315baf1d4a3d242f44fe07b1fd606d5f4853c9ff546ca6c12a5af","97bc9e047d25fae8c14ce6ec882224e7b722f5e79b62a2602a6bacebdac8547b","28c46992eaf10dc0cceb313c30572d023432b7bd26e85e679bc8fe419533a7bf","c32e3acde2ff2885c9cc87253b40d6827d167dfcc3022c72f27084fd98788062","19e66a47f075c7cccde8a7b52803119e089e33e3a4847cace0bd1d17b0d22bab","8e8ac560e77a1ee72e82a5eb6887adbe5979a10cd29cb2c2a3720ce87db43a70","b7ff5141524b5cca24de6780a5dbfdf71e7de1e062fd85f557fb3b43b8e285dc","f09df0f113763ef9b9a2752ac293b478102f7cab03ef803a3d9db7585aea8912"]}"#;
let block = Block {
major_version: 16,
minor_version: 16,
timestamp: 1727293028,
prev_id: HexBytes32(hex!(
"41b56c273d69def3294e56179de71c61808042d54c1e085078d21dbe99e81b6f"
)),
nonce: 311,
miner_tx: MinerTransaction::V2 {
prefix: MinerTransactionPrefix {
version: 2,
unlock_time: 3245469,
vin: [Input {
r#gen: Gen { height: 3245409 },
}],
vout: vec![Output {
amount: 601012280000,
target: Target::TaggedKey {
tagged_key: TaggedKey {
key: HexBytes32(hex!(
"8c0b16c6df02b9944b49f375d96a958a0fc5431c048879bb5bf25f64a1163b9e"
)),
view_tag: HexBytes1(hex!("88")),
},
},
}],
extra: vec![
1, 39, 23, 182, 203, 58, 48, 15, 217, 9, 13, 147, 104, 133, 206, 176, 185,
56, 237, 179, 136, 72, 84, 129, 113, 98, 206, 4, 18, 50, 130, 162, 94, 2,
17, 73, 18, 21, 33, 32, 112, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
],
},
rct_signatures: MinerTransactionRctSignatures { r#type: 0 },
},
tx_hashes: vec![
HexBytes32(hex!(
"eab76986a0cbcae690d8499f0f616f783fd2c89c6f611417f18011950dbdab2e"
)),
HexBytes32(hex!(
"57b19aa8c2cdbb6836cf13dd1e321a67860965c12e4418f3c30f58c8899a851e"
)),
HexBytes32(hex!(
"5340185432ab6b74fb21379f7e8d8f0e37f0882b2a7121fd7c08736f079e2edc"
)),
HexBytes32(hex!(
"01dc6d31db56d68116f5294c1b4f80b33b048b5cdfefcd904f23e6c0de3daff5"
)),
HexBytes32(hex!(
"c9fb6a2730678203948fef2a49fa155b63f35a3649f3d32ed405a6806f3bbd56"
)),
HexBytes32(hex!(
"af965cdd2a2315baf1d4a3d242f44fe07b1fd606d5f4853c9ff546ca6c12a5af"
)),
HexBytes32(hex!(
"97bc9e047d25fae8c14ce6ec882224e7b722f5e79b62a2602a6bacebdac8547b"
)),
HexBytes32(hex!(
"28c46992eaf10dc0cceb313c30572d023432b7bd26e85e679bc8fe419533a7bf"
)),
HexBytes32(hex!(
"c32e3acde2ff2885c9cc87253b40d6827d167dfcc3022c72f27084fd98788062"
)),
HexBytes32(hex!(
"19e66a47f075c7cccde8a7b52803119e089e33e3a4847cace0bd1d17b0d22bab"
)),
HexBytes32(hex!(
"8e8ac560e77a1ee72e82a5eb6887adbe5979a10cd29cb2c2a3720ce87db43a70"
)),
HexBytes32(hex!(
"b7ff5141524b5cca24de6780a5dbfdf71e7de1e062fd85f557fb3b43b8e285dc"
)),
HexBytes32(hex!(
"f09df0f113763ef9b9a2752ac293b478102f7cab03ef803a3d9db7585aea8912"
)),
],
};
test(block, JSON);
} }
} }

File diff suppressed because one or more lines are too long