#![cfg(feature = "test-bpf")] mod program_test; use gemachain_program_test::tokio; use program_test::*; use gpl_governance::{error::GovernanceError, state::enums::ProposalState}; #[tokio::test] async fn test_remove_signatory() { // Arrange let mut governance_test = GovernanceProgramTest::start_new().await; let realm_cookie = governance_test.with_realm().await; let governed_account_cookie = governance_test.with_governed_account().await; let token_owner_record_cookie = governance_test .with_community_token_deposit(&realm_cookie) .await .unwrap(); let mut account_governance_cookie = governance_test .with_account_governance( &realm_cookie, &governed_account_cookie, &token_owner_record_cookie, ) .await .unwrap(); let proposal_cookie = governance_test .with_proposal(&token_owner_record_cookie, &mut account_governance_cookie) .await .unwrap(); let signatory_record_cookie = governance_test .with_signatory(&proposal_cookie, &token_owner_record_cookie) .await .unwrap(); // Act governance_test .remove_signatory( &proposal_cookie, &token_owner_record_cookie, &signatory_record_cookie, ) .await .unwrap(); // Assert let proposal_account = governance_test .get_proposal_account(&proposal_cookie.address) .await; assert_eq!(0, proposal_account.signatories_count); assert_eq!(ProposalState::Draft, proposal_account.state); let signatory_account = governance_test .bench .get_account(&signatory_record_cookie.address) .await; assert_eq!(None, signatory_account); } #[tokio::test] async fn test_remove_signatory_with_owner_or_delegate_must_sign_error() { // Arrange let mut governance_test = GovernanceProgramTest::start_new().await; let realm_cookie = governance_test.with_realm().await; let governed_account_cookie = governance_test.with_governed_account().await; let mut token_owner_record_cookie = governance_test .with_community_token_deposit(&realm_cookie) .await .unwrap(); let mut account_governance_cookie = governance_test .with_account_governance( &realm_cookie, &governed_account_cookie, &token_owner_record_cookie, ) .await .unwrap(); let proposal_cookie = governance_test .with_proposal(&token_owner_record_cookie, &mut account_governance_cookie) .await .unwrap(); let signatory_record_cookie = governance_test .with_signatory(&proposal_cookie, &token_owner_record_cookie) .await .unwrap(); let other_token_owner_record_cookie = governance_test .with_council_token_deposit(&realm_cookie) .await .unwrap(); token_owner_record_cookie.token_owner = other_token_owner_record_cookie.token_owner; // Act let err = governance_test .remove_signatory( &proposal_cookie, &token_owner_record_cookie, &signatory_record_cookie, ) .await .err() .unwrap(); // Assert assert_eq!( err, GovernanceError::GoverningTokenOwnerOrDelegateMustSign.into() ); } #[tokio::test] async fn test_remove_signatory_with_invalid_proposal_owner_error() { // Arrange let mut governance_test = GovernanceProgramTest::start_new().await; let realm_cookie = governance_test.with_realm().await; let governed_account_cookie = governance_test.with_governed_account().await; let mut token_owner_record_cookie = governance_test .with_community_token_deposit(&realm_cookie) .await .unwrap(); let mut account_governance_cookie = governance_test .with_account_governance( &realm_cookie, &governed_account_cookie, &token_owner_record_cookie, ) .await .unwrap(); let proposal_cookie = governance_test .with_proposal(&token_owner_record_cookie, &mut account_governance_cookie) .await .unwrap(); let signatory_record_cookie = governance_test .with_signatory(&proposal_cookie, &token_owner_record_cookie) .await .unwrap(); let other_token_owner_record_cookie = governance_test .with_council_token_deposit(&realm_cookie) .await .unwrap(); token_owner_record_cookie.address = other_token_owner_record_cookie.address; // Act let err = governance_test .remove_signatory( &proposal_cookie, &token_owner_record_cookie, &signatory_record_cookie, ) .await .err() .unwrap(); // Assert assert_eq!(err, GovernanceError::InvalidProposalOwnerAccount.into()); } #[tokio::test] async fn test_remove_signatory_with_not_editable_error() { // Arrange let mut governance_test = GovernanceProgramTest::start_new().await; let realm_cookie = governance_test.with_realm().await; let governed_account_cookie = governance_test.with_governed_account().await; let token_owner_record_cookie = governance_test .with_community_token_deposit(&realm_cookie) .await .unwrap(); let mut account_governance_cookie = governance_test .with_account_governance( &realm_cookie, &governed_account_cookie, &token_owner_record_cookie, ) .await .unwrap(); let proposal_cookie = governance_test .with_proposal(&token_owner_record_cookie, &mut account_governance_cookie) .await .unwrap(); let signatory_record_cookie1 = governance_test .with_signatory(&proposal_cookie, &token_owner_record_cookie) .await .unwrap(); let signatory_record_cookie2 = governance_test .with_signatory(&proposal_cookie, &token_owner_record_cookie) .await .unwrap(); governance_test .sign_off_proposal(&proposal_cookie, &signatory_record_cookie1) .await .unwrap(); // Act let err = governance_test .remove_signatory( &proposal_cookie, &token_owner_record_cookie, &signatory_record_cookie2, ) .await .err() .unwrap(); // Assert assert_eq!( err, GovernanceError::InvalidStateCannotEditSignatories.into() ); } #[tokio::test] async fn test_remove_signatory_with_already_signed_error() { // Arrange let mut governance_test = GovernanceProgramTest::start_new().await; let realm_cookie = governance_test.with_realm().await; let governed_account_cookie = governance_test.with_governed_account().await; let token_owner_record_cookie = governance_test .with_community_token_deposit(&realm_cookie) .await .unwrap(); let mut account_governance_cookie = governance_test .with_account_governance( &realm_cookie, &governed_account_cookie, &token_owner_record_cookie, ) .await .unwrap(); let proposal_cookie = governance_test .with_proposal(&token_owner_record_cookie, &mut account_governance_cookie) .await .unwrap(); let signatory_record_cookie = governance_test .with_signatory(&proposal_cookie, &token_owner_record_cookie) .await .unwrap(); governance_test .sign_off_proposal(&proposal_cookie, &signatory_record_cookie) .await .unwrap(); // Act let err = governance_test .remove_signatory( &proposal_cookie, &token_owner_record_cookie, &signatory_record_cookie, ) .await .err() .unwrap(); // Assert assert_eq!( err, GovernanceError::InvalidStateCannotEditSignatories.into() ); }