From bb964f86011ace28c27bed7bb8406bd7abbe0f72 Mon Sep 17 00:00:00 2001
From: cgeek <cem.moreau@gmail.com>
Date: Mon, 30 Oct 2023 13:28:12 +0100
Subject: [PATCH] fix(#125): test: identity removal by membership expiry

---
 runtime/gdev/tests/integration_tests.rs | 27 +++++++++++++++++++++++++
 1 file changed, 27 insertions(+)

diff --git a/runtime/gdev/tests/integration_tests.rs b/runtime/gdev/tests/integration_tests.rs
index b87ecc022..34ae8878c 100644
--- a/runtime/gdev/tests/integration_tests.rs
+++ b/runtime/gdev/tests/integration_tests.rs
@@ -17,10 +17,12 @@
 mod common;
 
 use common::*;
+use frame_support::instances::Instance1;
 use frame_support::traits::{Get, PalletInfo, StorageInfo, StorageInfoTrait};
 use frame_support::{assert_noop, assert_ok};
 use frame_support::{StorageHasher, Twox128};
 use gdev_runtime::*;
+use pallet_duniter_wot::IdtyRemovalWotReason;
 use sp_keyring::AccountKeyring;
 use sp_runtime::MultiAddress;
 
@@ -195,6 +197,31 @@ fn test_membership_expiry() {
     });
 }
 
+#[test]
+fn test_membership_expiry_with_identity_removal() {
+    ExtBuilder::new(1, 3, 4).build().execute_with(|| {
+        run_to_block(100);
+
+        System::assert_has_event(RuntimeEvent::Membership(
+            pallet_membership::Event::MembershipExpired(4),
+        ));
+
+        // Trigger pending membership expiry
+        run_to_block(
+            100 + <Runtime as pallet_membership::Config<Instance1>>::PendingMembershipPeriod::get(),
+        );
+
+        System::assert_has_event(RuntimeEvent::Identity(
+            pallet_identity::Event::IdtyRemoved {
+                idty_index: 4,
+                reason: pallet_identity::IdtyRemovalReason::Other(
+                    IdtyRemovalWotReason::MembershipExpired,
+                ),
+            },
+        ));
+    });
+}
+
 /// test membership renewal
 #[test]
 fn test_membership_renewal() {
-- 
GitLab