Skip to content

Commit

Permalink
feat: use consts for addrs (filecoin-project#660)
Browse files Browse the repository at this point in the history
* feat: use consts for addrs

And expose actor IDs so we don't need to call `.id().unwrap()` to
retrieve them.

* remove old TODO and extern crate refs

Co-authored-by: mriise <[email protected]>
  • Loading branch information
2 people authored and shamb0 committed Jan 31, 2023
1 parent 6c879d3 commit abb573c
Show file tree
Hide file tree
Showing 46 changed files with 670 additions and 451 deletions.
7 changes: 7 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion actors/account/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(std::iter::once(&*SYSTEM_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&SYSTEM_ACTOR_ADDR))?;
match address.protocol() {
Protocol::Secp256k1 | Protocol::BLS => {}
protocol => {
Expand Down
6 changes: 3 additions & 3 deletions actors/account/tests/account_actor_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ macro_rules! account_constructor_tests {
caller_type: SYSTEM_ACTOR_CODE_ID.clone(),
..Default::default()
};
rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);

if exit_code.is_success() {
rt.call::<AccountActor>(1, &RawBytes::serialize(addr).unwrap()).unwrap();
Expand Down Expand Up @@ -157,13 +157,13 @@ account_constructor_tests! {
fn authenticate_message() {
let mut rt = MockRuntime {
receiver: Address::new_id(100),
caller: *SYSTEM_ACTOR_ADDR,
caller: SYSTEM_ACTOR_ADDR,
caller_type: *SYSTEM_ACTOR_CODE_ID,
..Default::default()
};

let addr = Address::new_secp256k1(&[2; fvm_shared::address::SECP_PUB_LEN]).unwrap();
rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);

rt.call::<AccountActor>(1, &RawBytes::serialize(addr).unwrap()).unwrap();

Expand Down
4 changes: 2 additions & 2 deletions actors/cron/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(std::iter::once(&*SYSTEM_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&SYSTEM_ACTOR_ADDR))?;
rt.create(&State { entries: params.entries })?;
Ok(())
}
Expand All @@ -59,7 +59,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(std::iter::once(&*SYSTEM_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&SYSTEM_ACTOR_ADDR))?;

let st: State = rt.state()?;
for entry in st.entries {
Expand Down
6 changes: 3 additions & 3 deletions actors/cron/tests/cron_actor_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ fn check_state(rt: &MockRuntime) {
fn construct_runtime() -> MockRuntime {
MockRuntime {
receiver: Address::new_id(100),
caller: *SYSTEM_ACTOR_ADDR,
caller: SYSTEM_ACTOR_ADDR,
caller_type: *SYSTEM_ACTOR_CODE_ID,
..Default::default()
}
Expand Down Expand Up @@ -114,14 +114,14 @@ fn epoch_tick_with_entries() {
}

fn construct_and_verify(rt: &mut MockRuntime, params: &ConstructorParams) {
rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);
let ret = rt.call::<CronActor>(1, &RawBytes::serialize(&params).unwrap()).unwrap();
assert_eq!(RawBytes::default(), ret);
rt.verify();
}

fn epoch_tick_and_verify(rt: &mut MockRuntime) {
rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);
let ret = rt.call::<CronActor>(2, &RawBytes::default()).unwrap();
assert_eq!(RawBytes::default(), ret);
rt.verify();
Expand Down
8 changes: 4 additions & 4 deletions actors/init/tests/init_actor_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ fn check_state(rt: &MockRuntime) {
fn construct_runtime() -> MockRuntime {
MockRuntime {
receiver: Address::new_id(1000),
caller: *SYSTEM_ACTOR_ADDR,
caller: SYSTEM_ACTOR_ADDR,
caller_type: *SYSTEM_ACTOR_CODE_ID,
..Default::default()
}
Expand Down Expand Up @@ -163,7 +163,7 @@ fn create_storage_miner() {
construct_and_verify(&mut rt);

// only the storage power actor can create a miner
rt.set_caller(*POWER_ACTOR_CODE_ID, *STORAGE_POWER_ACTOR_ADDR);
rt.set_caller(*POWER_ACTOR_CODE_ID, STORAGE_POWER_ACTOR_ADDR);

let unique_address = Address::new_actor(b"miner");
rt.new_actor_addr = Some(unique_address);
Expand Down Expand Up @@ -248,7 +248,7 @@ fn sending_constructor_failure() {
construct_and_verify(&mut rt);

// Only the storage power actor can create a miner
rt.set_caller(*POWER_ACTOR_CODE_ID, *STORAGE_POWER_ACTOR_ADDR);
rt.set_caller(*POWER_ACTOR_CODE_ID, STORAGE_POWER_ACTOR_ADDR);

// Assign new address for the storage actor miner
let unique_address = Address::new_actor(b"miner");
Expand Down Expand Up @@ -288,7 +288,7 @@ fn sending_constructor_failure() {
}

fn construct_and_verify(rt: &mut MockRuntime) {
rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);
let params = ConstructorParams { network_name: "mock".to_string() };
let ret =
rt.call::<InitActor>(METHOD_CONSTRUCTOR, &RawBytes::serialize(&params).unwrap()).unwrap();
Expand Down
4 changes: 2 additions & 2 deletions actors/market/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(std::iter::once(&*SYSTEM_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&SYSTEM_ACTOR_ADDR))?;

let st = State::new(rt.store()).map_err(|e| {
e.downcast_default(ExitCode::USR_ILLEGAL_STATE, "Failed to create market state")
Expand Down Expand Up @@ -785,7 +785,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(std::iter::once(&*CRON_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&CRON_ACTOR_ADDR))?;

let mut amount_slashed = TokenAmount::zero();
let curr_epoch = rt.curr_epoch();
Expand Down
2 changes: 1 addition & 1 deletion actors/market/tests/cron_tick_deal_slashing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,7 @@ fn slash_multiple_deals_in_the_same_epoch() {
+ &deal_proposal2.provider_collateral
+ &deal_proposal3.provider_collateral;
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
total_slashed,
Expand Down
33 changes: 30 additions & 3 deletions actors/market/tests/cron_tick_timedout_deals.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ fn timed_out_deal_is_slashed_and_deleted() {
// do a cron tick for it -> should time out and get slashed
rt.set_epoch(process_epoch(START_EPOCH, deal_id));
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
deal_proposal.provider_collateral.clone(),
Expand Down Expand Up @@ -114,7 +114,7 @@ fn publishing_timed_out_deal_again_should_work_after_cron_tick_as_it_should_no_l
// do a cron tick for it -> should time out and get slashed
rt.set_epoch(process_epoch(START_EPOCH, deal_id));
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
deal_proposal.provider_collateral.clone(),
Expand Down Expand Up @@ -177,9 +177,36 @@ fn timed_out_and_verified_deals_are_slashed_deleted() {
// ONLY deal1 and deal2 should be sent to the Registry actor
rt.set_epoch(process_epoch(START_EPOCH, *deal_ids.last().unwrap()));

// expected sends to the registry actor
let param1 = RestoreBytesParams {
address: deal1.client,
deal_size: StoragePower::from(deal1.piece_size.0),
};
let param2 = RestoreBytesParams {
address: deal2.client,
deal_size: StoragePower::from(deal2.piece_size.0),
};

rt.expect_send(
VERIFIED_REGISTRY_ACTOR_ADDR,
ext::verifreg::RESTORE_BYTES_METHOD as u64,
RawBytes::serialize(param1).unwrap(),
TokenAmount::zero(),
RawBytes::default(),
ExitCode::OK,
);
rt.expect_send(
VERIFIED_REGISTRY_ACTOR_ADDR,
ext::verifreg::RESTORE_BYTES_METHOD as u64,
RawBytes::serialize(param2).unwrap(),
TokenAmount::zero(),
RawBytes::default(),
ExitCode::OK,
);

let expected_burn = 3 * &deal1.provider_collateral;
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
expected_burn,
Expand Down
22 changes: 11 additions & 11 deletions actors/market/tests/harness.rs
Original file line number Diff line number Diff line change
Expand Up @@ -85,8 +85,8 @@ pub fn setup() -> MockRuntime {
]);

let mut rt = MockRuntime {
receiver: *STORAGE_MARKET_ACTOR_ADDR,
caller: *SYSTEM_ACTOR_ADDR,
receiver: STORAGE_MARKET_ACTOR_ADDR,
caller: SYSTEM_ACTOR_ADDR,
caller_type: *INIT_ACTOR_CODE_ID,
actor_code_cids,
balance: RefCell::new(TokenAmount::from_whole(10)),
Expand Down Expand Up @@ -114,7 +114,7 @@ pub fn check_state_with_expected(rt: &MockRuntime, expected_patterns: &[Regex])
}

pub fn construct_and_verify(rt: &mut MockRuntime) {
rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);
assert_eq!(
RawBytes::default(),
rt.call::<MarketActor>(METHOD_CONSTRUCTOR, &RawBytes::default()).unwrap()
Expand Down Expand Up @@ -371,7 +371,7 @@ pub fn cron_tick_and_assert_balances(
let mut payment_end = d.end_epoch;
if s.slash_epoch != EPOCH_UNDEFINED {
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
d.provider_collateral.clone(),
Expand Down Expand Up @@ -515,9 +515,9 @@ pub fn publish_deals(
new_allocations: vec![alloc_id],
};
rt.expect_send(
*DATACAP_TOKEN_ACTOR_ADDR,
ext::datacap::TRANSFER_FROM_METHOD as u64,
serialize(&params, "transfer from params").unwrap(),
VERIFIED_REGISTRY_ACTOR_ADDR,
ext::verifreg::USE_BYTES_METHOD as u64,
param,
TokenAmount::zero(),
serialize(
&TransferFromReturn {
Expand Down Expand Up @@ -628,8 +628,8 @@ pub fn cron_tick(rt: &mut MockRuntime) {
}

pub fn cron_tick_raw(rt: &mut MockRuntime) -> Result<RawBytes, ActorError> {
rt.expect_validate_caller_addr(vec![*CRON_ACTOR_ADDR]);
rt.set_caller(*CRON_ACTOR_CODE_ID, *CRON_ACTOR_ADDR);
rt.expect_validate_caller_addr(vec![CRON_ACTOR_ADDR]);
rt.set_caller(*CRON_ACTOR_CODE_ID, CRON_ACTOR_ADDR);

rt.call::<MarketActor>(Method::CronTick as u64, &RawBytes::default())
}
Expand All @@ -652,15 +652,15 @@ pub fn expect_query_network_info(rt: &mut MockRuntime) {
this_epoch_reward_smoothed: epoch_reward_smooth,
};
rt.expect_send(
*REWARD_ACTOR_ADDR,
REWARD_ACTOR_ADDR,
RewardMethod::ThisEpochReward as u64,
RawBytes::default(),
TokenAmount::zero(),
RawBytes::serialize(current_reward).unwrap(),
ExitCode::OK,
);
rt.expect_send(
*STORAGE_POWER_ACTOR_ADDR,
STORAGE_POWER_ACTOR_ADDR,
PowerMethod::CurrentTotalPower as u64,
RawBytes::default(),
TokenAmount::zero(),
Expand Down
16 changes: 8 additions & 8 deletions actors/market/tests/market_actor_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,12 +53,12 @@ fn test_remove_all_error() {
fn simple_construction() {
let mut rt = MockRuntime {
receiver: Address::new_id(100),
caller: *SYSTEM_ACTOR_ADDR,
caller: SYSTEM_ACTOR_ADDR,
caller_type: *INIT_ACTOR_CODE_ID,
..Default::default()
};

rt.expect_validate_caller_addr(vec![*SYSTEM_ACTOR_ADDR]);
rt.expect_validate_caller_addr(vec![SYSTEM_ACTOR_ADDR]);

assert_eq!(
RawBytes::default(),
Expand Down Expand Up @@ -896,9 +896,9 @@ fn provider_and_client_addresses_are_resolved_before_persisting_state_and_sent_t
.unwrap(),
};
rt.expect_send(
*DATACAP_TOKEN_ACTOR_ADDR,
ext::datacap::TRANSFER_FROM_METHOD as u64,
serialize(&transfer_params, "transfer from params").unwrap(),
VERIFIED_REGISTRY_ACTOR_ADDR,
ext::verifreg::USE_BYTES_METHOD as u64,
param,
TokenAmount::zero(),
serialize(&transfer_return, "transfer from return").unwrap(),
ExitCode::OK,
Expand Down Expand Up @@ -1343,7 +1343,7 @@ fn slash_a_deal_and_make_payment_for_another_deal_in_the_same_epoch() {

// cron tick will slash deal1 and make payment for deal2
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
d1.provider_collateral.clone(),
Expand Down Expand Up @@ -1586,7 +1586,7 @@ fn locked_fund_tracking_states() {
let curr = process_epoch(start_epoch, deal_id3);
rt.set_epoch(curr);
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
d3.provider_collateral.clone(),
Expand Down Expand Up @@ -1627,7 +1627,7 @@ fn locked_fund_tracking_states() {
clc = TokenAmount::zero();
plc = TokenAmount::zero();
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
d1.provider_collateral,
Expand Down
2 changes: 1 addition & 1 deletion actors/market/tests/random_cron_epoch_during_publish.rs
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ fn cron_processing_of_deal_after_missed_activation_should_fail_and_slash() {

// FIXME: cron_tick calls 'VERIFIED_REGISTRY_ACTOR_ADDR' with the 'USE_BYTES_METHOD' method.
rt.expect_send(
*BURNT_FUNDS_ACTOR_ADDR,
BURNT_FUNDS_ACTOR_ADDR,
METHOD_SEND,
RawBytes::default(),
deal_proposal.provider_collateral.clone(),
Expand Down
8 changes: 4 additions & 4 deletions actors/miner/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(&[*INIT_ACTOR_ADDR])?;
rt.validate_immediate_caller_is(std::iter::once(&INIT_ACTOR_ADDR))?;

check_control_addresses(rt.policy(), &params.control_addresses)?;
check_peer_info(rt.policy(), &params.peer_id, &params.multi_addresses)?;
Expand Down Expand Up @@ -2050,7 +2050,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(iter::once(&*STORAGE_POWER_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(iter::once(&STORAGE_POWER_ACTOR_ADDR))?;

// This should be enforced by the power actor. We log here just in case
// something goes wrong.
Expand Down Expand Up @@ -3022,7 +3022,7 @@ impl Actor {
let (pledge_delta_total, to_burn) = rt.transaction(|st: &mut State, rt| {
let mut pledge_delta_total = TokenAmount::zero();

rt.validate_immediate_caller_is(std::iter::once(&*REWARD_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&REWARD_ACTOR_ADDR))?;

let (reward_to_lock, locked_reward_vesting_spec) =
locked_reward_from_reward(params.reward);
Expand Down Expand Up @@ -3486,7 +3486,7 @@ impl Actor {
BS: Blockstore,
RT: Runtime<BS>,
{
rt.validate_immediate_caller_is(std::iter::once(&*STORAGE_POWER_ACTOR_ADDR))?;
rt.validate_immediate_caller_is(std::iter::once(&STORAGE_POWER_ACTOR_ADDR))?;

let payload: CronEventPayload = from_slice(&params.event_payload).map_err(|e| {
actor_error!(
Expand Down
Loading

0 comments on commit abb573c

Please sign in to comment.