From 6f191046079200cc02902397958a539e03eb8899 Mon Sep 17 00:00:00 2001 From: aidan46 Date: Tue, 26 Nov 2024 13:47:45 +0800 Subject: [PATCH] feat(sp): Add batch event for faulty partitions --- .../architecture/pallets/storage-provider.md | 5 +-- pallets/storage-provider/src/lib.rs | 40 ++++++++++-------- .../storage-provider/src/tests/post_hook.rs | 12 ++++-- .../src/tests/pre_commit_sector_hook.rs | 11 +++-- storagext/lib/artifacts/metadata.scale | Bin 163504 -> 163530 bytes .../src/runtime/display/storage_provider.rs | 18 +++++--- 6 files changed, 53 insertions(+), 33 deletions(-) diff --git a/docs/src/architecture/pallets/storage-provider.md b/docs/src/architecture/pallets/storage-provider.md index 0ee5971ff..b8fe02a5f 100644 --- a/docs/src/architecture/pallets/storage-provider.md +++ b/docs/src/architecture/pallets/storage-provider.md @@ -343,10 +343,9 @@ The Storage Provider Pallet emits the following events: - `deadline` - The deadline to which the recovered sectors are assigned. - `partition` - Partition number within the deadline containing the recovered sectors. - `sectors` - Sectors in the partition being declared as recovered. -- `PartitionFaulty` - It was detected that a storage provider has not submitted their PoSt on time and has marked some sectors as faulty. +- `PartitionsFaulty` - It was detected that a storage provider has not submitted their PoSt on time and has marked some partitions and sectors as faulty. - `owner` - SS58 address of the storage provider. - - `partition` - Partition number for which the PoSt was missed. - - `sectors` - The sectors in the partition declared faulty by the system. + - `faulty_partitions` - A map with partition numbers and the sectors associated with the partition number that are faulty. - `SectorsTerminated` - A storage provider has terminated some sectors. - `owner` - SS58 address of the storage provider. - `terminations` - An array with information about the terminated sectors. This information includes: diff --git a/pallets/storage-provider/src/lib.rs b/pallets/storage-provider/src/lib.rs index 3ba72c802..26c2dc0f1 100644 --- a/pallets/storage-provider/src/lib.rs +++ b/pallets/storage-provider/src/lib.rs @@ -35,7 +35,11 @@ pub mod pallet { extern crate alloc; - use alloc::{vec, vec::Vec}; + use alloc::{ + collections::{BTreeMap, BTreeSet}, + vec, + vec::Vec, + }; use core::fmt::Debug; use cid::Cid; @@ -293,10 +297,10 @@ pub mod pallet { recoveries: BoundedVec>, }, /// Emitted when an SP doesn't submit Windowed PoSt in time and PoSt hook marks partitions as faulty - PartitionFaulty { + PartitionsFaulty { owner: T::AccountId, - partition: PartitionNumber, - sectors: BoundedBTreeSet>, + // No need to be bounded as we are creating the sets ourselves + faulty_partitions: BTreeMap>, }, /// Emitted when an SP terminates some sectors. SectorsTerminated { @@ -1231,9 +1235,9 @@ pub mod pallet { } log::info!(target: LOG_TARGET, "block: {:?}, checking storage provider {:?} deadline: {:?}", - current_block, - storage_provider, - current_deadline.idx, + current_block, + storage_provider, + current_deadline.idx, ); let Ok(deadline) = @@ -1244,7 +1248,10 @@ pub mod pallet { continue; }; - let mut faulty_partitions = 0; + let mut faulty_partitions_amount = 0; + // Create collection for fault partitions, 1 event per SP + let mut faulty_partitions: BTreeMap> = + BTreeMap::new(); for (partition_number, partition) in deadline.partitions.iter_mut() { if partition.sectors.len() == 0 { continue; @@ -1278,24 +1285,23 @@ pub mod pallet { current_block, storage_provider, partition_number, new_faults.len()); if new_faults.len() > 0 { - Self::deposit_event(Event::PartitionFaulty { - owner: storage_provider.clone(), - partition: *partition_number, - sectors: new_faults.try_into() - .expect("new_faults.len() <= MAX_SECTORS, cannot be more new faults than all of the sectors in partition"), - }); - faulty_partitions += 1; + faulty_partitions.insert(*partition_number, new_faults); + faulty_partitions_amount += 1; } } // TODO(@th7nder,[#106,#187],08/08/2024): figure out slashing amounts (for continued faults, new faults). - if faulty_partitions > 0 { + if faulty_partitions_amount > 0 { log::warn!(target: LOG_TARGET, "block: {:?}, sp: {:?}, deadline: {:?} - should have slashed {} partitions...", current_block, storage_provider, current_deadline.idx, - faulty_partitions, + faulty_partitions_amount, ); + Self::deposit_event(Event::PartitionsFaulty { + owner: storage_provider.clone(), + faulty_partitions, + }) } else { log::info!(target: LOG_TARGET, "block: {:?}, sp: {:?}, deadline: {:?} - all proofs submitted on time.", current_block, diff --git a/pallets/storage-provider/src/tests/post_hook.rs b/pallets/storage-provider/src/tests/post_hook.rs index 1950979d3..aab3f8432 100644 --- a/pallets/storage-provider/src/tests/post_hook.rs +++ b/pallets/storage-provider/src/tests/post_hook.rs @@ -1,5 +1,7 @@ extern crate alloc; +use alloc::collections::{BTreeMap, BTreeSet}; + use frame_support::{assert_ok, pallet_prelude::Get}; use primitives_proofs::{DealId, SectorNumber}; use sp_core::bounded_vec; @@ -68,16 +70,18 @@ fn marks_partitions_as_faulty() { let partition = &deadline.partitions[&0]; let expected_sectors = sector_set::(&[first_sector_number, second_sector_number]); - + let faulty_sectors = BTreeSet::from([ + SectorNumber::new(first_sector_number).unwrap(), + SectorNumber::new(second_sector_number).unwrap(), + ]); assert_eq!(partition.faults.len(), 2); assert_eq!(expected_sectors, partition.faults); assert_eq!( events(), [RuntimeEvent::StorageProvider( - Event::::PartitionFaulty { + Event::::PartitionsFaulty { owner: account(storage_provider), - partition: 0, - sectors: expected_sectors.clone() + faulty_partitions: BTreeMap::from([(0u32, faulty_sectors)]), } ),] ); diff --git a/pallets/storage-provider/src/tests/pre_commit_sector_hook.rs b/pallets/storage-provider/src/tests/pre_commit_sector_hook.rs index 2bcc73cc9..85737c987 100644 --- a/pallets/storage-provider/src/tests/pre_commit_sector_hook.rs +++ b/pallets/storage-provider/src/tests/pre_commit_sector_hook.rs @@ -1,5 +1,8 @@ extern crate alloc; +use alloc::collections::{BTreeMap, BTreeSet}; + +use primitives_proofs::SectorNumber; use sp_core::bounded_vec; use super::new_test_ext; @@ -79,10 +82,12 @@ fn pre_commit_hook_slashed_deal() { assert_eq!( events(), [ - RuntimeEvent::StorageProvider(Event::::PartitionFaulty { + RuntimeEvent::StorageProvider(Event::::PartitionsFaulty { owner: account(storage_provider), - partition: 0, - sectors: sector_set(&[2]) + faulty_partitions: BTreeMap::from([( + 0, + BTreeSet::from([SectorNumber::new(2).unwrap()]) + )]), }), RuntimeEvent::StorageProvider(Event::::SectorSlashed { owner: account(storage_provider), diff --git a/storagext/lib/artifacts/metadata.scale b/storagext/lib/artifacts/metadata.scale index 39038327f429a42636881cc5f8cb06979df7cfeb..4e0ecf17cffa2b81032bc97ae60f3bf48035924f 100644 GIT binary patch delta 8764 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 H-a!5bcC+5& diff --git a/storagext/lib/src/runtime/display/storage_provider.rs b/storagext/lib/src/runtime/display/storage_provider.rs index 3b96f2f2c..42e7afb8c 100644 --- a/storagext/lib/src/runtime/display/storage_provider.rs +++ b/storagext/lib/src/runtime/display/storage_provider.rs @@ -115,16 +115,22 @@ impl std::fmt::Display for Event { ) .collect::() )), - Event::PartitionFaulty { + Event::PartitionsFaulty { owner, - partition, - sectors, + faulty_partitions, } => f.write_fmt(format_args!( - "Faulty Partition: {{ owner: {}, partition: {}, sectors: [{}] }}", + "Faulty Partitions: {{ owner: {}, faulty_partitions: [{}] }}", owner, - partition, itertools::Itertools::intersperse( - sectors.0.iter().map(|recovery| format!("{}", recovery)), + faulty_partitions.iter().map(|(partition, sectors)| format!( + "{{ partition: {}, sectors: {} }}", + partition, + itertools::Itertools::intersperse( + sectors.iter().map(|sector| format!("{}", sector)), + ", ".to_string() + ) + .collect::() + )), ", ".to_string() ) .collect::()