382 lines
10 KiB
Rust
382 lines
10 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_remove_instruction() {
|
|
// 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 mut proposal_cookie = governance_test
|
|
.with_proposal(&token_owner_record_cookie, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Act
|
|
|
|
governance_test
|
|
.remove_instruction(
|
|
&mut proposal_cookie,
|
|
&token_owner_record_cookie,
|
|
&proposal_instruction_cookie,
|
|
)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Assert
|
|
|
|
let proposal_account = governance_test
|
|
.get_proposal_account(&proposal_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(proposal_account.instructions_count, 0);
|
|
assert_eq!(proposal_account.instructions_next_index, 1);
|
|
assert_eq!(proposal_account.instructions_executed_count, 0);
|
|
|
|
let proposal_instruction_account = governance_test
|
|
.bench
|
|
.get_account(&proposal_instruction_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(None, proposal_instruction_account);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_replace_instruction() {
|
|
// 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 mut proposal_cookie = governance_test
|
|
.with_proposal(&token_owner_record_cookie, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Act
|
|
|
|
governance_test
|
|
.remove_instruction(
|
|
&mut proposal_cookie,
|
|
&token_owner_record_cookie,
|
|
&proposal_instruction_cookie,
|
|
)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie2 = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, Some(0))
|
|
.await
|
|
.unwrap();
|
|
|
|
// Assert
|
|
let proposal_account = governance_test
|
|
.get_proposal_account(&proposal_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(proposal_account.instructions_count, 2);
|
|
assert_eq!(proposal_account.instructions_next_index, 2);
|
|
|
|
let proposal_instruction_account2 = governance_test
|
|
.get_proposal_instruction_account(&proposal_instruction_cookie2.address)
|
|
.await;
|
|
|
|
assert_eq!(
|
|
proposal_instruction_cookie2.account,
|
|
proposal_instruction_account2
|
|
);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_remove_front_instruction() {
|
|
// 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 mut proposal_cookie = governance_test
|
|
.with_proposal(&token_owner_record_cookie, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Act
|
|
|
|
governance_test
|
|
.remove_instruction(
|
|
&mut proposal_cookie,
|
|
&token_owner_record_cookie,
|
|
&proposal_instruction_cookie,
|
|
)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Assert
|
|
let proposal_account = governance_test
|
|
.get_proposal_account(&proposal_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(proposal_account.instructions_count, 1);
|
|
assert_eq!(proposal_account.instructions_next_index, 2);
|
|
|
|
let proposal_instruction_account = governance_test
|
|
.bench
|
|
.get_account(&proposal_instruction_cookie.address)
|
|
.await;
|
|
|
|
assert_eq!(None, proposal_instruction_account);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_remove_instruction_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 mut proposal_cookie = governance_test
|
|
.with_proposal(&token_owner_record_cookie, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
let token_owner_record_cookie2 = governance_test
|
|
.with_council_token_deposit(&realm_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
token_owner_record_cookie.token_owner = token_owner_record_cookie2.token_owner;
|
|
|
|
// Act
|
|
let err = governance_test
|
|
.remove_instruction(
|
|
&mut proposal_cookie,
|
|
&token_owner_record_cookie,
|
|
&proposal_instruction_cookie,
|
|
)
|
|
.await
|
|
.err()
|
|
.unwrap();
|
|
|
|
// Assert
|
|
assert_eq!(
|
|
err,
|
|
GovernanceError::GoverningTokenOwnerOrDelegateMustSign.into()
|
|
);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_remove_instruction_with_proposal_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 mut proposal_cookie = governance_test
|
|
.with_proposal(&token_owner_record_cookie, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
governance_test
|
|
.cancel_proposal(&proposal_cookie, &token_owner_record_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Act
|
|
let err = governance_test
|
|
.remove_instruction(
|
|
&mut proposal_cookie,
|
|
&token_owner_record_cookie,
|
|
&proposal_instruction_cookie,
|
|
)
|
|
.await
|
|
.err()
|
|
.unwrap();
|
|
|
|
// Assert
|
|
assert_eq!(
|
|
err,
|
|
GovernanceError::InvalidStateCannotEditInstructions.into()
|
|
);
|
|
}
|
|
|
|
#[tokio::test]
|
|
async fn test_remove_instruction_with_instruction_from_other_proposal_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 mut proposal_cookie = governance_test
|
|
.with_proposal(&token_owner_record_cookie, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
governance_test
|
|
.with_nop_instruction(&mut proposal_cookie, &token_owner_record_cookie, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
let token_owner_record_cookie2 = governance_test
|
|
.with_community_token_deposit(&realm_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let mut proposal_cookie2 = governance_test
|
|
.with_proposal(&token_owner_record_cookie2, &mut account_governance_cookie)
|
|
.await
|
|
.unwrap();
|
|
|
|
let proposal_instruction_cookie2 = governance_test
|
|
.with_nop_instruction(&mut proposal_cookie2, &token_owner_record_cookie2, None)
|
|
.await
|
|
.unwrap();
|
|
|
|
// Act
|
|
let err = governance_test
|
|
.remove_instruction(
|
|
&mut proposal_cookie,
|
|
&token_owner_record_cookie,
|
|
&proposal_instruction_cookie2,
|
|
)
|
|
.await
|
|
.err()
|
|
.unwrap();
|
|
|
|
// Assert
|
|
assert_eq!(
|
|
err,
|
|
GovernanceError::InvalidProposalForProposalInstruction.into()
|
|
);
|
|
}
|