Skip to content

Commit

Permalink
chore: PR #177 is backported
Browse files Browse the repository at this point in the history
  • Loading branch information
Raid5594 authored and yahortsaryk committed Dec 8, 2023
1 parent b7ac195 commit a8ffd55
Show file tree
Hide file tree
Showing 3 changed files with 201 additions and 1 deletion.
6 changes: 6 additions & 0 deletions pallets/ddc-staking/src/benchmarking.rs
Original file line number Diff line number Diff line change
Expand Up @@ -130,4 +130,10 @@ benchmarks! {
verify {
assert!(Nodes::<T>::contains_key(&new_node));
}

impl_benchmark_test_suite!(
DdcStaking,
crate::mock::ExtBuilder::default().build(),
crate::mock::Test,
);
}
2 changes: 1 addition & 1 deletion pallets/ddc-staking/src/mock.rs
Original file line number Diff line number Diff line change
Expand Up @@ -353,7 +353,7 @@ impl ExtBuilder {
self.storages.push((stash, controller, stake, cluster));
self
}
fn build(self) -> TestExternalities {
pub fn build(self) -> TestExternalities {
sp_tracing::try_init_simple();
let mut storage = frame_system::GenesisConfig::default().build_storage::<Test>().unwrap();

Expand Down
194 changes: 194 additions & 0 deletions pallets/ddc-staking/src/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,21 @@ use pallet_balances::Error as BalancesError;
pub const BLOCK_TIME: u64 = 1000;
pub const INIT_TIMESTAMP: u64 = 30_000;

#[test]
fn test_default_staking_ledger() {
// Verifies initial conditions of mock
ExtBuilder::default().build_and_execute(|| {
let default_staking_ledger = StakingLedger::<
<Test as frame_system::Config>::AccountId,
BalanceOf<Test>,
Test,
>::default_from(1);
// Account 11 is stashed and locked, and account 10 is the controller
assert_eq!(default_staking_ledger.stash, 1);
assert_eq!(default_staking_ledger.total, Zero::zero());
});
}

#[test]
fn basic_setup_works() {
// Verifies initial conditions of mock
Expand Down Expand Up @@ -58,6 +73,10 @@ fn change_controller_works() {

// Change controller.
assert_ok!(DdcStaking::set_controller(RuntimeOrigin::signed(11), 3));
assert_noop!(
DdcStaking::set_controller(RuntimeOrigin::signed(11), 3),
Error::<Test>::AlreadyPaired
);
assert_eq!(DdcStaking::bonded(&11), Some(3));

// 10 is no longer in control.
Expand Down Expand Up @@ -89,6 +108,20 @@ fn not_enough_inital_bond_flow() {
Error::<Test>::InsufficientBond
);

// Add new Storage participant, account 1 controlled by 2 with node 3.
assert_ok!(DdcStaking::bond(
RuntimeOrigin::signed(1),
2,
NodePubKey::StoragePubKey(StorageNodePubKey::new([3; 32])),
100
));

// Not enough tokens bonded to store
assert_noop!(
DdcStaking::store(RuntimeOrigin::signed(4), ClusterId::from([1; 20])),
Error::<Test>::InsufficientBond
);

// Can not bond extra
assert_noop!(
DdcStaking::bond(
Expand Down Expand Up @@ -121,6 +154,67 @@ fn not_enough_inital_bond_flow() {
})
}

#[test]
fn unbonding_edge_cases_work() {
ExtBuilder::default().build_and_execute(|| {
System::set_block_number(1);

// Add new CDN participant, account 3 controlled by 4 with node 5.
assert_ok!(DdcStaking::bond(
RuntimeOrigin::signed(3),
4,
NodePubKey::CDNPubKey(CDNNodePubKey::new([5; 32])),
100
));

assert_ok!(DdcStaking::serve(RuntimeOrigin::signed(4), ClusterId::from([1; 20])));

assert_ok!(DdcStaking::unbond(RuntimeOrigin::signed(4), 1));
while System::block_number() < 33 {
assert_ok!(DdcStaking::unbond(RuntimeOrigin::signed(4), 1));
System::assert_last_event(Event::Unbonded(3, 1).into());
System::set_block_number(System::block_number() + 1);
}

assert_noop!(DdcStaking::unbond(RuntimeOrigin::signed(4), 1), Error::<Test>::NoMoreChunks);
})
}

#[test]
fn serve_or_store_should_be_prohibited() {
ExtBuilder::default().build_and_execute(|| {
System::set_block_number(1);

// Add new CDN participant, account 3 controlled by 4 with node 5.
assert_ok!(DdcStaking::bond(
RuntimeOrigin::signed(3),
4,
NodePubKey::CDNPubKey(CDNNodePubKey::new([5; 32])),
100
));

// Add new Storage participant, account 1 controlled by 2 with node 3.
assert_ok!(DdcStaking::bond(
RuntimeOrigin::signed(1),
2,
NodePubKey::StoragePubKey(StorageNodePubKey::new([3; 32])),
100
));

// Not enough tokens bonded to serve
assert_noop!(
DdcStaking::serve(RuntimeOrigin::signed(2), ClusterId::from([1; 20])),
Error::<Test>::ServingProhibited
);

// Not enough tokens bonded to store
assert_noop!(
DdcStaking::store(RuntimeOrigin::signed(4), ClusterId::from([1; 20])),
Error::<Test>::StoringProhibited
);
})
}

#[test]
fn set_node_works() {
ExtBuilder::default().build_and_execute(|| {
Expand Down Expand Up @@ -160,6 +254,45 @@ fn set_node_works() {
})
}

#[test]
fn cancel_previous_chill_works() {
ExtBuilder::default().build_and_execute(|| {
System::set_block_number(1);

let cluster_id = ClusterId::from([1; 20]);
// Add new CDN participant, account 3 controlled by 4 with node 5.
assert_ok!(DdcStaking::bond(
RuntimeOrigin::signed(3),
4,
NodePubKey::CDNPubKey(CDNNodePubKey::new([5; 32])),
100
));

// Add new Storage participant, account 1 controlled by 2 with node 3.
assert_ok!(DdcStaking::bond(
RuntimeOrigin::signed(1),
2,
NodePubKey::StoragePubKey(StorageNodePubKey::new([3; 32])),
100
));

// Not enough tokens bonded to serve
assert_ok!(DdcStaking::serve(RuntimeOrigin::signed(4), cluster_id));

assert_ok!(DdcStaking::store(RuntimeOrigin::signed(2), ClusterId::from([1; 20])));

// Schedule CDN participant removal.
assert_ok!(DdcStaking::chill(RuntimeOrigin::signed(4)));
// Not enough tokens bonded to serve
assert_ok!(DdcStaking::serve(RuntimeOrigin::signed(4), cluster_id));

// Schedule CDN participant removal.
assert_ok!(DdcStaking::chill(RuntimeOrigin::signed(2)));
// Not enough tokens bonded to serve
assert_ok!(DdcStaking::store(RuntimeOrigin::signed(2), cluster_id));
})
}

#[test]
fn staking_should_work() {
ExtBuilder::default().build_and_execute(|| {
Expand Down Expand Up @@ -453,3 +586,64 @@ fn storage_full_unbonding_works() {
MockNodeVisitor::reset_and_release_lock(lock);
});
}

#[test]
fn staking_creator_works() {
// Verifies initial conditions of mock
ExtBuilder::default().build_and_execute(|| {
let stash: u64 = 1;
let controller: u64 = 2;
let cluster_id = ClusterId::from([1; 20]);
let value = 5;
let cdn_node_pub_key = NodePubKey::StoragePubKey(StorageNodePubKey::new([2; 32]));
let storage_node_pub_key = NodePubKey::CDNPubKey(CDNNodePubKey::new([2; 32]));

assert_ok!(
<DdcStaking as StakerCreator<Test, BalanceOf<Test>>>::bond_stake_and_participate(
stash,
controller,
cdn_node_pub_key,
value,
cluster_id,
)
);

assert_ok!(
<DdcStaking as StakerCreator<Test, BalanceOf<Test>>>::bond_stake_and_participate(
stash,
controller,
storage_node_pub_key,
value,
cluster_id,
)
);
});
}

#[test]
fn staking_visitor_works() {
// Verifies initial conditions of mock
ExtBuilder::default().build_and_execute(|| {
let cluster_id = ClusterId::from([1; 20]);
let node_pub_key = NodePubKey::CDNPubKey(CDNNodePubKey::new([5; 32]));

// Add new CDN participant, account 3 controlled by 4 with node 5.
assert_ok!(DdcStaking::bond(RuntimeOrigin::signed(3), 4, node_pub_key.clone(), 100));

assert!(<DdcStaking as StakingVisitor<Test>>::has_stake(&node_pub_key,));

if let Ok(result) =
<DdcStaking as StakingVisitor<Test>>::has_chilling_attempt(&node_pub_key)
{
assert!(!result);
}

assert_ok!(DdcStaking::serve(RuntimeOrigin::signed(4), ClusterId::from([1; 20])));

if let Ok(result) =
<DdcStaking as StakingVisitor<Test>>::has_activated_stake(&node_pub_key, &cluster_id)
{
assert!(result);
}
});
}

0 comments on commit a8ffd55

Please sign in to comment.