216 lines
6.0 KiB
Rust
216 lines
6.0 KiB
Rust
#![cfg(feature = "test-bpf")]
|
|
|
|
mod program_test;
|
|
|
|
use solana_program_test::tokio;
|
|
|
|
use program_test::*;
|
|
|
|
use spl_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 mut account_governance_cookie = governance_test
|
|
.with_account_governance(&realm_cookie, &governed_account_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let token_owner_record_cookie = governance_test
|
|
.with_community_token_deposit(&realm_cookie)
|
|
.await;
|
|
|
|
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
|
|
.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 account_governance_cookie = governance_test
|
|
.with_account_governance(&realm_cookie, &governed_account_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let mut token_owner_record_cookie = governance_test
|
|
.with_community_token_deposit(&realm_cookie)
|
|
.await;
|
|
|
|
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;
|
|
|
|
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 account_governance_cookie = governance_test
|
|
.with_account_governance(&realm_cookie, &governed_account_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let mut token_owner_record_cookie = governance_test
|
|
.with_community_token_deposit(&realm_cookie)
|
|
.await;
|
|
|
|
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;
|
|
|
|
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 mut account_governance_cookie = governance_test
|
|
.with_account_governance(&realm_cookie, &governed_account_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let token_owner_record_cookie = governance_test
|
|
.with_community_token_deposit(&realm_cookie)
|
|
.await;
|
|
|
|
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()
|
|
);
|
|
}
|