@@ -2754,3 +2754,47 @@ fn update_rewards_disable_rewards_consensus_rewards_flow_test() {
27542754 : result , expected_error : StakingError :: REWARDS_ALREADY_UPDATED . describe (),
27552755 );
27562756}
2757+
2758+ /// Flow:
2759+ /// Start consensus rewards.
2760+ /// Staker stake with STRK pool.
2761+ /// Delegator delegate STRK.
2762+ /// Advance K epochs.
2763+ /// update_rewards.
2764+ /// Test staker rewards.
2765+ /// Test delegator rewards.
2766+ /// Advance epoch.
2767+ /// Test delegator rewards.
2768+ #[test]
2769+ fn update_rewards_strk_pool_flow_test () {
2770+ let cfg : StakingInitConfig = Default :: default ();
2771+ let mut system = SystemConfigTrait :: basic_stake_flow_cfg (: cfg ). deploy ();
2772+ system . start_consensus_rewards ();
2773+ let stake_amount = system . staking. get_min_stake ();
2774+ let delegation_amount = STRK_CONFIG . min_for_rewards;
2775+ let staker = system . new_staker (amount : stake_amount );
2776+ let commission = 200 ;
2777+ system . stake (: staker , amount : stake_amount , pool_enabled : true , : commission );
2778+ let pool = system . staking. get_pool (: staker );
2779+ let delegator = system . new_delegator (amount : delegation_amount );
2780+ system . delegate (: delegator , : pool , amount : delegation_amount );
2781+ system . advance_k_epochs ();
2782+
2783+ system . update_rewards (: staker , disable_rewards : false );
2784+ let (expected_staker_rewards , expected_pool_rewards ) =
2785+ calculate_staker_strk_rewards_with_balances_v3 (
2786+ amount_own : stake_amount ,
2787+ pool_amount : delegation_amount ,
2788+ : commission ,
2789+ staking_contract : system . staking. address,
2790+ minting_curve_contract : system . minting_curve. address,
2791+ );
2792+ let staker_rewards = system . staker_claim_rewards (: staker );
2793+ let delegator_rewards = system . delegator_claim_rewards (: delegator , : pool );
2794+ assert! (staker_rewards == expected_staker_rewards );
2795+ assert! (delegator_rewards . is_zero ());
2796+
2797+ system . advance_epoch ();
2798+ let delegator_rewards = system . delegator_claim_rewards (: delegator , : pool );
2799+ assert! (delegator_rewards == expected_pool_rewards );
2800+ }
0 commit comments