123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362 |
- #![cfg(test)]
- use super::genesis;
- use super::mock::*;
- use frame_support::*;
- // use sp_core::traits;
- fn get_membership_by_id(member_id: u64) -> crate::Membership<Test> {
- if <crate::MembershipById<Test>>::contains_key(member_id) {
- Members::membership(member_id)
- } else {
- panic!("member profile not created");
- }
- }
- fn assert_dispatch_error_message(result: Result<(), &'static str>, expected_message: &'static str) {
- assert!(result.is_err());
- let message = result.err().unwrap();
- assert_eq!(message, expected_message);
- }
- #[derive(Clone, Debug, PartialEq)]
- pub struct TestUserInfo {
- pub handle: Option<Vec<u8>>,
- pub avatar_uri: Option<Vec<u8>>,
- pub about: Option<Vec<u8>>,
- }
- fn get_alice_info() -> TestUserInfo {
- TestUserInfo {
- handle: Some(String::from("alice").as_bytes().to_vec()),
- avatar_uri: Some(
- String::from("http://avatar-url.com/alice")
- .as_bytes()
- .to_vec(),
- ),
- about: Some(String::from("my name is alice").as_bytes().to_vec()),
- }
- }
- fn get_bob_info() -> TestUserInfo {
- TestUserInfo {
- handle: Some(String::from("bobby").as_bytes().to_vec()),
- avatar_uri: Some(
- String::from("http://avatar-url.com/bob")
- .as_bytes()
- .to_vec(),
- ),
- about: Some(String::from("my name is bob").as_bytes().to_vec()),
- }
- }
- const ALICE_ACCOUNT_ID: u64 = 1;
- fn buy_default_membership_as_alice() -> crate::DispatchResult {
- let info = get_alice_info();
- Members::buy_membership(
- Origin::signed(ALICE_ACCOUNT_ID),
- DEFAULT_PAID_TERM_ID as u32,
- info.handle,
- info.avatar_uri,
- info.about,
- )
- .map_err(|err| err.into())
- }
- fn set_alice_free_balance(balance: u64) {
- let _ = Balances::deposit_creating(&ALICE_ACCOUNT_ID, balance);
- }
- #[test]
- fn initial_state() {
- const DEFAULT_FEE: u64 = 500;
- let initial_members = [(0, 1), (1, 2), (2, 3)];
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .default_paid_membership_fee(DEFAULT_FEE)
- .members(initial_members.to_vec())
- .build(),
- )
- .build()
- .execute_with(|| {
- let default_terms = if <crate::PaidMembershipTermsById<Test>>::contains_key(
- DEFAULT_PAID_TERM_ID as u32,
- ) {
- Members::paid_membership_terms_by_id(DEFAULT_PAID_TERM_ID as u32)
- } else {
- panic!("default terms not initialized");
- };
- assert_eq!(default_terms.fee, DEFAULT_FEE);
- });
- }
- #[test]
- fn buy_membership() {
- const DEFAULT_FEE: u64 = 500;
- const SURPLUS_BALANCE: u64 = 500;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .default_paid_membership_fee(DEFAULT_FEE)
- .build(),
- )
- .build()
- .execute_with(|| {
- let initial_balance = DEFAULT_FEE + SURPLUS_BALANCE;
- set_alice_free_balance(initial_balance);
- let next_member_id = Members::members_created();
- assert_ok!(buy_default_membership_as_alice());
- let member_ids = vec![0];
- assert_eq!(member_ids, vec![next_member_id]);
- let profile = get_membership_by_id(next_member_id);
- assert_eq!(Some(profile.handle), get_alice_info().handle);
- assert_eq!(Some(profile.avatar_uri), get_alice_info().avatar_uri);
- assert_eq!(Some(profile.about), get_alice_info().about);
- assert_eq!(Balances::free_balance(&ALICE_ACCOUNT_ID), SURPLUS_BALANCE);
- // controller account initially set to primary account
- assert_eq!(profile.controller_account, ALICE_ACCOUNT_ID);
- assert_eq!(
- <crate::MemberIdsByControllerAccountId<Test>>::get(ALICE_ACCOUNT_ID),
- vec![next_member_id]
- );
- });
- }
- #[test]
- fn buy_membership_fails_without_enough_balance() {
- const DEFAULT_FEE: u64 = 500;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .default_paid_membership_fee(DEFAULT_FEE)
- .build(),
- )
- .build()
- .execute_with(|| {
- let initial_balance = DEFAULT_FEE - 1;
- set_alice_free_balance(initial_balance);
- assert_dispatch_error_message(
- buy_default_membership_as_alice(),
- "not enough balance to buy membership",
- );
- });
- }
- #[test]
- fn new_memberships_allowed_flag() {
- const DEFAULT_FEE: u64 = 500;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .default_paid_membership_fee(DEFAULT_FEE)
- .build(),
- )
- .build()
- .execute_with(|| {
- let initial_balance = DEFAULT_FEE + 1;
- set_alice_free_balance(initial_balance);
- crate::NewMembershipsAllowed::put(false);
- assert_dispatch_error_message(
- buy_default_membership_as_alice(),
- "new members not allowed",
- );
- });
- }
- #[test]
- fn unique_handles() {
- const DEFAULT_FEE: u64 = 500;
- const SURPLUS_BALANCE: u64 = 500;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .default_paid_membership_fee(DEFAULT_FEE)
- .build(),
- )
- .build()
- .execute_with(|| {
- let initial_balance = DEFAULT_FEE + SURPLUS_BALANCE;
- set_alice_free_balance(initial_balance);
- // alice's handle already taken
- <crate::MemberIdByHandle<Test>>::insert(get_alice_info().handle.unwrap(), 1);
- // should not be allowed to buy membership with that handle
- assert_dispatch_error_message(
- buy_default_membership_as_alice(),
- "handle already registered",
- );
- });
- }
- #[test]
- fn update_profile() {
- const DEFAULT_FEE: u64 = 500;
- const SURPLUS_BALANCE: u64 = 500;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .default_paid_membership_fee(DEFAULT_FEE)
- .build(),
- )
- .build()
- .execute_with(|| {
- let initial_balance = DEFAULT_FEE + SURPLUS_BALANCE;
- set_alice_free_balance(initial_balance);
- let next_member_id = Members::members_created();
- assert_ok!(buy_default_membership_as_alice());
- let info = get_bob_info();
- assert_ok!(Members::update_membership(
- Origin::signed(ALICE_ACCOUNT_ID),
- next_member_id,
- info.handle,
- info.avatar_uri,
- info.about,
- ));
- let profile = get_membership_by_id(next_member_id);
- assert_eq!(Some(profile.handle), get_bob_info().handle);
- assert_eq!(Some(profile.avatar_uri), get_bob_info().avatar_uri);
- assert_eq!(Some(profile.about), get_bob_info().about);
- });
- }
- #[test]
- fn add_screened_member() {
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(genesis::GenesisConfigBuilder::default().build())
- .build()
- .execute_with(|| {
- let screening_authority = 5;
- <crate::ScreeningAuthority<Test>>::put(&screening_authority);
- let next_member_id = Members::members_created();
- let endownment = ScreenedMemberMaxInitialBalance::get() - 1;
- let info = get_alice_info();
- assert_ok!(Members::add_screened_member(
- Origin::signed(screening_authority),
- ALICE_ACCOUNT_ID,
- info.handle,
- info.avatar_uri,
- info.about,
- Some(endownment),
- ));
- let profile = get_membership_by_id(next_member_id);
- assert_eq!(Some(profile.handle), get_alice_info().handle);
- assert_eq!(Some(profile.avatar_uri), get_alice_info().avatar_uri);
- assert_eq!(Some(profile.about), get_alice_info().about);
- assert_eq!(
- crate::EntryMethod::Screening(screening_authority),
- profile.entry
- );
- assert_eq!(Balances::free_balance(ALICE_ACCOUNT_ID), endownment);
- // Transfer should fail because of balance lock
- assert_err!(
- Balances::transfer(Origin::signed(ALICE_ACCOUNT_ID), screening_authority, 1),
- balances::Error::<Test, _>::LiquidityRestrictions
- );
- // .. but we should be able to slash
- assert!(Balances::can_slash(&ALICE_ACCOUNT_ID, 1));
- // Deposit more funds to have a surplus above lock limit
- let _ = Balances::deposit_creating(&ALICE_ACCOUNT_ID, 10);
- // If free balance above lock limit, transfers should be possible
- assert_ok!(Balances::transfer(
- Origin::signed(ALICE_ACCOUNT_ID),
- screening_authority,
- 1
- ));
- });
- }
- #[test]
- fn set_controller_key() {
- let initial_members = [(0, ALICE_ACCOUNT_ID)];
- const ALICE_CONTROLLER_ID: u64 = 2;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .members(initial_members.to_vec())
- .build(),
- )
- .build()
- .execute_with(|| {
- let member_id = 0;
- assert_ok!(Members::set_controller_account(
- Origin::signed(ALICE_ACCOUNT_ID),
- member_id,
- ALICE_CONTROLLER_ID
- ));
- let profile = get_membership_by_id(member_id);
- assert_eq!(profile.controller_account, ALICE_CONTROLLER_ID);
- assert_eq!(
- <crate::MemberIdsByControllerAccountId<Test>>::get(&ALICE_CONTROLLER_ID),
- vec![member_id]
- );
- assert!(
- <crate::MemberIdsByControllerAccountId<Test>>::get(&ALICE_ACCOUNT_ID).is_empty()
- );
- });
- }
- #[test]
- fn set_root_account() {
- let initial_members = [(0, ALICE_ACCOUNT_ID)];
- const ALICE_NEW_ROOT_ACCOUNT: u64 = 2;
- TestExternalitiesBuilder::<Test>::default()
- .set_membership_config(
- genesis::GenesisConfigBuilder::default()
- .members(initial_members.to_vec())
- .build(),
- )
- .build()
- .execute_with(|| {
- let member_id = 0;
- assert_ok!(Members::set_root_account(
- Origin::signed(ALICE_ACCOUNT_ID),
- member_id,
- ALICE_NEW_ROOT_ACCOUNT
- ));
- let membership = Members::membership(member_id);
- assert_eq!(ALICE_NEW_ROOT_ACCOUNT, membership.root_account);
- assert!(<crate::MemberIdsByRootAccountId<Test>>::get(&ALICE_ACCOUNT_ID).is_empty());
- });
- }
|