Skip to content

Commit

Permalink
chore(power): add CurrentTotalPowerReturn serialization tests
Browse files Browse the repository at this point in the history
plus a minor naming fix
  • Loading branch information
rvagg committed Oct 1, 2024
1 parent 01a05fc commit db28a77
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 2 deletions.
1 change: 1 addition & 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/market/src/ext.rs
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@ pub mod power {
pub const CURRENT_TOTAL_POWER_METHOD: u64 = 9;

#[derive(Serialize_tuple, Deserialize_tuple)]
pub struct CurrentTotalPowerReturnParams {
pub struct CurrentTotalPowerReturn {
#[serde(with = "bigint_ser")]
pub raw_byte_power: StoragePower,
#[serde(with = "bigint_ser")]
Expand Down
2 changes: 1 addition & 1 deletion actors/market/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1775,7 +1775,7 @@ fn request_current_baseline_power(rt: &impl Runtime) -> Result<StoragePower, Act
fn request_current_network_power(
rt: &impl Runtime,
) -> Result<(StoragePower, StoragePower), ActorError> {
let ret: ext::power::CurrentTotalPowerReturnParams =
let ret: ext::power::CurrentTotalPowerReturn =
deserialize_block(extract_send_result(rt.send_simple(
&STORAGE_POWER_ACTOR_ADDR,
ext::power::CURRENT_TOTAL_POWER_METHOD,
Expand Down
1 change: 1 addition & 0 deletions actors/power/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ fvm_ipld_encoding = { workspace = true }
[dev-dependencies]
fil_actors_runtime = { workspace = true, features = ["test_utils", "sector-default"] }
fil_actor_reward = { workspace = true }
const-hex = { workspace = true }

[features]
fil-actor = ["fil_actors_runtime/fil-actor"]
48 changes: 48 additions & 0 deletions actors/power/tests/types_test.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
// Tests to match with Go github.com/filecoin-project/go-state-types/builtin/*/power
mod serialization {
use fil_actor_power::CurrentTotalPowerReturn;
use fvm_ipld_encoding::ipld_block::IpldBlock;

use fil_actors_runtime::reward::FilterEstimate;
use fvm_shared::bigint::BigInt;
use fvm_shared::econ::TokenAmount;
use fvm_shared::sector::StoragePower;

#[test]
fn current_total_power_return() {
let test_cases = vec![
(
CurrentTotalPowerReturn {
raw_byte_power: Default::default(),
quality_adj_power: Default::default(),
pledge_collateral: Default::default(),
quality_adj_power_smoothed: Default::default(),
ramp_start_epoch: Default::default(),
ramp_duration_epochs: Default::default(),
},
// [byte[],byte[],byte[],[byte[],byte[]],0,0]
"864040408240400000",
),
(
CurrentTotalPowerReturn {
raw_byte_power: StoragePower::from(1 << 20),
quality_adj_power: StoragePower::from(1 << 21),
pledge_collateral: TokenAmount::from_atto(1 << 22),
quality_adj_power_smoothed: FilterEstimate::new(BigInt::from(1 << 23), BigInt::from(1 << 24)),
ramp_start_epoch: 25,
ramp_duration_epochs: 26,
},
// FilterEstimate BigInts have a precision shift of 128, so they end up larger than the others.
// [byte[00100000],byte[00200000],byte[00400000],[byte[0080000000000000000000000000000000000000],byte[000100000000000000000000000000000000000000]],25,26]
"8644001000004400200000440040000082540080000000000000000000000000000000000000550001000000000000000000000000000000000000001819181a",
),
];

for (params, expected_hex) in test_cases {
let encoded = IpldBlock::serialize_cbor(&params).unwrap().unwrap();
assert_eq!(const_hex::encode(&encoded.data), expected_hex);
let decoded: CurrentTotalPowerReturn = IpldBlock::deserialize(&encoded).unwrap();
assert_eq!(params, decoded);
}
}
}

0 comments on commit db28a77

Please sign in to comment.