sui_types::test_checkpoint_data_builder

Struct TestCheckpointDataBuilder

Source
pub struct TestCheckpointDataBuilder { /* private fields */ }
Expand description

A builder for creating test checkpoint data. Once initialized, the builder can be used to build multiple checkpoints. Call start_transaction to begin creating a new transaction. Call finish_transaction to complete the current transaction and add it to the current checkpoint. After all transactions are added, call build_checkpoint to get the final checkpoint data. This will also increment the stored checkpoint sequence number. Start the above process again to build the next checkpoint. NOTE: The generated checkpoint data is not guaranteed to be semantically valid or consistent. For instance, all object digests will be randomly set. It focuses on providing a way to generate various shaped test data for testing purposes. If you need to test the validity of the checkpoint data, you should use Simulacrum instead.

Implementations§

Source§

impl TestCheckpointDataBuilder

Source

pub fn new(checkpoint: u64) -> Self

Source

pub fn with_epoch(self, epoch: u64) -> Self

Set the epoch for the checkpoint.

Source

pub fn start_transaction(self, sender_idx: u8) -> Self

Start creating a new transaction. sender_idx is a convenient representation of the sender’s address. A proper SuiAddress will be derived from it. It will also create a gas object for the sender if it doesn’t already exist in the live object map. You do not need to create the gas object yourself.

Source

pub fn create_owned_object(self, object_idx: u64) -> Self

Create a new object in the transaction. object_idx is a convenient representation of the object’s ID. The object will be created as a SUI coin object, with default balance, and the transaction sender as its owner.

Source

pub fn create_shared_object(self, object_idx: u64) -> Self

Create a new shared object in the transaction. object_idx is a convenient representation of the object’s ID. The object will be created as a SUI coin object, with default balance, and it is a shared object.

Source

pub fn create_sui_object(self, object_idx: u64, balance: u64) -> Self

Create a new SUI coin object in the transaction. object_idx is a convenient representation of the object’s ID. balance is the amount of SUI to be created.

Source

pub fn create_coin_object( self, object_idx: u64, owner_idx: u8, balance: u64, coin_type: TypeTag, ) -> Self

Create a new coin object in the transaction. object_idx is a convenient representation of the object’s ID. owner_idx is a convenient representation of the object’s owner’s address. balance is the amount of SUI to be created. coin_type is the type of the coin to be created.

Source

pub fn mutate_object(self, object_idx: u64) -> Self

Mutate an existing object in the transaction. object_idx is a convenient representation of the object’s ID.

Source

pub fn transfer_object(self, object_idx: u64, recipient_idx: u8) -> Self

Transfer an existing object to a new owner. object_idx is a convenient representation of the object’s ID. recipient_idx is a convenient representation of the recipient’s address.

Source

pub fn change_object_owner(self, object_idx: u64, owner: Owner) -> Self

Change the owner of an existing object. object_idx is a convenient representation of the object’s ID. owner is the new owner of the object.

Source

pub fn transfer_coin_balance( self, object_idx: u64, new_object_idx: u64, recipient_idx: u8, amount: u64, ) -> Self

Transfer part of an existing coin object’s balance to a new owner. object_idx is a convenient representation of the object’s ID. new_object_idx is a convenient representation of the new object’s ID. recipient_idx is a convenient representation of the recipient’s address. amount is the amount of balance to be transferred.

Source

pub fn wrap_object(self, object_idx: u64) -> Self

Wrap an existing object in the transaction. object_idx is a convenient representation of the object’s ID.

Source

pub fn unwrap_object(self, object_idx: u64) -> Self

Unwrap an existing object from the transaction. object_idx is a convenient representation of the object’s ID.

Source

pub fn delete_object(self, object_idx: u64) -> Self

Delete an existing object from the transaction. object_idx is a convenient representation of the object’s ID.

Source

pub fn with_events(self, events: Vec<Event>) -> Self

Add events to the transaction. events is a vector of events to be added to the transaction.

Source

pub fn add_move_call( self, package: ObjectID, module: &'static str, function: &'static str, ) -> Self

Add a move call PTB command to the transaction. package is the ID of the package to be called. module is the name of the module to be called. function is the name of the function to be called.

Source

pub fn finish_transaction(self) -> Self

Complete the current transaction and add it to the checkpoint. This will also finalize all the object changes, and reflect them in the live object map.

Source

pub fn build_checkpoint(&mut self) -> CheckpointData

Build the checkpoint data using all the transactions added to the builder so far. This will also increment the stored checkpoint sequence number.

Source

pub fn advance_epoch(&mut self, safe_mode: bool) -> CheckpointData

Creates a transaction that advances the epoch, adds it to the checkpoint, and then builds the checkpoint. This increments the stored checkpoint sequence number and epoch. If safe_mode is true, the epoch end transaction will not include the SystemEpochInfoEvent.

Source

pub fn derive_object_id(object_idx: u64) -> ObjectID

Derive an object ID from an index. This is used to conveniently represent an object’s ID. We ensure that the bytes of object IDs have a stable order that is the same as object_idx.

Source

pub fn derive_address(address_idx: u8) -> SuiAddress

Derive an address from an index.

Source

pub fn transactions_mut(&mut self) -> &mut Vec<CheckpointTransaction>

Get mutable access to all transactions in the current checkpoint

Source

pub fn transaction_mut( &mut self, idx: usize, ) -> Option<&mut CheckpointTransaction>

Get mutable access to a specific transaction by index

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<U> As for U

§

fn as_<T>(self) -> T
where T: CastFrom<U>,

Casts self to type T. The semantics of numeric casting with the as operator are followed, so <T as As>::as_::<U> can be used in the same way as T as U for numeric conversions. Read more
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a Request
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSendSync for T