Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add update settings tests #506

Merged
merged 6 commits into from
Aug 31, 2023
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions starknet/src/tests.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ mod test_factory;
mod test_space;
mod test_upgrade;
mod test_stark_tx_auth;
mod test_update_settings;

mod proposal_validation_strategies;
mod voting_strategies;
Expand Down
18 changes: 9 additions & 9 deletions starknet/src/tests/setup/setup.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,9 @@ mod setup {
#[derive(Drop)]
struct Config {
owner: ContractAddress,
min_voting_duration: u64,
max_voting_duration: u64,
voting_delay: u64,
min_voting_duration: u32,
max_voting_duration: u32,
voting_delay: u32,
proposal_validation_strategy: Strategy,
voting_strategies: Array<Strategy>,
authenticators: Array<ContractAddress>,
Expand All @@ -37,9 +37,9 @@ mod setup {

// Space Settings
let owner = contract_address_const::<0x123456789>();
let max_voting_duration = 2_u64;
let min_voting_duration = 1_u64;
let voting_delay = 1_u64;
let max_voting_duration = 2_u32;
let min_voting_duration = 1_u32;
let voting_delay = 1_u32;
let quorum = u256_from_felt252(1);

// Deploy Vanilla Authenticator
Expand Down Expand Up @@ -98,9 +98,9 @@ mod setup {

fn get_initialize_calldata(
owner: @ContractAddress,
min_voting_duration: @u64,
max_voting_duration: @u64,
voting_delay: @u64,
min_voting_duration: @u32,
max_voting_duration: @u32,
voting_delay: @u32,
proposal_validation_strategy: @Strategy,
voting_strategies: @Array<Strategy>,
authenticators: @Array<ContractAddress>
Expand Down
279 changes: 279 additions & 0 deletions starknet/src/tests/test_update_settings.cairo
Original file line number Diff line number Diff line change
@@ -0,0 +1,279 @@
#[cfg(test)]
mod tests {
use sx::space::space::{Space, ISpaceDispatcher, ISpaceDispatcherTrait};
use sx::tests::setup::setup::setup::{setup, deploy, Config};
use sx::types::{UpdateSettingsCalldata, UpdateSettingsCalldataImpl};
use sx::tests::utils::strategy_trait::{StrategyImpl};
use starknet::testing;
use starknet::info;
use starknet::contract_address_const;
use clone::Clone;
use array::{ArrayTrait, SpanTrait};
use serde::Serde;

fn setup_update_settings() -> (Config, ISpaceDispatcher) {
let config = setup();
let (_, space) = deploy(@config);

testing::set_caller_address(config.owner);
testing::set_contract_address(config.owner);

(config, space)
}

#[test]
#[available_gas(10000000000)]
#[should_panic(expected: ('Caller is not the owner', 'ENTRYPOINT_FAILED'))]
fn update_unauthorized() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();

testing::set_contract_address(contract_address_const::<'unauthorized'>());
space.update_settings(input);
}

#[test]
#[available_gas(10000000000)]
fn update_min_voting_duration() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.min_voting_duration = config.min_voting_duration + 1;

space.update_settings(input.clone());

assert(
space.min_voting_duration() == input.min_voting_duration,
'Min voting duration not updated'
);
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
// #[should_panic(expected: ('Invalid duration', 'ENTRYPOINT_FAILED'))] // TODO: uncomment once PR is merged
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

which PR is this?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

#505 fixed the update_settings function

fn update_min_voting_duration_too_big() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.min_voting_duration = config.max_voting_duration + 1;

space.update_settings(input.clone());
}


#[test]
#[available_gas(10000000000)]
fn update_max_voting_duration() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.max_voting_duration = config.max_voting_duration + 1;

space.update_settings(input.clone());

assert(
space.max_voting_duration() == input.max_voting_duration,
'Max voting duration not updated'
);
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
// #[should_panic(expected: ('Invalid duration', 'ENTRYPOINT_FAILED'))] // TODO: uncomment once PR is merged
fn update_max_voting_duration_too_small() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.max_voting_duration = config.min_voting_duration - 1;

space.update_settings(input.clone());
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn update_min_max_voting_duration_at_once() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.min_voting_duration = config.max_voting_duration + 1;
input.max_voting_duration = config.max_voting_duration + 2;

space.update_settings(input.clone());
assert(
space.min_voting_duration() == input.min_voting_duration,
'Min voting duration not updated'
);
assert(
space.max_voting_duration() == input.max_voting_duration,
'Max voting duration not updated'
);
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
// #[should_panic(expected: ('Invalid duration', 'ENTRYPOINT_FAILED'))] // TODO: uncomment once PR is merged
fn update_min_max_voting_duration_at_once_invalid() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.min_voting_duration = config.max_voting_duration + 1;
input
.max_voting_duration = config
.max_voting_duration; // min is bigger than max, should fail

space.update_settings(input.clone());
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn update_voting_delay() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
input.voting_delay = config.voting_delay + 1;

space.update_settings(input.clone());

assert(space.voting_delay() == input.voting_delay, 'Voting delay not updated');
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn metadata_uri() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
let mut arr = array![];
'hello!'.serialize(ref arr);
input.metadata_URI = arr;

space.update_settings(input.clone());
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn dao_uri() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
let mut arr = array![];
'hello!'.serialize(ref arr);
input.dao_URI = arr;

space.update_settings(input.clone());
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn proposal_validation_strategy() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
let randomStrategy = StrategyImpl::from_address(
contract_address_const::<'randomStrategy'>()
);
input.proposal_validation_strategy = randomStrategy;
let mut arr = array![];
'hello!'.serialize(ref arr);
input.proposal_validation_strategy_metadata_URI = arr;

space.update_settings(input.clone());

assert(
space.proposal_validation_strategy() == input.proposal_validation_strategy,
'Proposal strategy not updated'
);
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn add_authenticators() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
let auth1 = contract_address_const::<'authenticator1'>();
let auth2 = contract_address_const::<'authenticator2'>();
let mut arr = array![auth1, auth2];
input.authenticators_to_add = arr;

space.update_settings(input.clone());

assert(space.authenticators(auth1) == true, 'Authenticator 1 not added');

assert(space.authenticators(auth2) == true, 'Authenticator 2 not added');
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn remove_authenticators() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();
let auth1 = *config.authenticators.at(0);
let mut arr = array![auth1];
input.authenticators_to_remove = arr;

space.update_settings(input.clone());

assert(space.authenticators(auth1) == false, 'Authenticator not removed');
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
fn add_voting_strategies() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();

let vs1 = StrategyImpl::from_address(contract_address_const::<'votingStrategy1'>());
let vs2 = StrategyImpl::from_address(contract_address_const::<'votingStrategy2'>());

let mut arr = array![vs1.clone(), vs2.clone()];
input.voting_strategies_to_add = arr;

space.update_settings(input);

assert(space.voting_strategies(1) == vs1, 'Voting strategy 1 not added');
assert(space.voting_strategies(2) == vs2, 'Voting strategy 2 not added');
assert(space.active_voting_strategies() == 0b111, 'Voting strategies not active');
// TODO: check event once it's been added
// voting_strategies_metadata_URIs_to_add: Array<Array<felt252>>,
}


#[test]
#[available_gas(10000000000)]
fn remove_voting_strategies() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();

// First, add a new voting strategy
let vs1 = StrategyImpl::from_address(contract_address_const::<'votingStrategy1'>());
let mut arr = array![vs1.clone()];
input.voting_strategies_to_add = arr;
space.update_settings(input);
assert(space.voting_strategies(1) == vs1, 'Voting strategy 1 not added');
assert(space.active_voting_strategies() == 0b11, 'Voting strategy not active');

// Now, remove the first voting strategy
let mut input = UpdateSettingsCalldataImpl::default();
let mut arr = array![0];
input.voting_strategies_to_remove = arr;

space.update_settings(input);
assert(space.active_voting_strategies() == 0b10, 'strategy not removed');
// TODO: check event once it's been added
}

#[test]
#[available_gas(10000000000)]
#[should_panic(expected: ('No active voting strategy left', 'ENTRYPOINT_FAILED'))]
fn remove_all_voting_strategies() {
let (config, space) = setup_update_settings();
let mut input = UpdateSettingsCalldataImpl::default();

// Remove the first voting strategy
let mut arr = array![0];
input.voting_strategies_to_remove = arr;

space.update_settings(input);
}
}
8 changes: 4 additions & 4 deletions starknet/src/tests/voting_strategies/erc20_votes.cairo
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ mod tests {

// Advance to vote start + 1
let current = info::get_block_timestamp();
testing::set_block_timestamp(current + config.voting_delay + 1);
testing::set_block_timestamp(current + config.voting_delay.into() + 1);

let mut vote_calldata = array::ArrayTrait::<felt252>::new();
let voter = *accounts.at(0);
Expand All @@ -196,7 +196,7 @@ mod tests {
// Vote on proposal
authenticator.authenticate(space.contract_address, VOTE_SELECTOR, vote_calldata);

testing::set_block_timestamp(current + config.max_voting_duration);
testing::set_block_timestamp(current + config.max_voting_duration.into());

// Execute proposal
space.execute(1_u256, vanilla_execution_strategy.params);
Expand Down Expand Up @@ -234,7 +234,7 @@ mod tests {

// Move to the exact voting period start so the strategy will revert.
let current = info::get_block_timestamp();
testing::set_block_timestamp(current + config.voting_delay);
testing::set_block_timestamp(current + config.voting_delay.into());

let mut vote_calldata = array::ArrayTrait::<felt252>::new();
let voter = *accounts.at(0);
Expand Down Expand Up @@ -286,7 +286,7 @@ mod tests {

// Move to the exact voting period start + 1
let current = info::get_block_timestamp();
testing::set_block_timestamp(current + config.voting_delay + 1);
testing::set_block_timestamp(current + config.voting_delay.into() + 1);

let mut vote_calldata = array::ArrayTrait::<felt252>::new();
let voter = *accounts.at(0);
Expand Down
Loading