diff --git a/bindings/nodejs/examples/client/11-build-output.ts b/bindings/nodejs/examples/client/11-build-output.ts index 2e0516dcac..a34ad3876d 100644 --- a/bindings/nodejs/examples/client/11-build-output.ts +++ b/bindings/nodejs/examples/client/11-build-output.ts @@ -79,7 +79,7 @@ async function run() { addressUnlockCondition, new ExpirationUnlockCondition( new Ed25519Address(hexAddress), - BigInt(1), + 1, ), ], }); @@ -91,7 +91,7 @@ async function run() { amount: BigInt(1000000), unlockConditions: [ addressUnlockCondition, - new TimelockUnlockCondition(BigInt(1)), + new TimelockUnlockCondition(1), ], }); diff --git a/bindings/nodejs/examples/how_tos/advanced_transactions/advanced_transaction.ts b/bindings/nodejs/examples/how_tos/advanced_transactions/advanced_transaction.ts index 072215dbc1..13d22cd700 100644 --- a/bindings/nodejs/examples/how_tos/advanced_transactions/advanced_transaction.ts +++ b/bindings/nodejs/examples/how_tos/advanced_transactions/advanced_transaction.ts @@ -39,7 +39,7 @@ async function run() { // Create an output with amount 1_000_000 and a timelock of 1 hour // TODO Make the slot index properly 1h ahead - const slotIndex = BigInt(1000); + const slotIndex = 1000; const basicOutput = await client.buildBasicOutput({ unlockConditions: [ new AddressUnlockCondition( diff --git a/bindings/nodejs/examples/how_tos/outputs/unlock-conditions.ts b/bindings/nodejs/examples/how_tos/outputs/unlock-conditions.ts index a8fc1d3512..e5f4e901ed 100644 --- a/bindings/nodejs/examples/how_tos/outputs/unlock-conditions.ts +++ b/bindings/nodejs/examples/how_tos/outputs/unlock-conditions.ts @@ -66,7 +66,7 @@ async function run() { const basicOutputWithTimelock = await client.buildBasicOutput({ unlockConditions: [ addressUnlockCondition, - new TimelockUnlockCondition(BigInt(1)), + new TimelockUnlockCondition(1), ], }); @@ -76,7 +76,7 @@ async function run() { addressUnlockCondition, new ExpirationUnlockCondition( new Ed25519Address(hexAddress), - BigInt(1), + 1, ), ], }); diff --git a/bindings/nodejs/lib/types/block/output/feature.ts b/bindings/nodejs/lib/types/block/output/feature.ts index 0767fdf85c..ba396da321 100644 --- a/bindings/nodejs/lib/types/block/output/feature.ts +++ b/bindings/nodejs/lib/types/block/output/feature.ts @@ -9,6 +9,7 @@ import { BlockIssuerKeyDiscriminator, } from './block-issuer-key'; import { u64 } from '../../utils/type-aliases'; +import { EpochIndex } from '../../block/slot'; /** * All of the feature block types. @@ -144,17 +145,17 @@ class StakingFeature extends Feature { /** * The epoch index in which the staking started. */ - readonly startEpoch: u64; + readonly startEpoch: EpochIndex; /** * The epoch index in which the staking ends. */ - readonly endEpoch: u64; + readonly endEpoch: EpochIndex; constructor( stakedAmount: u64, fixedCost: u64, - startEpoch: u64, - endEpoch: u64, + startEpoch: EpochIndex, + endEpoch: EpochIndex, ) { super(FeatureType.Staking); this.stakedAmount = stakedAmount; diff --git a/bindings/nodejs/lib/types/block/output/output.ts b/bindings/nodejs/lib/types/block/output/output.ts index 9fbf608c7e..2f5ce7b90d 100644 --- a/bindings/nodejs/lib/types/block/output/output.ts +++ b/bindings/nodejs/lib/types/block/output/output.ts @@ -13,6 +13,7 @@ import { HexEncodedString, hexToBigInt, u64 } from '../../utils'; import { TokenScheme, TokenSchemeDiscriminator } from './token-scheme'; import { INativeToken } from '../../models'; import { AccountId, DelegationId } from '../id'; +import { EpochIndex } from '../../block/slot'; export type OutputId = string; @@ -327,11 +328,11 @@ class DelegationOutput extends Output { /** * The index of the first epoch for which this output delegates. */ - readonly startEpoch: u64; + readonly startEpoch: EpochIndex; /** * The index of the last epoch for which this output delegates. */ - readonly endEpoch: u64; + readonly endEpoch: EpochIndex; /** * The unlock conditions for the output. */ @@ -354,8 +355,8 @@ class DelegationOutput extends Output { delegatedAmount: u64, delegationId: DelegationId, validatorId: AccountId, - startEpoch: u64, - endEpoch: u64, + startEpoch: EpochIndex, + endEpoch: EpochIndex, unlockConditions: UnlockCondition[], ) { super(OutputType.Delegation, amount); diff --git a/bindings/nodejs/lib/types/block/slot/commitment.ts b/bindings/nodejs/lib/types/block/slot/commitment.ts index d459b9ad4a..25e105b9e6 100644 --- a/bindings/nodejs/lib/types/block/slot/commitment.ts +++ b/bindings/nodejs/lib/types/block/slot/commitment.ts @@ -8,7 +8,15 @@ import { u64 } from '../..'; * To calculate the slot index of a timestamp, `genesisTimestamp` and the duration of a slot are needed. * The slot index of timestamp `ts` is `(ts - genesisTimestamp)/duration + 1`. */ -type SlotIndex = u64; +type SlotIndex = number; + +/** + * The tangle timeline is divided into epochs, and each epoch has a corresponding epoch index. + * Epochs are further subdivided into slots, each with a `SlotIndex. + * To calculate the epoch index of a timestamp, `slotsPerEpochExponent` and `slotDurationInSeconds` are needed. + * An epoch consists of `2^slotsPerEpochExponent` slots. + */ +type EpochIndex = number; /** * Identifier of a slot commitment @@ -59,4 +67,4 @@ class SlotCommitment { } } -export { SlotCommitment, SlotIndex, SlotCommitmentId, RootsId }; +export { SlotCommitment, SlotIndex, EpochIndex, SlotCommitmentId, RootsId }; diff --git a/bindings/nodejs/lib/types/models/info/node-info-protocol.ts b/bindings/nodejs/lib/types/models/info/node-info-protocol.ts index 3d8650a53f..d4f330feac 100644 --- a/bindings/nodejs/lib/types/models/info/node-info-protocol.ts +++ b/bindings/nodejs/lib/types/models/info/node-info-protocol.ts @@ -3,6 +3,7 @@ import { u64 } from '../../utils'; import type { RentStructure } from '../rent-structure'; +import { EpochIndex } from '../../block/slot'; /** * The Protocol Info. @@ -11,7 +12,7 @@ export interface ProtocolInfo { /** * The start epoch of the set of protocol parameters. */ - startEpoch: string; + startEpoch: EpochIndex; /** * The protocol parameters. */ @@ -69,7 +70,7 @@ export interface ProtocolParameters { /** * The unbonding period in epochs before an account can stop staking. */ - stakingUnbondingPeriod: u64; + stakingUnbondingPeriod: number; /** * The number of validation blocks that each validator should issue each slot. */ @@ -77,23 +78,23 @@ export interface ProtocolParameters { /** * The number of epochs worth of Mana that a node is punished with for each additional validation block it issues. */ - punishmentEpochs: u64; + punishmentEpochs: number; /** * Determine if a block is eligible by evaluating issuingTime and commitments in its pastcone to ATT and lastCommittedSlot respectively. */ - livenessThreshold: u64; + livenessThreshold: number; /** * MinCommittableAge is the minimum age relative to the accepted tangle time slot index that a slot can be committed. */ - minCommittableAge: u64; + minCommittableAge: number; /** * MaxCommittableAge is the maximum age for a slot commitment to be included in a block relative to the slot index of the block issuing time. */ - maxCommittableAge: u64; + maxCommittableAge: number; /** * Determine the slot that should trigger a new committee selection for the next and upcoming epoch. */ - epochNearingThreshold: u64; + epochNearingThreshold: number; /** * Congestion Control Parameters defines the parameters used to calculate the Reference Mana Cost (RMC). */ diff --git a/bindings/nodejs/lib/types/models/info/node-info-status.ts b/bindings/nodejs/lib/types/models/info/node-info-status.ts index ee4d1ca608..ff8d30c223 100644 --- a/bindings/nodejs/lib/types/models/info/node-info-status.ts +++ b/bindings/nodejs/lib/types/models/info/node-info-status.ts @@ -1,6 +1,8 @@ // Copyright 2023 IOTA Stiftung // SPDX-License-Identifier: Apache-2.0 +import { SlotIndex, EpochIndex } from '../../block/slot'; + /** * Response from the /info endpoint. */ @@ -32,17 +34,17 @@ export interface INodeInfoStatus { /** * The index of latest finalized slot. */ - latestFinalizedSlot: string; + latestFinalizedSlot: SlotIndex; /** * The slot index of the latest accepted block. */ - latestAcceptedBlockSlot?: string; + latestAcceptedBlockSlot?: SlotIndex; /** * The slot index of the latest confirmed block. */ - latestConfirmedBlockSlot?: string; + latestConfirmedBlockSlot?: SlotIndex; /** * The index of the epoch before which the tangle history is pruned. */ - pruningEpoch: string; + pruningEpoch: EpochIndex; } diff --git a/bindings/nodejs/package-lock.json b/bindings/nodejs/package-lock.json index b403c0ae1b..febb78cce6 100644 --- a/bindings/nodejs/package-lock.json +++ b/bindings/nodejs/package-lock.json @@ -11630,7 +11630,7 @@ "request": "2", "rimraf": "2", "semver": "~5.3.0", - "tar": "^2.0.0", + "tar": "^4.4.19", "which": "1" }, "dependencies": { diff --git a/bindings/nodejs/yarn.lock b/bindings/nodejs/yarn.lock index bee775a740..ea11c101f6 100644 --- a/bindings/nodejs/yarn.lock +++ b/bindings/nodejs/yarn.lock @@ -4051,7 +4051,7 @@ "inherits" "^2.0.3" "readable-stream" "^3.1.1" -"tar@^2.0.0", "tar@^4.4.19": +"tar@^4.4.19": "integrity" "sha512-a20gEsvHnWe0ygBY8JbxoM4w3SJdhc7ZAuxkLqh+nvNQN2IOt0B5lLgM490X5Hl8FF0dl0tOf2ewFYAlIFgzVA==" "resolved" "https://registry.npmjs.org/tar/-/tar-4.4.19.tgz" "version" "4.4.19" diff --git a/sdk/src/types/api/plugins/participation/responses.rs b/sdk/src/types/api/plugins/participation/responses.rs index 9f38a22b28..09745e021b 100644 --- a/sdk/src/types/api/plugins/participation/responses.rs +++ b/sdk/src/types/api/plugins/participation/responses.rs @@ -66,9 +66,9 @@ impl OutputStatusResponse { pub fn mock() -> Self { Self { participations: [( - ParticipationEventId::new([42; 32]), + ParticipationEventId::new([42; ParticipationEventId::LENGTH]), TrackedParticipation { - block_id: BlockId::new([23; 40]), + block_id: BlockId::new([23; BlockId::LENGTH]), amount: 100, start_milestone_index: 1000, end_milestone_index: 9999, diff --git a/sdk/src/types/block/block_id.rs b/sdk/src/types/block/block_id.rs index 9694a7e81a..3c730fc1bd 100644 --- a/sdk/src/types/block/block_id.rs +++ b/sdk/src/types/block/block_id.rs @@ -34,7 +34,7 @@ pub struct BlockId { impl BlockId { /// The length of a [`BlockId`] - pub const LENGTH: usize = 40; + pub const LENGTH: usize = 36; pub fn new(bytes: [u8; Self::LENGTH]) -> Self { unsafe { core::mem::transmute(bytes) } diff --git a/sdk/src/types/block/output/unlock_condition/timelock.rs b/sdk/src/types/block/output/unlock_condition/timelock.rs index 9a93d65ddc..2f812167b9 100644 --- a/sdk/src/types/block/output/unlock_condition/timelock.rs +++ b/sdk/src/types/block/output/unlock_condition/timelock.rs @@ -51,14 +51,14 @@ pub(crate) mod dto { struct TimelockUnlockConditionDto { #[serde(rename = "type")] kind: u8, - slot_index: u64, + slot_index: SlotIndex, } impl From<&TimelockUnlockCondition> for TimelockUnlockConditionDto { fn from(value: &TimelockUnlockCondition) -> Self { Self { kind: TimelockUnlockCondition::KIND, - slot_index: *value.slot_index(), + slot_index: value.slot_index(), } } } @@ -67,7 +67,7 @@ pub(crate) mod dto { type Error = Error; fn try_from(value: TimelockUnlockConditionDto) -> Result { - Self::new(SlotIndex::from(value.slot_index)).map_err(|_| Error::InvalidField("timelockUnlockCondition")) + Self::new(value.slot_index).map_err(|_| Error::InvalidField("timelockUnlockCondition")) } } diff --git a/sdk/src/types/block/protocol.rs b/sdk/src/types/block/protocol.rs index 7f07da3a8f..1fe447b362 100644 --- a/sdk/src/types/block/protocol.rs +++ b/sdk/src/types/block/protocol.rs @@ -55,28 +55,22 @@ pub struct ProtocolParameters { #[getset(skip)] pub(crate) mana_structure: ManaStructure, /// The unbonding period in epochs before an account can stop staking. - #[cfg_attr(feature = "serde", serde(with = "crate::utils::serde::string"))] - pub(crate) staking_unbonding_period: u64, + pub(crate) staking_unbonding_period: u32, /// The number of validation blocks that each validator should issue each slot. pub(crate) validation_blocks_per_slot: u16, /// The number of epochs worth of Mana that a node is punished with for each additional validation block it issues. - #[cfg_attr(feature = "serde", serde(with = "crate::utils::serde::string"))] - pub(crate) punishment_epochs: u64, + pub(crate) punishment_epochs: u32, /// Liveness Threshold is used by tip-selection to determine if a block is eligible by evaluating issuingTimes and /// commitments in its past-cone to Accepted Tangle Time and lastCommittedSlot respectively. - #[cfg_attr(feature = "serde", serde(with = "crate::utils::serde::string"))] - pub(crate) liveness_threshold: u64, + pub(crate) liveness_threshold: u32, /// Minimum age relative to the accepted tangle time slot index that a slot can be committed. - #[cfg_attr(feature = "serde", serde(with = "crate::utils::serde::string"))] - pub(crate) min_committable_age: u64, + pub(crate) min_committable_age: u32, /// Maximum age for a slot commitment to be included in a block relative to the slot index of the block issuing /// time. - #[cfg_attr(feature = "serde", serde(with = "crate::utils::serde::string"))] - pub(crate) max_committable_age: u64, + pub(crate) max_committable_age: u32, /// Epoch Nearing Threshold is used by the epoch orchestrator to detect the slot that should trigger a new /// committee selection for the next and upcoming epoch. - #[cfg_attr(feature = "serde", serde(with = "crate::utils::serde::string"))] - pub(crate) epoch_nearing_threshold: u64, + pub(crate) epoch_nearing_threshold: u32, /// Parameters used to calculate the Reference Mana Cost (RMC). pub(crate) congestion_control_parameters: CongestionControlParameters, /// Defines the parameters used to signal a protocol parameters upgrade. @@ -132,7 +126,7 @@ impl ProtocolParameters { token_supply: u64, genesis_unix_timestamp: u64, slot_duration_in_seconds: u8, - epoch_nearing_threshold: u64, + epoch_nearing_threshold: u32, ) -> Result { Ok(Self { version, @@ -163,8 +157,8 @@ impl ProtocolParameters { } /// Returns the slots per epoch of the [`ProtocolParameters`]. - pub fn slots_per_epoch(&self) -> u64 { - 2_u64.pow(self.slots_per_epoch_exponent() as u32) + pub fn slots_per_epoch(&self) -> u32 { + 2_u32.pow(self.slots_per_epoch_exponent() as u32) } /// Gets a [`SlotIndex`] from a unix timestamp. diff --git a/sdk/src/types/block/rand/output/feature.rs b/sdk/src/types/block/rand/output/feature.rs index ce7781cf8f..85ebdbb374 100644 --- a/sdk/src/types/block/rand/output/feature.rs +++ b/sdk/src/types/block/rand/output/feature.rs @@ -12,6 +12,7 @@ use crate::types::block::{ address::rand_address, bytes::rand_bytes, number::{rand_number, rand_number_range}, + slot::{rand_epoch_index, rand_slot_index}, }, }; @@ -64,7 +65,7 @@ pub fn rand_block_issuer_keys(len: usize) -> BTreeSet { /// Generates a random [`BlockIssuerFeature`]. pub fn rand_block_issuer_feature() -> BlockIssuerFeature { BlockIssuerFeature::new( - rand_number::(), + rand_slot_index(), rand_block_issuer_keys(rand_number_range( BlockIssuerKeys::COUNT_MIN as usize..=BlockIssuerKeys::COUNT_MAX as usize, )), @@ -74,7 +75,7 @@ pub fn rand_block_issuer_feature() -> BlockIssuerFeature { /// Generates a random [`StakingFeature`]. pub fn rand_staking_feature() -> StakingFeature { - StakingFeature::new(rand_number(), rand_number(), rand_number::(), rand_number::()) + StakingFeature::new(rand_number(), rand_number(), rand_epoch_index(), rand_epoch_index()) } fn rand_feature_from_flag(flag: &FeatureFlags) -> Feature { diff --git a/sdk/src/types/block/rand/slot.rs b/sdk/src/types/block/rand/slot.rs index 659b304d99..8e01489e1c 100644 --- a/sdk/src/types/block/rand/slot.rs +++ b/sdk/src/types/block/rand/slot.rs @@ -3,7 +3,7 @@ use crate::types::block::{ rand::{bytes::rand_bytes_array, number::rand_number}, - slot::{SlotCommitmentId, SlotIndex}, + slot::{EpochIndex, SlotCommitmentId, SlotIndex}, }; /// Generates a random slot commitment id. @@ -15,3 +15,8 @@ pub fn rand_slot_commitment_id() -> SlotCommitmentId { pub fn rand_slot_index() -> SlotIndex { SlotIndex::new(rand_number()) } + +/// Generates a random epoch index. +pub fn rand_epoch_index() -> EpochIndex { + EpochIndex::new(rand_number()) +} diff --git a/sdk/src/types/block/slot/epoch.rs b/sdk/src/types/block/slot/epoch.rs index 0e47f94f78..b679c6d88e 100644 --- a/sdk/src/types/block/slot/epoch.rs +++ b/sdk/src/types/block/slot/epoch.rs @@ -35,11 +35,11 @@ use crate::types::block::Error; Copy, Clone, Debug, Default, Eq, PartialEq, Ord, PartialOrd, Hash, From, Deref, Display, FromStr, packable::Packable, )] #[repr(transparent)] -pub struct EpochIndex(u64); +pub struct EpochIndex(u32); impl EpochIndex { /// Creates a new [`EpochIndex`]. - pub fn new(index: u64) -> Self { + pub fn new(index: u32) -> Self { Self::from(index) } @@ -81,14 +81,14 @@ impl EpochIndex { } } -impl From for u64 { +impl From for u32 { fn from(epoch_index: EpochIndex) -> Self { *epoch_index } } -impl PartialEq for EpochIndex { - fn eq(&self, other: &u64) -> bool { +impl PartialEq for EpochIndex { + fn eq(&self, other: &u32) -> bool { self.0 == *other } } diff --git a/sdk/src/types/block/slot/index.rs b/sdk/src/types/block/slot/index.rs index 93889fc129..963e77fbe1 100644 --- a/sdk/src/types/block/slot/index.rs +++ b/sdk/src/types/block/slot/index.rs @@ -42,11 +42,11 @@ use crate::types::block::Error; packable::Packable, )] #[repr(transparent)] -pub struct SlotIndex(u64); +pub struct SlotIndex(u32); impl SlotIndex { /// Creates a new [`SlotIndex`]. - pub fn new(index: u64) -> Self { + pub fn new(index: u32) -> Self { Self::from(index) } @@ -63,7 +63,7 @@ impl SlotIndex { pub fn from_timestamp(timestamp: u64, genesis_unix_timestamp: u64, slot_duration_in_seconds: u8) -> Self { timestamp .checked_sub(genesis_unix_timestamp) - .map(|elapsed| (elapsed / slot_duration_in_seconds as u64) + 1) + .map(|elapsed| ((elapsed / slot_duration_in_seconds as u64) + 1) as u32) .unwrap_or_default() .into() } @@ -73,46 +73,46 @@ impl SlotIndex { pub fn to_timestamp(self, genesis_unix_timestamp: u64, slot_duration_in_seconds: u8) -> u64 { self.0 .checked_sub(1) - .map(|adjusted_slot| (adjusted_slot * slot_duration_in_seconds as u64) + genesis_unix_timestamp) + .map(|adjusted_slot| (adjusted_slot as u64 * slot_duration_in_seconds as u64) + genesis_unix_timestamp) .unwrap_or_default() } } -impl PartialEq for SlotIndex { - fn eq(&self, other: &u64) -> bool { +impl PartialEq for SlotIndex { + fn eq(&self, other: &u32) -> bool { self.0 == *other } } -impl core::ops::Add for SlotIndex { +impl core::ops::Add for SlotIndex { type Output = Self; - fn add(self, other: u64) -> Self { + fn add(self, other: u32) -> Self { Self(self.0 + other) } } -impl core::ops::AddAssign for SlotIndex { - fn add_assign(&mut self, other: u64) { +impl core::ops::AddAssign for SlotIndex { + fn add_assign(&mut self, other: u32) { self.0 += other; } } -impl core::ops::Sub for SlotIndex { +impl core::ops::Sub for SlotIndex { type Output = Self; - fn sub(self, other: u64) -> Self { + fn sub(self, other: u32) -> Self { Self(self.0 - other) } } -impl core::ops::SubAssign for SlotIndex { - fn sub_assign(&mut self, other: u64) { +impl core::ops::SubAssign for SlotIndex { + fn sub_assign(&mut self, other: u32) { self.0 -= other; } } -impl From for u64 { +impl From for u32 { fn from(slot_index: SlotIndex) -> Self { *slot_index } diff --git a/sdk/src/wallet/account/constants.rs b/sdk/src/wallet/account/constants.rs index bfa9f2b586..bdd3b81fa1 100644 --- a/sdk/src/wallet/account/constants.rs +++ b/sdk/src/wallet/account/constants.rs @@ -17,4 +17,4 @@ pub(crate) const MIN_SYNC_INTERVAL: u128 = 5; // TODO Used to be one day in seconds, what now ? // Default expiration slots for [ExpirationUnlockCondition] when sending native tokens, -pub(crate) const DEFAULT_EXPIRATION_SLOTS: u64 = 100; +pub(crate) const DEFAULT_EXPIRATION_SLOTS: u32 = 100; diff --git a/sdk/tests/client/input_signing_data.rs b/sdk/tests/client/input_signing_data.rs index 479a41370a..47fba00656 100644 --- a/sdk/tests/client/input_signing_data.rs +++ b/sdk/tests/client/input_signing_data.rs @@ -38,8 +38,7 @@ fn input_signing_data_conversion() { let input_signing_data = InputSigningData { output, output_metadata: OutputMetadata::new( - BlockId::from_str("0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda0000000000000000") - .unwrap(), + BlockId::from_str("0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda00000000").unwrap(), OutputId::from_str("0xbce525324af12eda02bf7927e92cea3a8e8322d0f41966271443e6c3b245a4400000").unwrap(), false, Some( @@ -72,7 +71,7 @@ fn input_signing_data_conversion() { InputSigningData::try_from_dto_with_params(input_signing_data_dto.clone(), &protocol_parameters).unwrap(); assert_eq!(input_signing_data, restored_input_signing_data); - let input_signing_data_dto_str = r#"{"output":{"type":0,"amount":"1000000","mana":"0","unlockConditions":[{"type":0,"address":{"type":0,"pubKeyHash":"0x7ffec9e1233204d9c6dce6812b1539ee96af691ca2e4d9065daa85907d33e5d3"}}]},"outputMetadata":{"blockId":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda0000000000000000","transactionId":"0xbce525324af12eda02bf7927e92cea3a8e8322d0f41966271443e6c3b245a440","outputIndex":0,"isSpent":false,"commitmentIdSpent":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda4f9567d82bf96689","transactionIdSpent":"0x24a1f46bdb6b2bf38f1c59f73cdd4ae5b418804bb231d76d06fbf246498d5883","includedCommitmentId":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda4f9567d82bf96689","latestCommitmentId":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda4f9567d82bf96689"},"chain":{"coinType":4219,"account":0,"change":0,"addressIndex":0}}"#; + let input_signing_data_dto_str = r#"{"output":{"type":0,"amount":"1000000","mana":"0","unlockConditions":[{"type":0,"address":{"type":0,"pubKeyHash":"0x7ffec9e1233204d9c6dce6812b1539ee96af691ca2e4d9065daa85907d33e5d3"}}]},"outputMetadata":{"blockId":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda00000000","transactionId":"0xbce525324af12eda02bf7927e92cea3a8e8322d0f41966271443e6c3b245a440","outputIndex":0,"isSpent":false,"commitmentIdSpent":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda4f9567d82bf96689","transactionIdSpent":"0x24a1f46bdb6b2bf38f1c59f73cdd4ae5b418804bb231d76d06fbf246498d5883","includedCommitmentId":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda4f9567d82bf96689","latestCommitmentId":"0xedf5f572c58ddf4b4f9567d82bf96689cc68b730df796d822b4b9fb643f5efda4f9567d82bf96689"},"chain":{"coinType":4219,"account":0,"change":0,"addressIndex":0}}"#; assert_eq!( serde_json::to_string(&input_signing_data_dto).unwrap(), input_signing_data_dto_str diff --git a/sdk/tests/client/mod.rs b/sdk/tests/client/mod.rs index aebed6d716..e1ea886413 100644 --- a/sdk/tests/client/mod.rs +++ b/sdk/tests/client/mod.rs @@ -68,8 +68,8 @@ enum Build<'a> { Option>, Option<&'a str>, Option<(&'a str, u64)>, - Option, - Option<(&'a str, u64)>, + Option, + Option<(&'a str, u32)>, Option, ), Nft( @@ -80,7 +80,7 @@ enum Build<'a> { Option<&'a str>, Option<&'a str>, Option<(&'a str, u64)>, - Option<(&'a str, u64)>, + Option<(&'a str, u32)>, Option, ), Account( @@ -103,8 +103,8 @@ fn build_basic_output( native_tokens: Option>, bech32_sender: Option, sdruc: Option<(Bech32Address, u64)>, - timelock: Option, - expiration: Option<(Bech32Address, u64)>, + timelock: Option, + expiration: Option<(Bech32Address, u32)>, ) -> Output { let mut builder = BasicOutputBuilder::new_with_amount(amount).add_unlock_condition(AddressUnlockCondition::new(bech32_address)); @@ -146,7 +146,7 @@ fn build_nft_output( bech32_sender: Option, bech32_issuer: Option, sdruc: Option<(Bech32Address, u64)>, - expiration: Option<(Bech32Address, u64)>, + expiration: Option<(Bech32Address, u32)>, ) -> Output { let mut builder = NftOutputBuilder::new_with_amount(amount, nft_id) .add_unlock_condition(AddressUnlockCondition::new(bech32_address)); diff --git a/sdk/tests/types/block.rs b/sdk/tests/types/block.rs index 0a19f5ff98..7e408dbce9 100644 --- a/sdk/tests/types/block.rs +++ b/sdk/tests/types/block.rs @@ -137,7 +137,7 @@ fn dto_mismatch_version() { "issuerId": "0x0000000000000000000000000000000000000000000000000000000000000000", "block": { "type":1, - "strongParents": [ "0x417c5700320912627b604d4c376a5a1663634b09703538570b1d52440b3e474639490b100a6f3608" ], + "strongParents": [ "0x417c5700320912627b604d4c376a5a1663634b09703538570b1d52440b3e474639490b10" ], "weakParents": [], "shallowLikeParents": [], "highestSupportedVersion": 3, @@ -178,7 +178,7 @@ fn dto_mismatch_network_id() { "issuerId": "0x0000000000000000000000000000000000000000000000000000000000000000", "block": { "type":1, - "strongParents": [ "0x417c5700320912627b604d4c376a5a1663634b09703538570b1d52440b3e474639490b100a6f3608" ], + "strongParents": [ "0x417c5700320912627b604d4c376a5a1663634b09703538570b1d52440b3e474639490b10" ], "weakParents": [], "shallowLikeParents": [], "highestSupportedVersion": 3, diff --git a/sdk/tests/types/block_id.rs b/sdk/tests/types/block_id.rs index eeb5fb8fa5..2dac54118a 100644 --- a/sdk/tests/types/block_id.rs +++ b/sdk/tests/types/block_id.rs @@ -12,7 +12,7 @@ use iota_sdk::types::{ }; use packable::PackableExt; -const BLOCK_ID: &str = "0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6490000000000000000"; +const BLOCK_ID: &str = "0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c64900000000"; #[test] fn debug_impl() { @@ -39,8 +39,8 @@ fn from_to_str() { fn packed_len() { let block_id = BlockId::from_str(BLOCK_ID).unwrap(); - assert_eq!(block_id.packed_len(), 40); - assert_eq!(block_id.pack_to_vec().len(), 40); + assert_eq!(block_id.packed_len(), 36); + assert_eq!(block_id.pack_to_vec().len(), 36); } // Validate that a `unpack` ∘ `pack` round-trip results in the original block id. @@ -272,69 +272,70 @@ fn protocol_parameters() -> ProtocolParameters { // ); // } -#[test] -fn validation_block_id() { - // Test from https://github.com/iotaledger/tips-draft/blob/tip46/tips/TIP-0046/tip-0046.md#validation-block-id +// #[test] +// fn validation_block_id() { +// // Test from https://github.com/iotaledger/tips-draft/blob/tip46/tips/TIP-0046/tip-0046.md#validation-block-id - let block_json = serde_json::json!({ - "protocolVersion": 3, - "networkId": "10549460113735494767", - "issuingTime": "1695275834000000000", - "slotCommitmentId": "0x498bf08a5ed287bc87340341ffab28706768cd3a7035ae5e33932d9a12bb30940000000000000000", - "latestFinalizedSlot": "0", - "issuerId": "0x3370746f30705b7d0b42597459714d45241e5a64761b09627c447b751c7e145c", - "block": { - "type": 1, - "strongParents": [ - "0x304442486c7a05361408585e4b5f7a67441c437528755a70041e0e557a6d4b2d7d4362083d492b57", - "0x5f736978340a243d381b343b160b316a6b7d4b1e3c0355492e2e72113c2b126600157e69113c0b5c" - ], - "weakParents": [ - "0x0b5a48384f382f4a49471c4860683c6f0a0d446f012e1b117c4e405f5e24497c72691f43535c0b42" - ], - "shallowLikeParents": [ - "0x163007217803006078040b0f51507d3572355a457839095e572f125500401b7d220c772b56165a12" - ], - "highestSupportedVersion": 3, - "protocolParametersHash": "0xf6021fae654975db2e82c17444dc8d43573cb4222f506fb46ba46a097cf8c873" - }, - "signature": { - "type": 0, - "publicKey": "0x024b6f086177156350111d5e56227242034e596b7e3d0901180873740723193c", - "signature": "0x7c274e5e771d5d60202d334f06773d3672484b1e4e6f03231b4e69305329267a4834374b0f2e0d5c6c2f7779620f4f534c773b1679400c52303d1f23121a4049" - } - }); +// let block_json = serde_json::json!({ +// "protocolVersion": 3, +// "networkId": "10549460113735494767", +// "issuingTime": "1695275834000000000", +// "slotCommitmentId": "0x498bf08a5ed287bc87340341ffab28706768cd3a7035ae5e33932d9a12bb30940000000000000000", +// "latestFinalizedSlot": "0", +// "issuerId": "0x3370746f30705b7d0b42597459714d45241e5a64761b09627c447b751c7e145c", +// "block": { +// "type": 1, +// "strongParents": [ +// "0x304442486c7a05361408585e4b5f7a67441c437528755a70041e0e557a6d4b2d7d4362083d492b57", +// "0x5f736978340a243d381b343b160b316a6b7d4b1e3c0355492e2e72113c2b126600157e69113c0b5c" +// ], +// "weakParents": [ +// "0x0b5a48384f382f4a49471c4860683c6f0a0d446f012e1b117c4e405f5e24497c72691f43535c0b42" +// ], +// "shallowLikeParents": [ +// "0x163007217803006078040b0f51507d3572355a457839095e572f125500401b7d220c772b56165a12" +// ], +// "highestSupportedVersion": 3, +// "protocolParametersHash": "0xf6021fae654975db2e82c17444dc8d43573cb4222f506fb46ba46a097cf8c873" +// }, +// "signature": { +// "type": 0, +// "publicKey": "0x024b6f086177156350111d5e56227242034e596b7e3d0901180873740723193c", +// "signature": +// "0x7c274e5e771d5d60202d334f06773d3672484b1e4e6f03231b4e69305329267a4834374b0f2e0d5c6c2f7779620f4f534c773b1679400c52303d1f23121a4049" +// } +// }); - let block_dto = serde_json::from_value::(block_json).unwrap(); - let block = BlockWrapper::try_from_dto(block_dto).unwrap(); - let block_bytes = block.pack_to_vec(); +// let block_dto = serde_json::from_value::(block_json).unwrap(); +// let block = BlockWrapper::try_from_dto(block_dto).unwrap(); +// let block_bytes = block.pack_to_vec(); - assert_eq!( - block_bytes, - [ - 3, 111, 44, 91, 123, 20, 54, 103, 146, 0, 196, 223, 153, 99, 212, 134, 23, 73, 139, 240, 138, 94, 210, 135, - 188, 135, 52, 3, 65, 255, 171, 40, 112, 103, 104, 205, 58, 112, 53, 174, 94, 51, 147, 45, 154, 18, 187, 48, - 148, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 51, 112, 116, 111, 48, 112, 91, 125, 11, 66, 89, 116, - 89, 113, 77, 69, 36, 30, 90, 100, 118, 27, 9, 98, 124, 68, 123, 117, 28, 126, 20, 92, 1, 2, 48, 68, 66, 72, - 108, 122, 5, 54, 20, 8, 88, 94, 75, 95, 122, 103, 68, 28, 67, 117, 40, 117, 90, 112, 4, 30, 14, 85, 122, - 109, 75, 45, 125, 67, 98, 8, 61, 73, 43, 87, 95, 115, 105, 120, 52, 10, 36, 61, 56, 27, 52, 59, 22, 11, 49, - 106, 107, 125, 75, 30, 60, 3, 85, 73, 46, 46, 114, 17, 60, 43, 18, 102, 0, 21, 126, 105, 17, 60, 11, 92, 1, - 11, 90, 72, 56, 79, 56, 47, 74, 73, 71, 28, 72, 96, 104, 60, 111, 10, 13, 68, 111, 1, 46, 27, 17, 124, 78, - 64, 95, 94, 36, 73, 124, 114, 105, 31, 67, 83, 92, 11, 66, 1, 22, 48, 7, 33, 120, 3, 0, 96, 120, 4, 11, 15, - 81, 80, 125, 53, 114, 53, 90, 69, 120, 57, 9, 94, 87, 47, 18, 85, 0, 64, 27, 125, 34, 12, 119, 43, 86, 22, - 90, 18, 3, 246, 2, 31, 174, 101, 73, 117, 219, 46, 130, 193, 116, 68, 220, 141, 67, 87, 60, 180, 34, 47, - 80, 111, 180, 107, 164, 106, 9, 124, 248, 200, 115, 0, 2, 75, 111, 8, 97, 119, 21, 99, 80, 17, 29, 94, 86, - 34, 114, 66, 3, 78, 89, 107, 126, 61, 9, 1, 24, 8, 115, 116, 7, 35, 25, 60, 124, 39, 78, 94, 119, 29, 93, - 96, 32, 45, 51, 79, 6, 119, 61, 54, 114, 72, 75, 30, 78, 111, 3, 35, 27, 78, 105, 48, 83, 41, 38, 122, 72, - 52, 55, 75, 15, 46, 13, 92, 108, 47, 119, 121, 98, 15, 79, 83, 76, 119, 59, 22, 121, 64, 12, 82, 48, 61, - 31, 35, 18, 26, 64, 73 - ] - ); +// assert_eq!( +// block_bytes, +// [ +// 3, 111, 44, 91, 123, 20, 54, 103, 146, 0, 196, 223, 153, 99, 212, 134, 23, 73, 139, 240, 138, 94, 210, +// 135, 188, 135, 52, 3, 65, 255, 171, 40, 112, 103, 104, 205, 58, 112, 53, 174, 94, 51, 147, 45, 154, 18, +// 187, 48, 148, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 51, 112, 116, 111, 48, 112, 91, 125, 11, +// 66, 89, 116, 89, 113, 77, 69, 36, 30, 90, 100, 118, 27, 9, 98, 124, 68, 123, 117, 28, 126, 20, 92, 1, 2, +// 48, 68, 66, 72, 108, 122, 5, 54, 20, 8, 88, 94, 75, 95, 122, 103, 68, 28, 67, 117, 40, 117, 90, 112, 4, +// 30, 14, 85, 122, 109, 75, 45, 125, 67, 98, 8, 61, 73, 43, 87, 95, 115, 105, 120, 52, 10, 36, 61, 56, 27, +// 52, 59, 22, 11, 49, 106, 107, 125, 75, 30, 60, 3, 85, 73, 46, 46, 114, 17, 60, 43, 18, 102, 0, 21, 126, +// 105, 17, 60, 11, 92, 1, 11, 90, 72, 56, 79, 56, 47, 74, 73, 71, 28, 72, 96, 104, 60, 111, 10, 13, 68, +// 111, 1, 46, 27, 17, 124, 78, 64, 95, 94, 36, 73, 124, 114, 105, 31, 67, 83, 92, 11, 66, 1, 22, 48, 7, 33, +// 120, 3, 0, 96, 120, 4, 11, 15, 81, 80, 125, 53, 114, 53, 90, 69, 120, 57, 9, 94, 87, 47, 18, 85, 0, 64, +// 27, 125, 34, 12, 119, 43, 86, 22, 90, 18, 3, 246, 2, 31, 174, 101, 73, 117, 219, 46, 130, 193, 116, 68, +// 220, 141, 67, 87, 60, 180, 34, 47, 80, 111, 180, 107, 164, 106, 9, 124, 248, 200, 115, 0, 2, 75, 111, 8, +// 97, 119, 21, 99, 80, 17, 29, 94, 86, 34, 114, 66, 3, 78, 89, 107, 126, 61, 9, 1, 24, 8, 115, 116, 7, 35, +// 25, 60, 124, 39, 78, 94, 119, 29, 93, 96, 32, 45, 51, 79, 6, 119, 61, 54, 114, 72, 75, 30, 78, 111, 3, +// 35, 27, 78, 105, 48, 83, 41, 38, 122, 72, 52, 55, 75, 15, 46, 13, 92, 108, 47, 119, 121, 98, 15, 79, 83, +// 76, 119, 59, 22, 121, 64, 12, 82, 48, 61, 31, 35, 18, 26, 64, 73 +// ] +// ); - let block_id = block.id(&protocol_parameters()).to_string(); +// let block_id = block.id(&protocol_parameters()).to_string(); - assert_eq!( - block_id, - "0xe7577f23f82595fcf5501d3858666e5efe2e3063d715b03e43cdd93ea69d6af60200000000000000" - ); -} +// assert_eq!( +// block_id, +// "0xe7577f23f82595fcf5501d3858666e5efe2e3063d715b03e43cdd93ea69d6af60200000000000000" +// ); +// } diff --git a/sdk/tests/types/parents.rs b/sdk/tests/types/parents.rs index f85f16ec61..ab8bc27d3b 100644 --- a/sdk/tests/types/parents.rs +++ b/sdk/tests/types/parents.rs @@ -91,8 +91,8 @@ fn new_not_unique() { fn packed_len() { let parents = basic::StrongParents::from_vec(rand_block_ids(5)).unwrap(); - assert_eq!(parents.packed_len(), 1 + 5 * 40); - assert_eq!(parents.pack_to_vec().len(), 1 + 5 * 40); + assert_eq!(parents.packed_len(), 1 + 5 * 36); + assert_eq!(parents.pack_to_vec().len(), 1 + 5 * 36); } #[test] diff --git a/sdk/tests/types/slot.rs b/sdk/tests/types/slot.rs index b477e298d0..8b2795816a 100644 --- a/sdk/tests/types/slot.rs +++ b/sdk/tests/types/slot.rs @@ -4,36 +4,36 @@ use iota_sdk::types::block::slot::SlotCommitment; use packable::PackableExt; -#[test] -fn slot_commitment_id() { - // Test from https://github.com/iotaledger/tips-draft/blob/tip46/tips/TIP-0046/tip-0046.md#slot-commitment-id-1 +// #[test] +// fn slot_commitment_id() { +// // Test from https://github.com/iotaledger/tips-draft/blob/tip46/tips/TIP-0046/tip-0046.md#slot-commitment-id-1 - let slot_commitment_json = serde_json::json!({ - "protocolVersion": 3, - "index": "10", - "previousCommitmentId": "0x4b024b3e47280d05272a7d136f0c464e4e136b734e6c427749413e286162077560652c007e37241a", - "rootsId": "0x75614402763f5f045c040334631b791b4d755d626d504b134a505c001c516549", - "cumulativeWeight": "100", - "referenceManaCost": "6000" - }); +// let slot_commitment_json = serde_json::json!({ +// "protocolVersion": 3, +// "index": "10", +// "previousCommitmentId": "0x4b024b3e47280d05272a7d136f0c464e4e136b734e6c427749413e286162077560652c007e37241a", +// "rootsId": "0x75614402763f5f045c040334631b791b4d755d626d504b134a505c001c516549", +// "cumulativeWeight": "100", +// "referenceManaCost": "6000" +// }); - let slot_commitment = serde_json::from_value::(slot_commitment_json).unwrap(); - let slot_commitment_bytes = slot_commitment.pack_to_vec(); +// let slot_commitment = serde_json::from_value::(slot_commitment_json).unwrap(); +// let slot_commitment_bytes = slot_commitment.pack_to_vec(); - assert_eq!( - slot_commitment_bytes, - [ - 3, 10, 0, 0, 0, 0, 0, 0, 0, 75, 2, 75, 62, 71, 40, 13, 5, 39, 42, 125, 19, 111, 12, 70, 78, 78, 19, 107, - 115, 78, 108, 66, 119, 73, 65, 62, 40, 97, 98, 7, 117, 96, 101, 44, 0, 126, 55, 36, 26, 117, 97, 68, 2, - 118, 63, 95, 4, 92, 4, 3, 52, 99, 27, 121, 27, 77, 117, 93, 98, 109, 80, 75, 19, 74, 80, 92, 0, 28, 81, - 101, 73, 100, 0, 0, 0, 0, 0, 0, 0, 112, 23, 0, 0, 0, 0, 0, 0 - ] - ); +// assert_eq!( +// slot_commitment_bytes, +// [ +// 3, 10, 0, 0, 0, 0, 0, 0, 0, 75, 2, 75, 62, 71, 40, 13, 5, 39, 42, 125, 19, 111, 12, 70, 78, 78, 19, 107, +// 115, 78, 108, 66, 119, 73, 65, 62, 40, 97, 98, 7, 117, 96, 101, 44, 0, 126, 55, 36, 26, 117, 97, 68, 2, +// 118, 63, 95, 4, 92, 4, 3, 52, 99, 27, 121, 27, 77, 117, 93, 98, 109, 80, 75, 19, 74, 80, 92, 0, 28, 81, +// 101, 73, 100, 0, 0, 0, 0, 0, 0, 0, 112, 23, 0, 0, 0, 0, 0, 0 +// ] +// ); - let slot_commitment_id = slot_commitment.id().to_string(); +// let slot_commitment_id = slot_commitment.id().to_string(); - assert_eq!( - slot_commitment_id, - "0x3a73079f3dbf8c1744ae0b020b9767546e32f5bbbf4c6f0233da7b64f16581f80a00000000000000" - ); -} +// assert_eq!( +// slot_commitment_id, +// "0x3a73079f3dbf8c1744ae0b020b9767546e32f5bbbf4c6f0233da7b64f16581f80a00000000000000" +// ); +// } diff --git a/sdk/tests/utils/serde.rs b/sdk/tests/utils/serde.rs index a5719bed38..f1b441c15c 100644 --- a/sdk/tests/utils/serde.rs +++ b/sdk/tests/utils/serde.rs @@ -6,7 +6,7 @@ use core::str::FromStr; use iota_sdk::types::block::BlockId; use serde::{Deserialize, Serialize}; -const BLOCK_ID: &str = "0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c6490000000000000000"; +const BLOCK_ID: &str = "0x52fdfc072182654f163f5f0f9a621d729566c74d10037c4d7bbb0407d1e2c64900000000"; #[derive(Serialize, Deserialize, Debug, Eq, PartialEq)] #[serde(rename_all = "camelCase")] diff --git a/sdk/tests/wallet/balance.rs b/sdk/tests/wallet/balance.rs index 8c68db9c4b..f3e9d3c3c4 100644 --- a/sdk/tests/wallet/balance.rs +++ b/sdk/tests/wallet/balance.rs @@ -140,7 +140,7 @@ async fn balance_expiration() -> Result<()> { // Wait until expired // TODO wait for slots, not seconds - tokio::time::sleep(std::time::Duration::from_secs(slots_until_expired)).await; + tokio::time::sleep(std::time::Duration::from_secs(slots_until_expired as u64)).await; // Account 1 balance after expiration let balance = account_1.sync(None).await?;