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
impl TestCheckpointDataBuilder
pub fn new(checkpoint: u64) -> Self
Sourcepub fn with_epoch(self, epoch: u64) -> Self
pub fn with_epoch(self, epoch: u64) -> Self
Set the epoch for the checkpoint.
Sourcepub fn start_transaction(self, sender_idx: u8) -> Self
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.
Sourcepub fn create_owned_object(self, object_idx: u64) -> Self
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.
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.
Sourcepub fn create_sui_object(self, object_idx: u64, balance: u64) -> Self
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.
Sourcepub fn create_coin_object(
self,
object_idx: u64,
owner_idx: u8,
balance: u64,
coin_type: TypeTag,
) -> Self
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.
Sourcepub fn mutate_object(self, object_idx: u64) -> Self
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.
Sourcepub fn transfer_object(self, object_idx: u64, recipient_idx: u8) -> Self
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.
Sourcepub fn change_object_owner(self, object_idx: u64, owner: Owner) -> Self
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.
Sourcepub fn transfer_coin_balance(
self,
object_idx: u64,
new_object_idx: u64,
recipient_idx: u8,
amount: u64,
) -> Self
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.
Sourcepub fn wrap_object(self, object_idx: u64) -> Self
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.
Sourcepub fn unwrap_object(self, object_idx: u64) -> Self
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.
Sourcepub fn delete_object(self, object_idx: u64) -> Self
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.
Sourcepub fn with_events(self, events: Vec<Event>) -> Self
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.
Sourcepub fn add_move_call(
self,
package: ObjectID,
module: &'static str,
function: &'static str,
) -> Self
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.
Sourcepub fn finish_transaction(self) -> Self
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.
Sourcepub fn build_checkpoint(&mut self) -> CheckpointData
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.
Sourcepub fn advance_epoch(&mut self, safe_mode: bool) -> CheckpointData
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
.
Sourcepub fn derive_object_id(object_idx: u64) -> ObjectID
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.
Sourcepub fn derive_address(address_idx: u8) -> SuiAddress
pub fn derive_address(address_idx: u8) -> SuiAddress
Derive an address from an index.
Sourcepub fn transactions_mut(&mut self) -> &mut Vec<CheckpointTransaction>
pub fn transactions_mut(&mut self) -> &mut Vec<CheckpointTransaction>
Get mutable access to all transactions in the current checkpoint
Sourcepub fn transaction_mut(
&mut self,
idx: usize,
) -> Option<&mut CheckpointTransaction>
pub fn transaction_mut( &mut self, idx: usize, ) -> Option<&mut CheckpointTransaction>
Get mutable access to a specific transaction by index
Auto Trait Implementations§
impl Freeze for TestCheckpointDataBuilder
impl RefUnwindSafe for TestCheckpointDataBuilder
impl Send for TestCheckpointDataBuilder
impl Sync for TestCheckpointDataBuilder
impl Unpin for TestCheckpointDataBuilder
impl UnwindSafe for TestCheckpointDataBuilder
Blanket Implementations§
§impl<U> As for U
impl<U> As for U
§fn as_<T>(self) -> Twhere
T: CastFrom<U>,
fn as_<T>(self) -> Twhere
T: CastFrom<U>,
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 Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a Request
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
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) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
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
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
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
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
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
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.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
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.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
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.