Skip to content

Commit 078ae44

Browse files
fix: block deserialization (#45)
* added temp test * fix: CoinbasePayload.best_cl_signature as BLSSignature * fix: CoinbasePayload.best_cl_height as compactsize * small fix --------- Co-authored-by: Odysseas Gabrielides <odysseas.gabrielides@gmail.com>
1 parent eb700ae commit 078ae44

File tree

4 files changed

+67
-8
lines changed

4 files changed

+67
-8
lines changed

Cargo.lock

Lines changed: 1 addition & 1 deletion
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

dash/Cargo.toml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
[package]
22
name = "dashcore"
3-
version = "0.33.1"
3+
version = "0.33.2"
44
authors = [
55
"Samuel Westrich <sam@dash.org>",
66
"Anton Suprunchuk <anton@dash.org>",

dash/src/blockdata/block.rs

Lines changed: 52 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -466,6 +466,58 @@ mod tests {
466466
assert_eq!(serialize(&real_decode), some_block);
467467
}
468468

469+
#[test]
470+
fn block_test_2() {
471+
472+
let some_block = hex!(
473+
"000000200ec684405b58b3a0f0144c9a92c7d4296587ba6fc71041fff2130a038a00000078e259b490cfc8a8e50e1933afde3f777a47bdac8b61d504a51b68dede2ac181cd0822679008011e2e0506000103000500010000000000000000000000000000000000000000000000000000000000000000ffffffff06031e42110101ffffffff037a681d04000000001976a914c69a0bda7daaae481be8def95e5f347a1d00a4b488ac8815a10400000000016ae523b707000000001976a91464f2b2b84f62d68a2cd7f7f5fb2b5aa75ef716d788ac00000000af03001e421100032459005e51c0c2180b5a06001eacee43e1ab9a169dc0c9fb8ca40506258fed68c5aa969c10a3015bde2cfbe1700c795f97a4fa3946e9de4decc14d3a2117be00b695cd60fa9339a8318b65dab7a8a45655ffc6daf0ff1b0b19958903460613f92ac911f3b80bf71bfaeff3968aff87dd0750233a73145f913a3a2a9b1ddaca1ef8f14738870767a80d539ad639837dff1140f78b8f4d65eb4216b7128b736a2453afd99ce4040000"
474+
);
475+
let cutoff_block = hex!(
476+
"010000004ddccd549d28f385ab457e98d1b11ce80bfea2c5ab93015ade4973e400000000bf4473e53794beae34e64fccc471dace6ae544180816f89591894e0f417a914cd74d6e49ffff001d323b3a7b0201000000010000000000000000000000000000000000000000000000000000000000000000ffffffff0804ffff001d026e04ffffffff0100f2052a0100000043410446ef0102d1ec5240f0d061a4246c1bdef63fc3dbab7733052fbbf0ecd8f41fc26bf049ebb4f9527f374280259e7cfa99c48b0e3f39c51347a19a5819651503a5ac00000000010000000321f75f3139a013f50f315b23b0c9a2b6eac31e2bec98e5891c924664889942260000000049483045022100cb2c6b346a978ab8c61b18b5e9397755cbd17d6eb2fe0083ef32e067fa6c785a02206ce44e613f31d9a6b0517e46f3db1576e9812cc98d159bfdaf759a5014081b5c01ffffffff79cda0945903627c3da1f85fc95d0b8ee3e76ae0cfdc9a65d09744b1f8fc85430000000049483045022047957cdd957cfd0becd642f6b84d82f49b6cb4c51a91f49246908af7c3cfdf4a022100e96b46621f1bffcf5ea5982f88cef651e9354f5791602369bf5a82a6cd61a62501fffffffffe09f5fe3ffbf5ee97a54eb5e5069e9da6b4856ee86fc52938c2f979b0f38e82000000004847304402204165be9a4cbab8049e1af9723b96199bfd3e85f44c6b4c0177e3962686b26073022028f638da23fc003760861ad481ead4099312c60030d4cb57820ce4d33812a5ce01ffffffff01009d966b01000000434104ea1feff861b51fe3f5f8a3b12d0f4712db80e919548a80839fc47c6a21e66d957e9c5d8cd108c7a2d2324bad71f9904ac0ae7336507d785b17a2c115e427a32fac"
477+
);
478+
479+
let prevhash = hex!("85691f6a060e65346c281ed25b99dbd18c139053562ccd001d00000000000000");
480+
let merkle = hex!("377b6aa24658b7a0ae7b73f0673d047a291de5cbc06907038b288b2ebf491c2c");
481+
482+
let work_bytes: [u8; 32] =
483+
hex!("000000000000000000000000000000000000000000000000050ec30af44bf25e")
484+
.try_into()
485+
.unwrap();
486+
let work = Work::from_be_bytes(work_bytes);
487+
488+
let real_decode: Block = deserialize(&some_block).expect("issue here");
489+
let bad_decode: Result<Block, _> = deserialize(&cutoff_block);
490+
491+
assert!(bad_decode.is_err());
492+
assert_eq!(real_decode.header.version, Version(536870912));
493+
assert_eq!(serialize(&real_decode.header.prev_blockhash), prevhash);
494+
assert_eq!(real_decode.header.merkle_root, real_decode.compute_merkle_root().unwrap());
495+
assert_eq!(serialize(&real_decode.header.merkle_root), merkle);
496+
assert_eq!(real_decode.header.time, 1685447065);
497+
assert_eq!(real_decode.header.bits, CompactTarget::from_consensus(422747587));
498+
assert_eq!(real_decode.header.nonce, 2456102546);
499+
assert_eq!(real_decode.header.work(), work);
500+
assert_eq!(
501+
real_decode.header.validate_pow(real_decode.header.target()).unwrap(),
502+
real_decode.block_hash()
503+
);
504+
assert_eq!(real_decode.header.difficulty(), 84852220);
505+
assert_eq!(real_decode.header.difficulty_float(), 84852220.19239795);
506+
// [test] TODO: check the transaction data
507+
508+
assert_eq!(real_decode.size(), some_block.len());
509+
assert_eq!(real_decode.strippedsize(), some_block.len());
510+
assert_eq!(
511+
real_decode.weight(),
512+
Weight::from_non_witness_data_size(some_block.len() as u64)
513+
);
514+
515+
// should be also ok for a non-witness block as commitment is optional in that case
516+
assert!(real_decode.check_witness_commitment());
517+
518+
assert_eq!(serialize(&real_decode), some_block);
519+
}
520+
469521
// Check testnet block 000000000000045e0b1660b6445b5e5c5ab63c9a4f956be7e1e69be04fa4497b
470522
#[ignore]
471523
#[test]

dash/src/blockdata/transaction/special_transaction/coinbase.rs

Lines changed: 13 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -21,8 +21,8 @@
2121
use crate::consensus::{Decodable, Encodable, encode};
2222
use crate::hash_types::{MerkleRootMasternodeList, MerkleRootQuorums};
2323
use crate::io::{Error, ErrorKind};
24-
use crate::prelude::Vec;
2524
use crate::{VarInt, io};
25+
use crate::bls_sig_utils::BLSSignature;
2626

2727
/// A Coinbase payload. This is contained as the payload of a coinbase special transaction.
2828
/// The Coinbase payload is described in DIP4.
@@ -36,7 +36,7 @@ pub struct CoinbasePayload {
3636
pub merkle_root_masternode_list: MerkleRootMasternodeList,
3737
pub merkle_root_quorums: MerkleRootQuorums,
3838
pub best_cl_height: Option<u32>,
39-
pub best_cl_signature: Option<Vec<u8>>,
39+
pub best_cl_signature: Option<BLSSignature>,
4040
pub asset_locked_amount: Option<u64>,
4141
}
4242

@@ -93,9 +93,16 @@ impl Decodable for CoinbasePayload {
9393
let height = u32::consensus_decode(r)?;
9494
let merkle_root_masternode_list = MerkleRootMasternodeList::consensus_decode(r)?;
9595
let merkle_root_quorums = MerkleRootQuorums::consensus_decode(r)?;
96-
let best_cl_height = if version >= 3 { Some(u32::consensus_decode(r)?) } else { None };
96+
let best_cl_height = if version >= 3 {
97+
let value = u8::consensus_decode(r)?;
98+
match value {
99+
253 => Some(u16::consensus_decode(r)? as u32),
100+
254 => Some(u32::consensus_decode(r)?),
101+
_ => Some(value as u32)
102+
}
103+
} else { None };
97104
let best_cl_signature =
98-
if version >= 3 { Some(Vec::<u8>::consensus_decode(r)?) } else { None };
105+
if version >= 3 { Some(BLSSignature::consensus_decode(r)?) } else { None };
99106
let asset_locked_amount = if version >= 3 { Some(u64::consensus_decode(r)?) } else { None };
100107
Ok(CoinbasePayload {
101108
version,
@@ -112,7 +119,7 @@ impl Decodable for CoinbasePayload {
112119
#[cfg(test)]
113120
mod tests {
114121
use hashes::Hash;
115-
122+
use crate::bls_sig_utils::BLSSignature;
116123
use crate::consensus::Encodable;
117124
use crate::hash_types::{MerkleRootMasternodeList, MerkleRootQuorums};
118125
use crate::transaction::special_transaction::coinbase::CoinbasePayload;
@@ -127,7 +134,7 @@ mod tests {
127134
merkle_root_masternode_list: MerkleRootMasternodeList::all_zeros(),
128135
merkle_root_quorums: MerkleRootQuorums::all_zeros(),
129136
best_cl_height: Some(900),
130-
best_cl_signature: Some(vec![0; 96]),
137+
best_cl_signature: Some(BLSSignature::from([0; 96])),
131138
asset_locked_amount: Some(10000),
132139
};
133140
assert_eq!(payload.size(), *want);

0 commit comments

Comments
 (0)