From 8f75944f51aa909f1d905067ee3e9ee74554014b Mon Sep 17 00:00:00 2001 From: Naohiro Yoshida Date: Tue, 27 Feb 2024 08:10:30 +0900 Subject: [PATCH] fix Signed-off-by: Naohiro Yoshida --- light-client/src/commitment.rs | 28 +++++++++++++++++++++++++++- light-client/src/errors.rs | 14 ++++++++++---- 2 files changed, 37 insertions(+), 5 deletions(-) diff --git a/light-client/src/commitment.rs b/light-client/src/commitment.rs index 2451c94..20b50f3 100644 --- a/light-client/src/commitment.rs +++ b/light-client/src/commitment.rs @@ -54,13 +54,14 @@ pub fn verify_proof( let expected_value = expected_value .as_ref() - .map(|e| rlp::encode(&trim_left_zero(e).to_vec()).to_vec()); + .map(|e| rlp::encode(&trim_left_zero(e)).to_vec()); if value != expected_value { return Err(Error::UnexpectedStateValue( *root, proof.to_vec(), expected_value, key.to_vec(), + value, )); } Ok(()) @@ -96,6 +97,7 @@ mod test { calculate_ibc_commitment_storage_key, decode_eip1184_rlp_proof, resolve_account, trim_left_zero, verify_proof, }; + use crate::errors::Error; use crate::misc::{Account, Hash}; #[test] @@ -131,6 +133,30 @@ mod test { } } + #[test] + fn test_verify_error() { + let key = hex!("0000000000000000000000000000000000000000000000000000000000000000"); + let root = hex!("c5bbc7e086abad66f3d4b49cc39c27e4864834ce3d21d91692c513481bf9de1b"); + let proof = vec![ + hex!("f8518080a051c7191217d318e27eed8b8f0b2c81df8ad258037ecdb3ee8808ab982623adba8080808080808080a028e886a776e1a5ccaf6819bc26ae7f83616639014e9751eb8d68eaaac54966448080808080").to_vec(), + hex!("f7a0390decd9548b62a8d60345a988386fc84ba6bc95484008f6362f93160ef3e5639594ebed59a7f647152af99ef0fd8e3f7e81bd7b1fd7").to_vec(), + ]; + let expected = hex!("fbed59a7f647152af99ef0fd8e3f7e81bd7b1fd7"); + match verify_proof(&root, &proof, &key, &Some(expected.to_vec())).unwrap_err() { + Error::UnexpectedStateValue(e1, e2, e3, e4, e5) => { + assert_eq!(root, e1); + assert_eq!(proof, e2); + assert_eq!(rlp::encode(&expected.as_slice()), e3.unwrap()); + assert_eq!(key, e4.as_slice()); + assert_eq!( + rlp::encode(&hex!("ebed59a7f647152af99ef0fd8e3f7e81bd7b1fd7").as_slice()), + e5.unwrap() + ); + } + err => unreachable!("{:?}", err), + } + } + #[test] fn test_verify_commitment_with_lcp_data() { let storage_root: Hash = [ diff --git a/light-client/src/errors.rs b/light-client/src/errors.rs index db1d934..8de2645 100644 --- a/light-client/src/errors.rs +++ b/light-client/src/errors.rs @@ -32,7 +32,13 @@ pub enum Error { // ConsensusState error AccountNotFound(Address), - UnexpectedStateValue(Hash, Vec>, Option>, Vec), + UnexpectedStateValue( + Hash, + Vec>, + Option>, + Vec, + Option>, + ), IllegalTimestamp(Time, Time), UnexpectedStateRoot(Vec), UnexpectedStorageRoot(Vec), @@ -191,11 +197,11 @@ impl core::fmt::Display for Error { write!(f, "UnexpectedSameBlockHash : {}", e1) } Error::UnknownMisbehaviourType(e1) => write!(f, "UnknownMisbehaviourType : {}", e1), - Error::UnexpectedStateValue(e1, e2, e3, e4) => { + Error::UnexpectedStateValue(e1, e2, e3, e4, e5) => { write!( f, - "UnexpectedStateValue : {:?} {:?} {:?} {:?}", - e1, e2, e3, e4 + "UnexpectedStateValue : {:?} {:?} {:?} {:?} {:?}", + e1, e2, e3, e4, e5 ) } Error::TrieError(e1) => {