133 lines
3.8 KiB
Rust
133 lines
3.8 KiB
Rust
#![cfg(feature = "test-bpf")]
|
|
|
|
mod program_test;
|
|
|
|
use solana_program_test::tokio;
|
|
|
|
use program_test::*;
|
|
|
|
use spl_governance::error::GovernanceError;
|
|
|
|
#[tokio::test]
|
|
async fn test_add_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();
|
|
|
|
// Act
|
|
let signatory_record_cookie = governance_test
|
|
.with_signatory(&proposal_cookie, &token_owner_record_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Assert
|
|
let signatory_record_account = governance_test
|
|
.get_signatory_record_account(&signatory_record_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(signatory_record_cookie.account, signatory_record_account);
|
|
|
|
let proposal_account = governance_test
|
|
.get_proposal_account(&proposal_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(1, proposal_account.signatories_count);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_add_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 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
|
|
.with_signatory(&proposal_cookie, &token_owner_record_cookie)
|
|
.await
|
|
.err()
|
|
.unwrap();
|
|
|
|
// Assert
|
|
assert_eq!(
|
|
err,
|
|
GovernanceError::GoverningTokenOwnerOrDelegateMustSign.into()
|
|
);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_add_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 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
|
|
.with_signatory(&proposal_cookie, &token_owner_record_cookie)
|
|
.await
|
|
.err()
|
|
.unwrap();
|
|
|
|
// Assert
|
|
assert_eq!(err, GovernanceError::InvalidProposalOwnerAccount.into());
|
|
}
|