|
1 | 1 | #![allow(clippy::unwrap_used)] |
2 | 2 |
|
| 3 | +use std::u16; |
| 4 | + |
3 | 5 | use frame_support::traits::Currency; |
| 6 | +use substrate_fixed::types::extra::True; |
4 | 7 |
|
5 | 8 | use crate::mock::*; |
6 | 9 | use frame_support::dispatch::{DispatchClass, DispatchInfo, GetDispatchInfo, Pays}; |
@@ -538,6 +541,118 @@ fn test_burn_adjustment() { |
538 | 541 | }); |
539 | 542 | } |
540 | 543 |
|
| 544 | +#[test] |
| 545 | +fn test_burn_registration_pruning_scenarios() { |
| 546 | + new_test_ext(1).execute_with(|| { |
| 547 | + let netuid: u16 = 1; |
| 548 | + let tempo: u16 = 13; |
| 549 | + let burn_cost = 1000; |
| 550 | + let coldkey_account_id = U256::from(667); |
| 551 | + let max_allowed_uids = 6; |
| 552 | + let immunity_period = 5000; |
| 553 | + |
| 554 | + SubtensorModule::set_burn(netuid, burn_cost); |
| 555 | + SubtensorModule::set_max_allowed_uids(netuid, max_allowed_uids); |
| 556 | + SubtensorModule::set_target_registrations_per_interval(netuid, max_allowed_uids); |
| 557 | + SubtensorModule::set_immunity_period(netuid, immunity_period); |
| 558 | + |
| 559 | + // SubtensorModule::set_immunity_period(netuid, immunity_period); |
| 560 | + |
| 561 | + add_network(netuid, tempo, 0); |
| 562 | + |
| 563 | + let mint_balance = burn_cost * u64::from(max_allowed_uids) + 1_000_000_000; |
| 564 | + SubtensorModule::add_balance_to_coldkey_account(&coldkey_account_id, mint_balance); |
| 565 | + |
| 566 | + // Register first half of neurons |
| 567 | + for i in 0..3 { |
| 568 | + assert_ok!(SubtensorModule::burned_register( |
| 569 | + <<Test as Config>::RuntimeOrigin>::signed(coldkey_account_id), |
| 570 | + netuid, |
| 571 | + U256::from(i) |
| 572 | + )); |
| 573 | + step_block(1); |
| 574 | + } |
| 575 | + |
| 576 | + // Note: pruning score is set to u16::MAX after getting neuron to prune |
| 577 | + |
| 578 | + // 1. Test all immune neurons |
| 579 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 0), true); |
| 580 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 1), true); |
| 581 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 2), true); |
| 582 | + |
| 583 | + SubtensorModule::set_pruning_score_for_uid(netuid, 0, 100); |
| 584 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, 75); |
| 585 | + SubtensorModule::set_pruning_score_for_uid(netuid, 2, 50); |
| 586 | + |
| 587 | + // The immune neuron with the lowest score should be pruned |
| 588 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 2); |
| 589 | + |
| 590 | + // 2. Test tie-breaking for immune neurons |
| 591 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, 50); |
| 592 | + SubtensorModule::set_pruning_score_for_uid(netuid, 2, 50); |
| 593 | + |
| 594 | + // Should get the oldest neuron |
| 595 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 1); |
| 596 | + |
| 597 | + // 3. Test no immune neurons |
| 598 | + step_block(immunity_period); |
| 599 | + |
| 600 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 0), false); |
| 601 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 1), false); |
| 602 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 2), false); |
| 603 | + |
| 604 | + SubtensorModule::set_pruning_score_for_uid(netuid, 0, 100); |
| 605 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, 50); |
| 606 | + SubtensorModule::set_pruning_score_for_uid(netuid, 2, 75); |
| 607 | + |
| 608 | + // The non-immune neuron with the lowest score should be pruned |
| 609 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 1); |
| 610 | + |
| 611 | + // 4. Test tie-breaking for non-immune neurons |
| 612 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, 50); |
| 613 | + SubtensorModule::set_pruning_score_for_uid(netuid, 2, 50); |
| 614 | + |
| 615 | + // Should get the oldest non-immune neuron |
| 616 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 1); |
| 617 | + |
| 618 | + // 5. Test mixed immunity |
| 619 | + // Register second batch of neurons (these will be non-immune) |
| 620 | + for i in 3..6 { |
| 621 | + assert_ok!(SubtensorModule::burned_register( |
| 622 | + <<Test as Config>::RuntimeOrigin>::signed(coldkey_account_id), |
| 623 | + netuid, |
| 624 | + U256::from(i) |
| 625 | + )); |
| 626 | + step_block(1); |
| 627 | + } |
| 628 | + |
| 629 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 3), true); |
| 630 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 4), true); |
| 631 | + assert_eq!(SubtensorModule::get_neuron_is_immune(netuid, 5), true); |
| 632 | + |
| 633 | + // Set pruning scores for all neurons |
| 634 | + SubtensorModule::set_pruning_score_for_uid(netuid, 0, 75); // non-immune |
| 635 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, 50); // non-immune |
| 636 | + SubtensorModule::set_pruning_score_for_uid(netuid, 2, 60); // non-immune |
| 637 | + SubtensorModule::set_pruning_score_for_uid(netuid, 3, 40); // immune |
| 638 | + SubtensorModule::set_pruning_score_for_uid(netuid, 4, 55); // immune |
| 639 | + SubtensorModule::set_pruning_score_for_uid(netuid, 5, 45); // immune |
| 640 | + |
| 641 | + // The non-immune neuron with the lowest score should be pruned |
| 642 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 1); |
| 643 | + |
| 644 | + // If we remove the lowest non-immune neuron, it should choose the next lowest non-immune |
| 645 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, u16::MAX); |
| 646 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 2); |
| 647 | + |
| 648 | + // If we make all non-immune neurons have high scores, it should choose the oldest non-immune neuron |
| 649 | + SubtensorModule::set_pruning_score_for_uid(netuid, 0, u16::MAX); |
| 650 | + SubtensorModule::set_pruning_score_for_uid(netuid, 1, u16::MAX); |
| 651 | + SubtensorModule::set_pruning_score_for_uid(netuid, 2, u16::MAX); |
| 652 | + assert_eq!(SubtensorModule::get_neuron_to_prune(netuid), 0); |
| 653 | + }); |
| 654 | +} |
| 655 | + |
541 | 656 | #[test] |
542 | 657 | fn test_registration_too_many_registrations_per_block() { |
543 | 658 | new_test_ext(1).execute_with(|| { |
|
0 commit comments