<!--
Sitemap:
- [Why Viem](/docs/introduction): A brief preamble on why we built Viem
- [Installation](/docs/installation)
- [Getting Started](/docs/getting-started): Get started with viem in just a few lines of code.
- [Platform Compatibility](/docs/compatibility): Platforms compatible with Viem
- [Frequently Asked Questions](/docs/faq)
- [Migration Guide](/docs/migration-guide)
- [Ethers v5 → viem Migration Guide](/docs/ethers-migration): Migrate from Ethers v5 to viem
- [TypeScript](/docs/typescript): TypeScript support for Viem
- [Error Handling](/docs/error-handling)
- [EIP-7702 Overview](/docs/eip7702): An Overview of EIP-7702
- [Contract Writes with EIP-7702](/docs/eip7702/contract-writes)
- [Sending Transactions with EIP-7702](/docs/eip7702/sending-transactions)
- [Blob Transactions](/docs/guides/blob-transactions): Sending your first Blob Transaction with Viem.
- [Introduction to Clients & Transports](/docs/clients/intro): A brief introduction to Clients & Transports.
- [Public Client](/docs/clients/public): A function to create a Public Client
- [Wallet Client](/docs/clients/wallet): A function to create a Wallet Client.
- [Test Client](/docs/clients/test): A function to create a Test Client
- [Build your own Client](/docs/clients/custom)
- [HTTP Transport](/docs/clients/transports/http): A function to create a HTTP Transport for a Client
- [WebSocket Transport](/docs/clients/transports/websocket): A function to create a WebSocket Transport for a Client
- [Custom Transport](/docs/clients/transports/custom): A function to create a Custom Transport for a Client
- [IPC Transport](/docs/clients/transports/ipc): A function to create an IPC Transport for a Client
- [Fallback Transport](/docs/clients/transports/fallback): A function to create a Fallback Transport for a Client
- [Introduction to Public Actions](/docs/actions/public/introduction): A brief introduction on what Public Actions are in viem.
- [createAccessList](/docs/actions/public/createAccessList)
- [getBalance](/docs/actions/public/getBalance): Returns the balance of an address in wei.
- [getTransactionCount](/docs/actions/public/getTransactionCount): Returns the number of Transactions an Account has sent.
- [getBlock](/docs/actions/public/getBlock): Returns information about a block at a block number, hash or tag.
- [getBlockReceipts](/docs/actions/public/getBlockReceipts): Returns the transaction receipts of a block at a block number, hash or tag.
- [getBlockNumber](/docs/actions/public/getBlockNumber): Returns the number of the most recent block seen.
- [getBlockTransactionCount](/docs/actions/public/getBlockTransactionCount): Returns the number of Transactions at a block number, hash or tag.
- [simulateBlocks](/docs/actions/public/simulateBlocks): Simulates a set of calls on block(s).
- [watchBlockNumber](/docs/actions/public/watchBlockNumber): Watches and returns incoming block numbers.
- [watchBlocks](/docs/actions/public/watchBlocks): Watches and returns information for incoming blocks.
- [call](/docs/actions/public/call): An Action for executing a new message call.
- [simulateCalls](/docs/actions/public/simulateCalls): Simulates a set of calls on block(s).
- [getChainId](/docs/actions/public/getChainId): Returns the chain ID associated with the current network
- [getEip712Domain](/docs/actions/public/getEip712Domain): Reads the EIP-712 domain from a contract.
- [estimateFeesPerGas](/docs/actions/public/estimateFeesPerGas): Returns an estimate for the fees per gas (in wei) for a transaction to be likely included in the next block.
- [estimateGas](/docs/actions/public/estimateGas): An Action for estimating gas for a transaction.
- [estimateMaxPriorityFeePerGas](/docs/actions/public/estimateMaxPriorityFeePerGas): Returns an estimate for the max priority fee per gas (in wei) for a transaction to be likely included in the next block.
- [getBlobBaseFee](/docs/actions/public/getBlobBaseFee): Returns the current blob base fee (in wei).
- [getFeeHistory](/docs/actions/public/getFeeHistory): Returns a collection of historical gas information.
- [getGasPrice](/docs/actions/public/getGasPrice): Returns the current price of gas (in wei).
- [createBlockFilter](/docs/actions/public/createBlockFilter): An Action for creating a new Block Filter.
- [createEventFilter](/docs/actions/public/createEventFilter): An Action for creating a new Event Filter.
- [createPendingTransactionFilter](/docs/actions/public/createPendingTransactionFilter): An Action for creating a new pending transaction filter.
- [getFilterChanges](/docs/actions/public/getFilterChanges): Returns a list of logs or hashes based on a Filter.
- [getFilterLogs](/docs/actions/public/getFilterLogs): Returns a list of event logs since the filter was created.
- [getLogs](/docs/actions/public/getLogs): Returns a list of event logs matching the provided parameters.
- [watchEvent](/docs/actions/public/watchEvent): Watches and returns emitted Event Logs.
- [uninstallFilter](/docs/actions/public/uninstallFilter): Destroys a Filter.
- [getProof](/docs/actions/public/getProof): Returns the account and storage values of the specified account including the Merkle-proof.
- [verifyMessage](/docs/actions/public/verifyMessage): Verifies if a signed message was generated by the provided address.
- [verifyTypedData](/docs/actions/public/verifyTypedData): Verifies a typed data signature
- [prepareTransactionRequest](/docs/actions/wallet/prepareTransactionRequest): Prepares a transaction request for signing.
- [getTransaction](/docs/actions/public/getTransaction): Returns information about a transaction given a hash or block identifier.
- [getTransactionConfirmations](/docs/actions/public/getTransactionConfirmations): Returns the number of blocks passed (confirmations) since the transaction was processed on a block.
- [getTransactionReceipt](/docs/actions/public/getTransactionReceipt): Returns the transaction receipt given a transaction hash.
- [sendRawTransaction](/docs/actions/wallet/sendRawTransaction): Sends a signed transaction to the network
- [waitForTransactionReceipt](/docs/actions/public/waitForTransactionReceipt): Retrieves a Transaction Receipt for a given Transaction hash.
- [watchPendingTransactions](/docs/actions/public/watchPendingTransactions): Watches and returns pending transaction hashes.
- [Introduction to Wallet Actions](/docs/actions/wallet/introduction): A brief introduction to Wallet Actions in viem.
- [getAddresses](/docs/actions/wallet/getAddresses): Returns a list of addresses owned by the wallet or client.
- [requestAddresses](/docs/actions/wallet/requestAddresses): Requests a list of accounts managed by a wallet.
- [watchAsset](/docs/actions/wallet/watchAsset): Requests that the user tracks the token in their wallet.
- [getCallsStatus](/docs/actions/wallet/getCallsStatus): Returns the status of a call batch.
- [getCapabilities](/docs/actions/wallet/getCapabilities): Extract capabilities that a connected wallet supports.
- [sendCalls](/docs/actions/wallet/sendCalls): Sign and broadcast a batch of calls to the network.
- [sendCallsSync](/docs/actions/wallet/sendCallsSync): Sign and broadcast a batch of calls to the network, and waits for the calls to be included in a block.
- [showCallsStatus](/docs/actions/wallet/showCallsStatus): Requests for the wallet to show information about a call batch.
- [waitForCallsStatus](/docs/actions/wallet/waitForCallsStatus): Waits for a call batch to be confirmed & included on a Block.
- [addChain](/docs/actions/wallet/addChain): Adds an EVM chain to the wallet.
- [switchChain](/docs/actions/wallet/switchChain): Switch the target chain in a wallet.
- [signMessage](/docs/actions/wallet/signMessage): Signs a message with the Account's private key.
- [signTypedData](/docs/actions/wallet/signTypedData): Signs typed data with the Account's private key.
- [getPermissions](/docs/actions/wallet/getPermissions): Gets the wallets current permissions.
- [requestPermissions](/docs/actions/wallet/requestPermissions): Requests permissions for a wallet.
- [sendRawTransactionSync](/docs/actions/wallet/sendRawTransactionSync): Sends a signed transaction to the network synchronously
- [sendTransaction](/docs/actions/wallet/sendTransaction): Creates, signs, and sends a new transaction to the network.
- [sendTransactionSync](/docs/actions/wallet/sendTransactionSync): Creates, signs, and sends a new transaction to the network synchronously.
- [signTransaction](/docs/actions/wallet/signTransaction): Signs a transaction.
- [Introduction to Test Actions](/docs/actions/test/introduction): A brief introduction on what Test Actions are in viem.
- [impersonateAccount](/docs/actions/test/impersonateAccount): Impersonate an account or contract address.
- [setBalance](/docs/actions/test/setBalance): Modifies the balance of an account.
- [setCode](/docs/actions/test/setCode): Modifies the bytecode stored at an account's address.
- [setNonce](/docs/actions/test/setNonce): Modifies (overrides) the nonce of an account.
- [setStorageAt](/docs/actions/test/setStorageAt): Writes to a slot of an account's storage.
- [stopImpersonatingAccount](/docs/actions/test/stopImpersonatingAccount): Stop impersonating an account after having previously used impersonateAccount.
- [getAutomine](/docs/actions/test/getAutomine): Returns the automatic mining status of the node.
- [increaseTime](/docs/actions/test/increaseTime): Jump forward in time by the given amount of time, in seconds.
- [mine](/docs/actions/test/mine): Mine a specified number of blocks.
- [removeBlockTimestampInterval](/docs/actions/test/removeBlockTimestampInterval): Removes setBlockTimestampInterval if it exists.
- [setAutomine](/docs/actions/test/setAutomine): Enables or disables the automatic mining of new blocks with each new transaction submitted to the network.
- [setIntervalMining](/docs/actions/test/setIntervalMining): Sets the automatic mining interval (in seconds) of blocks.
- [setBlockTimestampInterval](/docs/actions/test/setBlockTimestampInterval): Sets the block's timestamp interval.
- [setBlockGasLimit](/docs/actions/test/setBlockGasLimit): Sets the block's gas limit.
- [setNextBlockBaseFeePerGas](/docs/actions/test/setNextBlockBaseFeePerGas): Sets the next block's base fee per gas.
- [setNextBlockTimestamp](/docs/actions/test/setNextBlockTimestamp): Sets the next block's timestamp.
- [setCoinbase](/docs/actions/test/setCoinbase): Sets the coinbase address to be used in new blocks.
- [setMinGasPrice](/docs/actions/test/setMinGasPrice): Change the minimum gas price accepted by the network (in wei).
- [reset](/docs/actions/test/reset): Resets the fork back to its original state.
- [setLoggingEnabled](/docs/actions/test/setLoggingEnabled): Enable or disable logging on the test node network.
- [setRpcUrl](/docs/actions/test/setRpcUrl): Sets the backend RPC URL.
- [dumpState](/docs/actions/test/dumpState): Serializes the current state into a savable data blob.
- [loadState](/docs/actions/test/loadState): Adds state previously dumped to the current chain.
- [revert](/docs/actions/test/revert): Revert the state of the blockchain at the current block.
- [snapshot](/docs/actions/test/snapshot): Snapshot the state of the blockchain at the current block.
- [dropTransaction](/docs/actions/test/dropTransaction): Removes a transaction from the mempool.
- [getTxpoolContent](/docs/actions/test/getTxpoolContent): Returns the details of all transactions currently pending for inclusion in the next block(s).
- [getTxpoolStatus](/docs/actions/test/getTxpoolStatus): Returns a summary of all the transactions currently pending for inclusion in the next block(s).
- [inspectTxpool](/docs/actions/test/inspectTxpool): Returns a summary of all the transactions currently pending for inclusion in the next block(s).
- [sendUnsignedTransaction](/docs/actions/test/sendUnsignedTransaction): Executes a transaction regardless of the signature.
- [JSON-RPC Account](/docs/accounts/jsonRpc): A function to create a JSON-RPC Account.
- [Local Accounts (Private Key, Mnemonic, etc)](/docs/accounts/local)
- [privateKeyToAccount](/docs/accounts/local/privateKeyToAccount): A function to create a Private Key Account.
- [mnemonicToAccount](/docs/accounts/local/mnemonicToAccount): A function to create a Mnemonic Account.
- [hdKeyToAccount](/docs/accounts/local/hdKeyToAccount): A function to create a Hierarchical Deterministic (HD) Account.
- [toAccount](/docs/accounts/local/toAccount): A function to create a Custom Account.
- [createNonceManager](/docs/accounts/local/createNonceManager): Creates a Nonce Manager for automatic nonce generation
- [signMessage (Local Account)](/docs/accounts/local/signMessage): Signs a message with the Account's private key.
- [signTransaction (Local Account)](/docs/accounts/local/signTransaction): Signs a transaction with the Account's private key.
- [signTypedData (Local Account)](/docs/accounts/local/signTypedData): Signs typed data with the Account's private key.
- [Chains](/docs/chains/introduction)
- [Fees](/docs/chains/fees): Configure chain-based fee data in Viem
- [Formatters](/docs/chains/formatters): Configure chain-based formatters in Viem
- [Serializers](/docs/chains/serializers): Configure chain-based serializers in Viem
- [Celo](/docs/chains/celo): Integrating with Celo in Viem
- [Getting Started with OP Stack](/op-stack): Getting started with the OP Stack in Viem
- [Getting Started with ZKsync](/zksync): Getting started with the ZKsync in Viem
- [Contract Instances](/docs/contract/getContract): A Contract Instance is a type-safe interface for performing contract-related actions with a specific ABI and address, created by the getContract function.
- [createContractEventFilter](/docs/contract/createContractEventFilter): Creates a Filter to retrieve contract event logs.
- [deployContract](/docs/contract/deployContract): Deploys a contract to the network, given bytecode & constructor arguments.
- [estimateContractGas](/docs/contract/estimateContractGas): Estimates the gas required to successfully execute a contract write function call.
- [getCode](/docs/contract/getCode): Retrieves the bytecode at an address.
- [getContractEvents](/docs/contract/getContractEvents): Returns a list of event logs matching the provided parameters.
- [getStorageAt](/docs/contract/getStorageAt): Returns the value from a storage slot at a given address.
- [multicall](/docs/contract/multicall): Batches up multiple functions on a contract in a single call.
- [readContract](/docs/contract/readContract): Calls a read-only function on a contract, and returns the response.
- [simulateContract](/docs/contract/simulateContract): Simulates & validates a contract interaction.
- [writeContract](/docs/contract/writeContract): Executes a write function on a contract.
- [writeContractSync](/docs/contract/writeContractSync): Executes a write function on a contract synchronously.
- [watchContractEvent](/docs/contract/watchContractEvent): Watches and returns emitted contract event logs.
- [decodeDeployData](/docs/contract/decodeDeployData): Decodes ABI encoded deploy data (bytecode & arguments).
- [decodeErrorResult](/docs/contract/decodeErrorResult): Decodes reverted error from a contract function call.
- [decodeEventLog](/docs/contract/decodeEventLog): Decodes ABI encoded event topics & data.
- [decodeFunctionData](/docs/contract/decodeFunctionData): Decodes ABI encoded data (4 byte selector & arguments) into a function name and arguments.
- [decodeFunctionResult](/docs/contract/decodeFunctionResult): Decodes the result of a function call on a contract.
- [encodeDeployData](/docs/contract/encodeDeployData): Encodes deploy data (bytecode & constructor args) into an ABI encoded value.
- [encodeErrorResult](/docs/contract/encodeErrorResult): Encodes a reverted error from a function call.
- [encodeEventTopics](/docs/contract/encodeEventTopics): Encodes an event (with optional arguments) into filter topics.
- [encodeFunctionData](/docs/contract/encodeFunctionData): Encodes the function name and parameters into an ABI encoded value (4 byte selector & arguments).
- [encodeFunctionResult](/docs/contract/encodeFunctionResult): Encodes structured return data into ABI encoded data.
- [parseEventLogs](/docs/contract/parseEventLogs): Extracts & decodes logs from a set of opaque logs.
- [getEnsAddress](/docs/ens/actions/getEnsAddress): Gets address for ENS name.
- [getEnsAvatar](/docs/ens/actions/getEnsAvatar): Gets the avatar of an ENS name.
- [getEnsName](/docs/ens/actions/getEnsName): Gets primary name for specified address.
- [getEnsResolver](/docs/ens/actions/getEnsResolver): Gets resolver for ENS name.
- [getEnsText](/docs/ens/actions/getEnsText): Gets a text record for specified ENS name.
- [labelhash](/docs/ens/utilities/labelhash): Hashes ENS label.
- [namehash](/docs/ens/utilities/namehash): Hashes ENS name.
- [normalize](/docs/ens/utilities/normalize): Normalizes ENS name to UTS46.
- [verifySiweMessage](/docs/siwe/actions/verifySiweMessage): Verifies EIP-4361 formatted message was signed.
- [createSiweMessage](/docs/siwe/utilities/createSiweMessage): Creates EIP-4361 formatted message.
- [generateSiweNonce](/docs/siwe/utilities/generateSiweNonce): Generates random EIP-4361 nonce.
- [parseSiweMessage](/docs/siwe/utilities/parseSiweMessage): Parses EIP-4361 formatted message into message fields object.
- [validateSiweMessage](/docs/siwe/utilities/validateSiweMessage): Validates EIP-4361 message.
- [decodeAbiParameters](/docs/abi/decodeAbiParameters): Decodes ABI encoded data.
- [encodeAbiParameters](/docs/abi/encodeAbiParameters): Generates ABI encoded data.
- [encodePacked](/docs/abi/encodePacked): Generates ABI encoded data.
- [getAbiItem](/docs/abi/getAbiItem): Retrieves an item from the ABI array.
- [parseAbi](/docs/abi/parseAbi): Parses human-readable ABI into JSON.
- [parseAbiItem](/docs/abi/parseAbiItem): Parses human-readable ABI item (e.g. error, event, function) into ABI item.
- [parseAbiParameter](/docs/abi/parseAbiParameter): Parses human-readable ABI parameter into ABI parameter.
- [parseAbiParameters](/docs/abi/parseAbiParameters): Parses human-readable ABI parameters into ABI parameters.
- [getDelegation](/docs/eip7702/getDelegation): Returns the address an account has delegated to via EIP-7702.
- [prepareAuthorization](/docs/eip7702/prepareAuthorization): Prepares an EIP-7702 Authorization for signing.
- [signAuthorization](/docs/eip7702/signAuthorization): Signs an EIP-7702 Authorization object.
- [hashAuthorization](/docs/eip7702/hashAuthorization): Calculates an Authorization object hash in EIP-7702 format.
- [recoverAuthorizationAddress](/docs/eip7702/recoverAuthorizationAddress): Recovers the original signing address from a signed Authorization object.
- [verifyAuthorization](/docs/eip7702/verifyAuthorization): Verifies that an Authorization object was signed by the provided address.
- [getAddress](/docs/utilities/getAddress): Converts an address into an address that is checksum encoded.
- [getContractAddress](/docs/utilities/getContractAddress): Retrieves a contract address.
- [isAddress](/docs/utilities/isAddress): Checks if the address is valid.
- [isAddressEqual](/docs/utilities/isAddressEqual): Checks if the given addresses (checksummed) are equal.
- [blobsToProofs](/docs/utilities/blobsToProofs): Compute the proofs for a list of blobs and their commitments.
- [blobsToCommitments](/docs/utilities/blobsToCommitments): Compute commitments from a list of blobs.
- [commitmentsToVersionedHashes](/docs/utilities/commitmentsToVersionedHashes): Transform a list of commitments to their versioned hashes.
- [commitmentToVersionedHash](/docs/utilities/commitmentToVersionedHash): Transform a commitment to it's versioned hash.
- [fromBlobs](/docs/utilities/fromBlobs): Transforms blobs into the originating data.
- [sidecarsToVersionedHashes](/docs/utilities/sidecarsToVersionedHashes): Transforms a list of sidecars to their versioned hashes.
- [toBlobs](/docs/utilities/toBlobs): Transforms arbitrary data into blobs.
- [toBlobSidecars](/docs/utilities/toBlobSidecars): Transforms arbitrary data into blob sidecars.
- [extractChain](/docs/utilities/extractChain)
- [concat](/docs/utilities/concat): Concatenates a set of hex values or byte arrays.
- [isBytes](/docs/utilities/isBytes): Checks whether the value is a byte array or not.
- [isHex](/docs/utilities/isHex): Checks whether the value is a hex value or not.
- [pad](/docs/utilities/pad): Pads a hex value or byte array with leading or trailing zeros.
- [slice](/docs/utilities/slice): Returns a section of the hex or byte array given a start/end bytes offset.
- [size](/docs/utilities/size): Retrieves the size of the value (in bytes).
- [trim](/docs/utilities/trim): Trims the leading or trailing zero byte data from a hex value or byte array.
- [fromBytes](/docs/utilities/fromBytes): Decodes a byte array to a string, hex value, boolean or number.
- [fromHex](/docs/utilities/fromHex): Decodes a hex value to a string, number or byte array.
- [fromRlp](/docs/utilities/fromRlp): Decodes a RLP value into a decoded hex value or byte array.
- [toBytes](/docs/utilities/toBytes): Encodes a string, hex value, number or boolean to a byte array.
- [toHex](/docs/utilities/toHex): Encodes a string, number, boolean or byte array to a hex value.
- [toRlp](/docs/utilities/toRlp): Encodes a hex value or byte array into a RLP encoded value.
- [isHash](/docs/utilities/isHash): Checks if a string is a valid 32-byte hex hash.
- [keccak256](/docs/utilities/keccak256): Calculates the Keccak256 hash of a byte array.
- [ripemd160](/docs/utilities/ripemd160): Calculates the Ripemd160 hash of a byte array.
- [sha256](/docs/utilities/sha256): Calculates the Sha256 hash of a byte array.
- [toEventHash](/docs/utilities/toEventHash): Returns the hash (of the event signature) for a given event definition.
- [toEventSelector](/docs/utilities/toEventSelector): Returns the event selector for a given event definition.
- [toEventSignature](/docs/utilities/toEventSignature): Returns the signature for a given event or event definition.
- [toFunctionHash](/docs/utilities/toFunctionHash): Returns the hash (of the function signature) for a given function definition.
- [toFunctionSelector](/docs/utilities/toFunctionSelector): Returns the function selector (4 byte encoding) for a given function definition.
- [toFunctionSignature](/docs/utilities/toFunctionSignature): Returns the signature for a given function definition.
- [setupKzg](/docs/utilities/setupKzg): Sets up and returns a KZG interface.
- [compactSignatureToSignature](/docs/utilities/compactSignatureToSignature): Parses a compact signature into signature format.
- [hashMessage](/docs/utilities/hashMessage): Hashes a message in EIP-191 format.
- [hashTypedData](/docs/utilities/hashTypedData): Hashes EIP-712 typed data.
- [isErc6492Signature](/docs/utilities/isErc6492Signature): Checks whether the signature is in ERC-6492 format.
- [parseCompactSignature](/docs/utilities/parseCompactSignature): Parses a hex formatted compact signature into a structured compact signature.
- [parseErc6492Signature](/docs/utilities/parseErc6492Signature): Parses a hex-formatted ERC-6492 flavoured signature.
- [parseSignature](/docs/utilities/parseSignature): Parses a hex formatted signature into a structured signature.
- [recoverAddress](/docs/utilities/recoverAddress): Recovers the signing address from a hash & signature.
- [recoverMessageAddress](/docs/utilities/recoverMessageAddress): Recovers the signing address from a message & signature.
- [recoverPublicKey](/docs/utilities/recoverPublicKey): Recovers the signing public key from a hash & signature.
- [recoverTransactionAddress](/docs/utilities/recoverTransactionAddress): Recovers the signing address from a transaction & signature.
- [recoverTypedDataAddress](/docs/utilities/recoverTypedDataAddress): Recovers the signing address from EIP-712 typed data & signature.
- [serializeCompactSignature](/docs/utilities/serializeCompactSignature): Serializes a compact signature into hex format.
- [serializeErc6492Signature](/docs/utilities/serializeErc6492Signature): Serializes a ERC-6492 flavoured signature into hex format.
- [serializeSignature](/docs/utilities/serializeSignature): Serializes a structured signature into hex format.
- [signatureToCompactSignature](/docs/utilities/signatureToCompactSignature): Parses a signature into a compact signature.
- [verifyMessage](/docs/utilities/verifyMessage): Verifies if a signed message was generated by the provided address.
- [verifyTypedData](/docs/utilities/verifyTypedData): Verifies a typed data signature
- [parseTransaction](/docs/utilities/parseTransaction): Converts a serialized transaction to a structured transaction.
- [serializeTransaction](/docs/utilities/serializeTransaction): Serializes a transaction object.
- [formatEther](/docs/utilities/formatEther): Converts numerical wei to a string representation of ether.
- [formatGwei](/docs/utilities/formatGwei): Converts numerical wei to a string representation of gwei.
- [formatUnits](/docs/utilities/formatUnits): Divides a number by a given exponent of base 10, and formats it into a string representation of the number.
- [parseEther](/docs/utilities/parseEther): Converts a string representation of ether to numerical wei.
- [parseGwei](/docs/utilities/parseGwei): Converts a string representation of gwei to numerical wei.
- [parseUnits](/docs/utilities/parseUnits): Multiplies a string representation of a number by a given exponent of base 10.
- [Terms](/docs/glossary/terms): Glossary of Terms in viem.
- [Types](/docs/glossary/types): Glossary of Types in viem.
- [Errors](/docs/glossary/errors): Glossary of Errors in viem.
- [Getting Started with Account Abstraction](/account-abstraction): Getting Started with Account Abstraction in Viem
- [Sending User Operations](/account-abstraction/guides/sending-user-operations)
- [Bundler Client](/account-abstraction/clients/bundler): A function to create a Bundler Client.
- [Paymaster Client](/account-abstraction/clients/paymaster): A function to create a Paymaster Client.
- [Smart Accounts](/account-abstraction/accounts/smart)
- [Coinbase Smart Wallet](/account-abstraction/accounts/smart/toCoinbaseSmartAccount)
- [MetaMask Smart Account](/account-abstraction/accounts/smart/toMetaMaskSmartAccount)
- [Thirdweb Smart Account](/account-abstraction/accounts/smart/toThirdwebSmartAccount)
- [Nexus Smart Account](/account-abstraction/accounts/smart/toNexusSmartAccount)
- [Light Smart Account](/account-abstraction/accounts/smart/toLightSmartAccount)
- [Kernel (ZeroDev) Smart Account](/account-abstraction/accounts/smart/toEcdsaKernelSmartAccount)
- [Safe Smart Account](/account-abstraction/accounts/smart/toSafeSmartAccount)
- [Simple Smart Account](/account-abstraction/accounts/smart/toSimpleSmartAccount)
- [Solady Smart Account](/account-abstraction/accounts/smart/toSoladySmartAccount)
- [Trust Smart Account](/account-abstraction/accounts/smart/toTrustSmartAccount)
- [toSmartAccount](/account-abstraction/accounts/smart/toSmartAccount): Creates a Smart Account with a provided Account Implementation.
- [signMessage (Smart Account)](/account-abstraction/accounts/smart/signMessage)
- [signTypedData (Smart Account)](/account-abstraction/accounts/smart/signTypedData)
- [signUserOperation (Smart Account)](/account-abstraction/accounts/smart/signUserOperation)
- [WebAuthn Account](/account-abstraction/accounts/webauthn)
- [toWebAuthnAccount](/account-abstraction/accounts/webauthn/toWebAuthnAccount)
- [createWebAuthnCredential](/account-abstraction/accounts/webauthn/createWebAuthnCredential)
- [estimateUserOperationGas](/account-abstraction/actions/bundler/estimateUserOperationGas): Estimates the gas values for a User Operation to be executed successfully.
- [getChainId](/account-abstraction/actions/bundler/getChainId): Returns the chain ID associated with the bundler
- [getSupportedEntryPoints](/account-abstraction/actions/bundler/getSupportedEntryPoints): Returns the EntryPoints that the bundler supports.
- [getUserOperation](/account-abstraction/actions/bundler/getUserOperation): Retrieves information about a User Operation given a hash.
- [getUserOperationReceipt](/account-abstraction/actions/bundler/getUserOperationReceipt): Returns the User Operation receipt given a User Operation hash.
- [prepareUserOperation](/account-abstraction/actions/bundler/prepareUserOperation): Prepares a User Operation for execution and fills in missing properties.
- [sendUserOperation](/account-abstraction/actions/bundler/sendUserOperation): Broadcasts a User Operation to the Bundler.
- [waitForUserOperationReceipt](/account-abstraction/actions/bundler/waitForUserOperationReceipt): Waits for the User Operation to be included on a Block, and then returns the User Operation receipt.
- [getPaymasterData](/account-abstraction/actions/paymaster/getPaymasterData): Retrieves paymaster-related properties to be used for the User Operation.
- [getPaymasterStubData](/account-abstraction/actions/paymaster/getPaymasterStubData): Retrieves paymaster-related properties to be used for the User Operation.
- [Getting Started](/experimental): Getting started with experimental features in Viem
- [Extending Client with ERC-7715](/experimental/erc7715/client): Setting up your Viem Client
- [grantPermissions](/experimental/erc7715/grantPermissions): Request permissions from a wallet to perform actions on behalf of a user.
- [Extending Client with ERC-7739 Actions](/experimental/erc7739/client): Setting up your Viem Client
- [signMessage](/experimental/erc7739/signMessage): Signs a personal sign message via Solady's ERC-1271 format.
- [signTypedData](/experimental/erc7739/signTypedData): Signs typed data via Solady's ERC-1271 format.
- [hashMessage](/experimental/erc7739/hashMessage): Hashes an EIP-191 message via ERC-7739 format.
- [hashTypedData](/experimental/erc7739/hashTypedData): Hashes EIP-712 typed data via Solady's ERC-1271 format.
- [wrapTypedDataSignature](/experimental/erc7739/wrapTypedDataSignature)
- [Extending Client with ERC-7811 Actions](/experimental/erc7811/client): Setting up your Viem Client
- [getAssets](/experimental/erc7811/getAssets): Requests to get assets for an account from a Wallet.
- [Extending Client with ERC-7821 Actions](/experimental/erc7821/client): Setting up your Viem Client
- [execute](/experimental/erc7821/execute): Executes call(s) using the `execute` function on an ERC-7821-compatible contract.
- [executeBatches](/experimental/erc7821/executeBatches): Executes batches of call(s) on an ERC-7821-compatible contract.
- [supportsExecutionMode](/experimental/erc7821/supportsExecutionMode): Checks if the contract supports the ERC-7821 execution mode.
- [Extending Client with ERC-7846 Actions](/experimental/erc7846/client): Setting up your Viem Client
- [connect](/experimental/erc7846/connect): Requests to connect Account(s).
- [disconnect](/experimental/erc7846/disconnect): Requests to disconnect account(s).
- [Extending Client with ERC-7895 Actions](/experimental/erc7895/client): Setting up your Viem Client
- [addSubAccount](/experimental/erc7895/addSubAccount): Requests to add a Sub Account.
- [Client](/op-stack/client): Setting up your Viem Client with the OP Stack
- [Chains](/op-stack/chains)
- [Deposits](/op-stack/guides/deposits)
- [Withdrawals](/op-stack/guides/withdrawals)
- [buildDepositTransaction](/op-stack/actions/buildDepositTransaction): Builds & prepares parameters for a deposit transaction to be initiated on an L1 and executed on the L2.
- [buildProveWithdrawal](/op-stack/actions/buildProveWithdrawal): Builds the transaction that proves a withdrawal was initiated on an L2.
- [estimateContractL1Fee](/op-stack/actions/estimateContractL1Fee): Estimates the L1 fee to execute an L2 contract write.
- [estimateContractL1Gas](/op-stack/actions/estimateContractL1Gas): Estimates the L1 gas to execute an L2 contract write.
- [estimateContractTotalFee](/op-stack/actions/estimateContractTotalFee): Estimates the total (L1 + L2) fee to execute an L2 contract write.
- [estimateContractTotalGas](/op-stack/actions/estimateContractTotalGas): Estimates the total (L1 + L2) gas to execute an L2 contract write.
- [estimateInitiateWithdrawalGas](/op-stack/actions/estimateInitiateWithdrawalGas): Estimates gas required to initiate a withdrawal on an L2 to the L1.
- [estimateL1Fee](/op-stack/actions/estimateL1Fee): Estimates the L1 fee to execute an L2 transaction.
- [estimateL1Gas](/op-stack/actions/estimateL1Gas): Estimates the amount of L1 gas required to execute an L2 transaction
- [estimateOperatorFee](/op-stack/actions/estimateOperatorFee): Estimates the operator fee to execute an L2 transaction.
- [estimateTotalFee](/op-stack/actions/estimateTotalFee): Estimates the L1 + L2 + operator fee to execute an L2 transaction.
- [estimateTotalGas](/op-stack/actions/estimateTotalGas): Estimates the amount of L1 + L2 gas required to execute an L2 transaction
- [initiateWithdrawal](/op-stack/actions/initiateWithdrawal): Initiates a withdrawal on an L2 to the L1.
- [buildInitiateWithdrawal](/op-stack/actions/buildInitiateWithdrawal): Builds & prepares parameters for a withdrawal to be initiated on an L2.
- [estimateDepositTransactionGas](/op-stack/actions/estimateDepositTransactionGas): Estimates gas to initiate a deposit transaction on an L1, which executes a transaction on an L2.
- [estimateFinalizeWithdrawalGas](/op-stack/actions/estimateFinalizeWithdrawalGas): Estimates gas required to finalize a withdrawal that occurred on an L2.
- [estimateProveWithdrawalGas](/op-stack/actions/estimateProveWithdrawalGas): Estimates gas required to prove a withdrawal that occurred on an L2.
- [getGame](/op-stack/actions/getGame): Retrieves a valid dispute game on an L2 that occurred after a provided L2 block number.
- [getGames](/op-stack/actions/getGames): Retrieves dispute games for an L2.
- [getL2Output](/op-stack/actions/getL2Output): Retrieves the first L2 output proposal that occurred after a provided block number.
- [getTimeToFinalize](/op-stack/actions/getTimeToFinalize): Returns the time until the withdrawal transaction can be finalized.
- [getTimeToNextGame](/op-stack/actions/getTimeToNextGame): Returns the time until the next L2 dispute game is submitted.
- [getTimeToNextL2Output](/op-stack/actions/getTimeToNextL2Output): Builds & prepares parameters for a withdrawal to be initiated on an L2.
- [getTimeToProve](/op-stack/actions/getTimeToProve): Gets time until the L2 withdrawal transaction is ready to be proved.
- [getWithdrawalStatus](/op-stack/actions/getWithdrawalStatus): Returns the current status of a withdrawal.
- [waitForNextGame](/op-stack/actions/waitForNextGame): Waits for the next dispute game to be submitted.
- [waitForNextL2Output](/op-stack/actions/waitForNextL2Output): Waits for the next L2 output (after the provided block number) to be submitted.
- [waitToFinalize](/op-stack/actions/waitToFinalize): Waits until the withdrawal transaction can be finalized.
- [waitToProve](/op-stack/actions/waitToProve): Waits until the L2 withdrawal transaction is ready to be proved.
- [depositTransaction](/op-stack/actions/depositTransaction): Initiates a deposit transaction on an L1, which executes a transaction on an L2.
- [finalizeWithdrawal](/op-stack/actions/finalizeWithdrawal): Finalizes a withdrawal that occurred on an L2.
- [proveWithdrawal](/op-stack/actions/proveWithdrawal): Proves a withdrawal that occurred on an L2.
- [extractTransactionDepositedLogs](/op-stack/utilities/extractTransactionDepositedLogs): Extracts "TransactionDeposited" logs from an opaque array of logs.
- [extractWithdrawalMessageLogs](/op-stack/utilities/extractWithdrawalMessageLogs): Extracts "MessagePassed" logs from a withdrawal initialization from an opaque array of logs.
- [getL2TransactionHash](/op-stack/utilities/getL2TransactionHash): Computes the L2 transaction hash from an L1 "TransactionDeposited" log.
- [getL2TransactionHashes](/op-stack/utilities/getL2TransactionHashes): Computes the L2 transaction hashes from an array of L1 "TransactionDeposited" logs.
- [getWithdrawals](/op-stack/utilities/getWithdrawals): Gets the messages from a withdrawal initialization.
- [getSourceHash](/op-stack/utilities/getSourceHash): Computes source hash of a deposit transaction.
- [opaqueDataToDepositData](/op-stack/utilities/opaqueDataToDepositData): Converts opaque data into a structured deposit data format.
- [getWithdrawalHashStorageSlot](/op-stack/utilities/getWithdrawalHashStorageSlot): Computes the withdrawal hash storage slot to be used when proving a withdrawal.
- [parseTransaction (OP Stack)](/op-stack/utilities/parseTransaction): Converts a serialized transaction to a structured transaction, with support for OP Stack.
- [serializeTransaction (OP Stack)](/op-stack/utilities/serializeTransaction): Serializes a transaction object, with support for OP Stack.
- [USDC (Circle)](/circle-usdc)
- [Integrating USDC into Your Application](/circle-usdc/guides/integrating)
- [Cross-Chain USDC Transfers](/circle-usdc/guides/cross-chain)
- [Cross Chain USDC Transfers with Bridge Kit](/circle-usdc/guides/bridge-kit)
- [Cross Chain USDC Transfers (CCTP Integration)](/circle-usdc/guides/manual-cctp)
- [Gasless USDC Transfers with Circle Paymaster](/circle-usdc/guides/paymaster)
- [Circle Smart Account](/circle-usdc/guides/smart-account)
- [Getting Started](/tempo/)
- [Chains](/tempo/chains)
- [Guides](/tempo/guides/): Task-oriented guides for building common Tempo features with Viem.
- [Create an Account](/tempo/guides/accounts/create): Create a Tempo Account from a private key, passkey, or device-bound key, and use it with a Viem client.
- [Sign In with a Passkey](/tempo/guides/accounts/passkeys): Create and restore WebAuthn passkey accounts for non-custodial browser sign-in on Tempo.
- [Use the Tempo Accounts SDK](/tempo/guides/accounts/accounts-sdk): Connect a Tempo account with the Tempo Accounts SDK and drive it with Viem and Tempo Actions.
- [Tempo Transactions](/tempo/transactions): Send your first Tempo Transaction with Viem, and discover the payment-native features they unlock.
- [Batch Calls](/tempo/guides/batch-calls): Bundle multiple operations into a single atomic Tempo Transaction.
- [Concurrent Transactions](/tempo/guides/concurrent-transactions): Send multiple Tempo Transactions in parallel using concurrent nonces.
- [Scheduled Transactions](/tempo/guides/scheduled-transactions): Sign a Tempo Transaction now and define when it can execute onchain.
- [Pay Fees in a Stablecoin](/tempo/guides/pay-fees): Pay Tempo transaction fees in any USD-denominated TIP-20 stablecoin.
- [Sponsor User Fees](/tempo/guides/sponsor-fees): Sponsor transaction fees on behalf of your users for a gasless experience on Tempo.
- [Create a TIP-20 Token](/tempo/guides/create-token): Deploy a TIP-20 stablecoin on Tempo and read its onchain metadata.
- [Mint & Burn Tokens](/tempo/guides/manage-token-balances): Mint and burn TIP-20 token supply on Tempo.
- [Transfer Tokens](/tempo/guides/transfer-tokens): Transfer TIP-20 tokens, authorize spenders, and read balances on Tempo.
- [Manage Token Roles & Supply](/tempo/guides/manage-token-roles): Grant and revoke TIP-20 roles, cap supply, and pause transfers on Tempo.
- [Configure Transfer Policies](/tempo/guides/transfer-policies): Restrict which accounts can send or receive a TIP-20 token with a transfer policy.
- [Distribute Token Rewards](/tempo/guides/token-rewards): Distribute rewards to TIP-20 holders and let them claim their share on Tempo.
- [Access Keys](/tempo/guides/access-keys/): Delegate signing to a secondary key with access keys, with spending limits, scopes, admin keys, and signature verification.
- [Authorize Access Keys](/tempo/guides/access-keys/authorize): Authorize an access key to sign transactions on behalf of an account, and defer authorization to a transaction.
- [Set Permissions & Limits](/tempo/guides/access-keys/permissions): Restrict an access key with an expiry, per-token spending limits, recurring limits, and call scopes.
- [Manage Access Keys](/tempo/guides/access-keys/manage): Update spending limits, revoke access keys, and inspect their onchain metadata and remaining limits.
- [Admin Access Keys](/tempo/guides/access-keys/admin): Authorize unrestricted admin access keys that can manage an account's other keys, and check admin status.
- [Witnesses](/tempo/guides/access-keys/witnesses): Bind a witness to a key authorization and burn it to revoke signed-but-not-yet-submitted authorizations.
- [Verify Signatures](/tempo/guides/access-keys/verify): Verify that a keychain signature was produced by an active access key for the expected account.
- [Stablecoin Exchange](/tempo/guides/stablecoin-exchange/): Trade stablecoins on Tempo's enshrined DEX, manage orders and balances, create trading pairs, and provide Fee AMM liquidity.
- [Swap Stablecoins](/tempo/guides/stablecoin-exchange/swap): Quote and swap one USD-denominated TIP-20 stablecoin for another on Tempo's enshrined DEX.
- [Place & Manage Orders](/tempo/guides/stablecoin-exchange/orders): Place limit and flip orders on Tempo's Stablecoin DEX, then read, inspect, and cancel them.
- [Manage Exchange Balances](/tempo/guides/stablecoin-exchange/balances): Read your internal Stablecoin DEX balances and withdraw them back to your Tempo wallet.
- [Create a Trading Pair](/tempo/guides/stablecoin-exchange/create-pair): Create a new trading pair on Tempo's Stablecoin DEX and configure a token's quote token.
- [Provide Fee AMM Liquidity](/tempo/guides/stablecoin-exchange/fee-amm-liquidity): Add and remove liquidity in Tempo's Fee AMM so stablecoin fee conversions can settle.
- [Virtual Addresses](/tempo/guides/virtual-addresses/): Register a master address and accept TIP-20 deposits at unlimited virtual addresses that forward to you without sweeps.
- [Register a Master Address](/tempo/guides/virtual-addresses/register): Mine a TIP-1022 proof-of-work salt and register a master address for virtual-address deposit forwarding.
- [Resolve & Accept Payments](/tempo/guides/virtual-addresses/resolve): Derive per-customer virtual deposit addresses offchain and resolve them to your master wallet.
- [Receive Policies](/tempo/guides/receive-policies/): Control who can pay you on Tempo with receive policies, validate inbound transfers, and recover blocked funds.
- [Set a Receive Policy](/tempo/guides/receive-policies/set): Set and read an account's receive policy to control which senders and tokens it accepts.
- [Validate Transfers](/tempo/guides/receive-policies/validate): Check whether a TIP-20 transfer would be accepted by a recipient's receive policy before sending it.
- [Handle Blocked Funds](/tempo/guides/receive-policies/blocked): Read, claim, and burn TIP-20 funds that a receive policy blocked from being credited.
- [Payment Channels](/tempo/guides/payment-channels/): Open funded TIP-20 channels on Tempo, stream off-chain vouchers, and settle or close to move funds onchain.
- [Open & Fund a Channel](/tempo/guides/payment-channels/open): Open and fund a TIP-20 payment channel on Tempo, top it up, and read its onchain state.
- [Send & Settle Vouchers](/tempo/guides/payment-channels/vouchers): Sign off-chain TIP-20 channel vouchers as the payer and settle them onchain as the payee.
- [Close & Withdraw](/tempo/guides/payment-channels/close): Close a TIP-20 payment channel from either side and withdraw the remaining deposit on Tempo.
- [Private Zones](/tempo/guides/zones/): Connect to private Tempo Zones, deposit funds into them, and withdraw back to Tempo Mainnet.
- [Connect to a Zone](/tempo/guides/zones/connect): Connect a Viem client to a private Tempo Zone and authenticate with an authorization token.
- [Deposit to a Zone](/tempo/guides/zones/deposit): Deposit TIP-20 stablecoins from Tempo Mainnet into a private Tempo Zone.
- [Withdraw from a Zone](/tempo/guides/zones/withdraw): Withdraw TIP-20 stablecoins from a private Tempo Zone back to Tempo Mainnet.
- [Accounts](/tempo/accounts/)
- [Account.fromSecp256k1](/tempo/accounts/account.fromSecp256k1)
- [Account.fromP256](/tempo/accounts/account.fromP256)
- [Account.fromWebAuthnP256](/tempo/accounts/account.fromWebAuthnP256)
- [Account.fromWebCryptoP256](/tempo/accounts/account.fromWebCryptoP256)
- [Overview](/tempo/actions/)
- [accessKey.authorize](/tempo/actions/accessKey.authorize)
- [accessKey.burnWitness](/tempo/actions/accessKey.burnWitness)
- [accessKey.getMetadata](/tempo/actions/accessKey.getMetadata)
- [accessKey.getRemainingLimit](/tempo/actions/accessKey.getRemainingLimit)
- [accessKey.isAdmin](/tempo/actions/accessKey.isAdmin)
- [accessKey.isWitnessBurned](/tempo/actions/accessKey.isWitnessBurned)
- [accessKey.revoke](/tempo/actions/accessKey.revoke)
- [accessKey.signAuthorization](/tempo/actions/accessKey.signAuthorization)
- [accessKey.updateLimit](/tempo/actions/accessKey.updateLimit)
- [accessKey.verifyHash](/tempo/actions/accessKey.verifyHash)
- [accessKey.watchAdminAuthorized](/tempo/actions/accessKey.watchAdminAuthorized)
- [accessKey.watchWitness](/tempo/actions/accessKey.watchWitness)
- [accessKey.watchWitnessBurned](/tempo/actions/accessKey.watchWitnessBurned)
- [amm.burn](/tempo/actions/amm.burn)
- [amm.getLiquidityBalance](/tempo/actions/amm.getLiquidityBalance)
- [amm.getPool](/tempo/actions/amm.getPool)
- [amm.mint](/tempo/actions/amm.mint)
- [amm.rebalanceSwap](/tempo/actions/amm.rebalanceSwap)
- [amm.watchBurn](/tempo/actions/amm.watchBurn)
- [amm.watchMint](/tempo/actions/amm.watchMint)
- [amm.watchRebalanceSwap](/tempo/actions/amm.watchRebalanceSwap)
- [channel.close](/tempo/actions/channel.close)
- [channel.getStates](/tempo/actions/channel.getStates)
- [channel.open](/tempo/actions/channel.open)
- [channel.requestClose](/tempo/actions/channel.requestClose)
- [channel.settle](/tempo/actions/channel.settle)
- [channel.signVoucher](/tempo/actions/channel.signVoucher)
- [channel.topUp](/tempo/actions/channel.topUp)
- [channel.withdraw](/tempo/actions/channel.withdraw)
- [fee.getUserToken](/tempo/actions/fee.getUserToken)
- [fee.setUserToken](/tempo/actions/fee.setUserToken)
- [fee.watchSetUserToken](/tempo/actions/fee.watchSetUserToken)
- [nonce.getNonce](/tempo/actions/nonce.getNonce)
- [nonce.watchNonceIncremented](/tempo/actions/nonce.watchNonceIncremented)
- [policy.create](/tempo/actions/policy.create)
- [policy.getData](/tempo/actions/policy.getData)
- [policy.isAuthorized](/tempo/actions/policy.isAuthorized)
- [policy.modifyBlacklist](/tempo/actions/policy.modifyBlacklist)
- [policy.modifyWhitelist](/tempo/actions/policy.modifyWhitelist)
- [policy.setAdmin](/tempo/actions/policy.setAdmin)
- [policy.watchAdminUpdated](/tempo/actions/policy.watchAdminUpdated)
- [policy.watchBlacklistUpdated](/tempo/actions/policy.watchBlacklistUpdated)
- [policy.watchCreate](/tempo/actions/policy.watchCreate)
- [policy.watchWhitelistUpdated](/tempo/actions/policy.watchWhitelistUpdated)
- [receivePolicy.burn](/tempo/actions/receivePolicy.burn)
- [receivePolicy.claim](/tempo/actions/receivePolicy.claim)
- [receivePolicy.get](/tempo/actions/receivePolicy.get)
- [receivePolicy.getBlockedBalance](/tempo/actions/receivePolicy.getBlockedBalance)
- [receivePolicy.set](/tempo/actions/receivePolicy.set)
- [receivePolicy.validate](/tempo/actions/receivePolicy.validate)
- [receivePolicy.watchBlocked](/tempo/actions/receivePolicy.watchBlocked)
- [receivePolicy.watchBurned](/tempo/actions/receivePolicy.watchBurned)
- [receivePolicy.watchClaimed](/tempo/actions/receivePolicy.watchClaimed)
- [receivePolicy.watchUpdated](/tempo/actions/receivePolicy.watchUpdated)
- [faucet.fund](/tempo/actions/faucet.fund)
- [reward.claim](/tempo/actions/reward.claim)
- [reward.distribute](/tempo/actions/reward.distribute)
- [reward.getGlobalRewardPerToken](/tempo/actions/reward.getGlobalRewardPerToken)
- [reward.getPendingRewards](/tempo/actions/reward.getPendingRewards)
- [reward.getUserRewardInfo](/tempo/actions/reward.getUserRewardInfo)
- [reward.setRecipient](/tempo/actions/reward.setRecipient)
- [reward.watchRewardDistributed](/tempo/actions/reward.watchRewardDistributed)
- [reward.watchRewardRecipientSet](/tempo/actions/reward.watchRewardRecipientSet)
- [simulate.simulateBlocks](/tempo/actions/simulate.simulateBlocks)
- [simulate.simulateCalls](/tempo/actions/simulate.simulateCalls)
- [dex.buy](/tempo/actions/dex.buy)
- [dex.cancel](/tempo/actions/dex.cancel)
- [dex.cancelStale](/tempo/actions/dex.cancelStale)
- [dex.createPair](/tempo/actions/dex.createPair)
- [dex.getBalance](/tempo/actions/dex.getBalance)
- [dex.getBuyQuote](/tempo/actions/dex.getBuyQuote)
- [dex.getOrder](/tempo/actions/dex.getOrder)
- [dex.getTickLevel](/tempo/actions/dex.getTickLevel)
- [dex.getSellQuote](/tempo/actions/dex.getSellQuote)
- [dex.place](/tempo/actions/dex.place)
- [dex.placeFlip](/tempo/actions/dex.placeFlip)
- [dex.sell](/tempo/actions/dex.sell)
- [dex.watchFlipOrderPlaced](/tempo/actions/dex.watchFlipOrderPlaced)
- [dex.watchOrderCancelled](/tempo/actions/dex.watchOrderCancelled)
- [dex.watchOrderFilled](/tempo/actions/dex.watchOrderFilled)
- [dex.watchOrderPlaced](/tempo/actions/dex.watchOrderPlaced)
- [dex.withdraw](/tempo/actions/dex.withdraw)
- [token.approve](/tempo/actions/token.approve)
- [token.burn](/tempo/actions/token.burn)
- [token.burnBlocked](/tempo/actions/token.burnBlocked)
- [token.changeTransferPolicy](/tempo/actions/token.changeTransferPolicy)
- [token.create](/tempo/actions/token.create)
- [token.getAllowance](/tempo/actions/token.getAllowance)
- [token.getBalance](/tempo/actions/token.getBalance)
- [token.getMetadata](/tempo/actions/token.getMetadata)
- [token.grantRoles](/tempo/actions/token.grantRoles)
- [token.hasRole](/tempo/actions/token.hasRole)
- [token.mint](/tempo/actions/token.mint)
- [token.pause](/tempo/actions/token.pause)
- [token.renounceRoles](/tempo/actions/token.renounceRoles)
- [token.revokeRoles](/tempo/actions/token.revokeRoles)
- [token.setRoleAdmin](/tempo/actions/token.setRoleAdmin)
- [token.setSupplyCap](/tempo/actions/token.setSupplyCap)
- [token.transfer](/tempo/actions/token.transfer)
- [token.unpause](/tempo/actions/token.unpause)
- [token.watchAdminRole](/tempo/actions/token.watchAdminRole)
- [token.watchApprove](/tempo/actions/token.watchApprove)
- [token.watchBurn](/tempo/actions/token.watchBurn)
- [token.watchCreate](/tempo/actions/token.watchCreate)
- [token.watchMint](/tempo/actions/token.watchMint)
- [token.watchRole](/tempo/actions/token.watchRole)
- [token.watchTransfer](/tempo/actions/token.watchTransfer)
- [validator.add](/tempo/actions/validator.add)
- [validator.changeOwner](/tempo/actions/validator.changeOwner)
- [validator.changeStatus](/tempo/actions/validator.changeStatus)
- [validator.get](/tempo/actions/validator.get)
- [validator.getByIndex](/tempo/actions/validator.getByIndex)
- [validator.getCount](/tempo/actions/validator.getCount)
- [validator.getNextFullDkgCeremony](/tempo/actions/validator.getNextFullDkgCeremony)
- [validator.getOwner](/tempo/actions/validator.getOwner)
- [validator.list](/tempo/actions/validator.list)
- [validator.setNextFullDkgCeremony](/tempo/actions/validator.setNextFullDkgCeremony)
- [validator.update](/tempo/actions/validator.update)
- [virtualAddress.getMasterAddress](/tempo/actions/virtualAddress.getMasterAddress)
- [virtualAddress.registerMaster](/tempo/actions/virtualAddress.registerMaster)
- [virtualAddress.resolve](/tempo/actions/virtualAddress.resolve)
- [wallet.deposit](/tempo/actions/wallet.deposit)
- [wallet.transfer](/tempo/actions/wallet.transfer)
- [wallet.swap](/tempo/actions/wallet.swap)
- [zone.deposit](/tempo/actions/zone.deposit)
- [zone.encryptedDeposit](/tempo/actions/zone.encryptedDeposit)
- [zone.getAuthorizationTokenInfo](/tempo/actions/zone.getAuthorizationTokenInfo)
- [zone.getDepositStatus](/tempo/actions/zone.getDepositStatus)
- [zone.getWithdrawalFee](/tempo/actions/zone.getWithdrawalFee)
- [zone.getZoneInfo](/tempo/actions/zone.getZoneInfo)
- [zone.requestVerifiableWithdrawal](/tempo/actions/zone.requestVerifiableWithdrawal)
- [zone.requestWithdrawal](/tempo/actions/zone.requestWithdrawal)
- [zone.signAuthorizationToken](/tempo/actions/zone.signAuthorizationToken)
- [withRelay](/tempo/transports/withRelay)
- [TempoAddress.format](/tempo/utilities/TempoAddress.format)
- [TempoAddress.parse](/tempo/utilities/TempoAddress.parse)
- [TempoAddress.validate](/tempo/utilities/TempoAddress.validate)
- [Storage.defaultStorage](/tempo/utilities/Storage.defaultStorage)
- [Storage.from](/tempo/utilities/Storage.from)
- [Storage.memory](/tempo/utilities/Storage.memory)
- [Storage.session](/tempo/utilities/Storage.session)
- [Client](/zksync/client): Setting up your ZKsync Viem Client
- [Chains](/zksync/chains)
- [toSinglesigSmartAccount (ZKsync)](/zksync/accounts/toSinglesigSmartAccount): Creates a single-signature ZKsync Smart Account
- [toMultisigSmartAccount (ZKsync)](/zksync/accounts/toMultisigSmartAccount): Creates a multi-signature ZKsync Smart Account
- [toSmartAccount (ZKsync)](/zksync/accounts/toSmartAccount): Creates a ZKsync Smart Account
- [deployContract](/zksync/actions/deployContract): Deploys a contract to the network, given bytecode & constructor arguments by using EIP712 transaction.
- [sendTransaction](/zksync/actions/sendTransaction): Creates, signs, and sends a new transaction to the network, with EIP712 transaction support.
- [signTransaction](/zksync/actions/signTransaction): Signs a transaction, with EIP712 transaction support.
- [writeContract](/zksync/actions/writeContract): Executes a write function on a contract, with EIP712 transaction support.
- [estimateGasL1ToL2](/zksync/actions/estimateGasL1ToL2): Returns an estimated gas for L1 to L2 execution.
- [getBlockDetails](/zksync/actions/getBlockDetails): Returns additional ZKsync-specific information about the L2 block.
- [getBridgehubContractAddress](/zksync/actions/getBridgehubContractAddress): Returns the Bridgehub smart contract address.
- [getDefaultBridgeAddresses](/zksync/actions/getDefaultBridgeAddress): Returns the addresses of the default ZKsync Era bridge contracts on both L1 and L2.
- [getGasPerPubData](/zksync/actions/getGasPerPubData): Returns the scaled gas per pubdata limit for the currently open batch.
- [getL1BatchDetails](/zksync/actions/getL1BatchDetails): Returns data pertaining to a given batch.
- [getL1BatchBlockRange](/zksync/actions/getL1BatchBlockRange): Returns the range of blocks contained within a batch given by batch number.
- [getL1BatchNumber](/zksync/actions/getL1BatchNumber): Returns the latest L1 batch number.
- [getL1TokenAddress](/zksync/actions/getL1TokenAddress): Returns the L1 token address equivalent for a L2 token address as they are not equal.
- [getL2TokenAddress](/zksync/actions/getL2TokenAddress): Returns the L2 token address equivalent for a L1 token address as they are not equal.
- [getLogProof](/zksync/actions/getLogProof): Given a transaction hash, and an index of the L2 to L1 log produced within the transaction, it returns the proof for the corresponding L2 to L1 log.
- [getTransactionDetails](/zksync/actions/getTransactionDetails): Returns data from a specific transaction given by the transaction hash.
- [estimateFee](/zksync/actions/estimateFee): Returns an estimated Fee for requested transaction.
- [getAllBalances](/zksync/actions/getAllBalances): Returns all known balances for a given account.
- [getBaseTokenL1Address](/zksync/actions/getBaseTokenL1Address): Returns the base token L1 address.
- [getL1ChainId](/zksync/actions/getL1ChainId): Returns the Chain Id of underlying L1 network.
- [getMainContractAddress](/zksync/actions/getMainContractAddress): Returns the address of a Main ZKsync Contract.
- [getRawBlockTransaction](/zksync/actions/getRawBlockTransactions): Returns data of transactions in a block.
- [getTestnetPaymasterAddress (depreated)](/zksync/actions/getTestnetPaymasterAddress): Returns the address of a Paymaster on a Testnet.
- [getL1Allowance](/zksync/actions/getL1Allowance): Determines the amount of approved tokens for a specific L1 bridge.
- [getL1Balance](/zksync/actions/getL1Balance): Returns the amount of the token held by the account on the L1 network.
- [getL1TokenBalance](/zksync/actions/getL1TokenBalance): Retrieve the token balance held by the contract on L1.
- [isWithdrawalFinalized](/zksync/actions/isWithdrawalFinalized): Returns whether the withdrawal transaction is finalized on the L1 network.
- [withdraw](/zksync/actions/withdraw): Initiates the withdrawal process which withdraws ETH or any ERC20 token from the associated account on L2 network to the target account on L1 network.
- [requestExecute](/zksync/actions/requestExecute): Requests execution of a L2 transaction from L1.
- [finalizeWithdrawal](/zksync/actions/finalizeWithdrawal): Proves the inclusion of the `L2->L1` withdrawal message.
- [deposit](/zksync/actions/deposit): Transfers the specified token from the associated account on the L1 network to the target account on the L2 network.
- [claimFailedDeposit](/zksync/actions/claimFailedDeposit): Withdraws funds from the initiated deposit, which failed when finalizing on L2.
- [getApprovalBasedPaymasterInput](/zksync/utilities/paymaster/getApprovalBasedPaymasterInput): Returns encoded formatted approval-based paymaster params.
- [getGeneralPaymasterInput](/zksync/utilities/paymaster/getGeneralPaymasterInput): Returns encoded formatted general-based paymaster params.
- [getL2HashFromPriorityOp](/zksync/utilities/bridge/getL2HashFromPriorityOp): Returns the hash of the L2 priority operation from a given L1 transaction receipt.
- [parseEip712Transaction](/zksync/utilities/parseEip712Transaction): Parse EIP712 transaction.
- [Viem · TypeScript Interface for Ethereum](/index)
- [Client](/experimental/client): Setting up your Viem Client
- [ZKsync](/docs/chains/zksync): Integrating with ZKsync in Viem
- [defineKzg](/docs/utilities/defineKzg): Defines a KZG interface.
- [fromBase58](/docs/utilities/fromBase58)
- [fromBase64](/docs/utilities/fromBase64)
- [toBase58](/docs/utilities/toBase58)
- [toBase64](/docs/utilities/toBase64)
- [opaqueDataToDepositData](/op-stack/utilities/fromOpaqueData): Decodes opaque deposit data found in the "TransactionDeposited" event log.
- [fee.validateToken](/tempo/actions/fee.validateToken)
- [Setup](/tempo/actions/setup)
- [withFeePayer](/tempo/transports/withFeePayer)
- [TODO](/account-abstraction/actions/bundler/introduction)
- [verifyHash](/docs/actions/public/verifyHash): Verifies if a signed hash was generated by the provided address.
-->

# Test Client \[A function to create a Test Client]

A Test Client is an interface to "test" JSON-RPC API methods accessible through a local Ethereum test node such as [Anvil](https://getfoundry.sh/anvil/overview) or [Hardhat](https://hardhat.org/) such as mining blocks, impersonating accounts, setting fees, etc through [Test Actions](/docs/actions/test/introduction).

The `createTestClient` function sets up a Test RPC Client with a given [Transport](/docs/clients/intro).

## Import

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"e31565978c8937a71522ec2d89471f9dcc302d109d4a5bd35ca5e3e191bbc257","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808AKAQwBsBLZuASgAIAzAK5gAxmnYQwvEaRjMaAFXhoAwhxhg0AHgC20GLzo0wUOLwA6IZmCLtWl3gB8LBZqSj55D55YDm15hF8GEsKXjRSazgsCFI0Q3oNU14FSLBo2LQwoOZ2KSMksxVPPKdeYVh+PJgoXgBecpMYKrAasMCRCGE0AHlSAEEoKFk4MwKTM36RTu6yweH4M2cK5urahpWWtt5SLBEAZSCYHWYE42SAJT3D4JOyzbX6xsq1gD5GLDdmHRgaUjhECllGp2BpVJIqr5dPowhEojE4tkSmB2tMupo+vMRnAwrsDkcTq9uIClHBVOpNNDYLC0hlEdJkWEAApuOAwKYzSkddG9AZDbGvGmCGC464E5ivcxgdg6BHxGRyRTAikMKhQCAiBCIEAqWTyeC8U6k+IgsG8ADu7DQ+ENvF87BIUmQqXhmQAuox8Gg0FgAQB6P22Y4AOjg+D96s1fpEKrgfryEQgfE6YEhglktX4sVtyGKuTAHq9Pv9gdBOlD4cjcZjoM01eRPGDUqlAFpeAARDUA3hF32IANB8thiNd6Oxv00MnNsD9IFk3imzS8dhmazLzRkfiBAxoCAuSdoBwAKX2PQAci2LkyVLx+kyAJK8H7W6Cr6aLdgAI1YO/wpC6vg2qcrAamwvAAKLWmQMCCDo4TKLwkCwLwcCCEEhpmMg/Q2HYhben2AafhAEAANbBr4vxZhUpAYBWfrWLYrB+nw2bIAAEm4HjyHhxb9n6njuJ4aDBrEvjMShaFAWYOh5Hkvi8N+GokTiy6ymQcCSPIcmGmi3QqWy3rafwMDwGEvwiOEf4ATazoIVM4iSHAPEEaWIbDlW9FiBI6QTso8aaP+UBoQ5YDcMGlDUMwvhasgyAgJ8kQ6BFKaQrwbbAAAAhwYAkXO5K1uCqbsL4AC+IBuhQcWyGg6bpBFs7GguKrBrwmXZblxqLmgZUVXFdDfFgP4RTKcqtdIepKmSXXZIIZIQHBJUCP+cEAOSDitUojZkY1USYNG8It/DLbwa1ltGDYbWAUopvONZmg0Cr6p1KqMMAUq8E++iAitDF2CtFDvQy+aArtwwYADUjhLScqAr2jDcBDJXcOVFUgGSbgMIgACcVA/mAvjWkgACMABsVBoG4FGYyAj2TflYIRdluCIAADFQOSRGIZBIFjJWo50sB4FtcRjbTMDPQVB1LfNJ3rRFz7MEgoDjHA3l4GgCAlSVQA="}
import { createTestClient } from 'viem'
```

## Usage

Initialize a Client with your desired [Chain](/docs/chains/introduction), [Transport](/docs/clients/intro) (e.g. `http`) and [mode](#mode) (e.g. `"anvil"`).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"f8fc0dd3f4319108221b560684361de4cf5058d2d94aecc0a3905dfdd000121c","data":"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="}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'

const client = createTestClient({
  chain: foundry,
  mode: 'anvil',
  transport: http(), 
})
```

Then you can consume [Test Actions](/docs/actions/test/introduction):

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"858297c2f2708d28b2aa0963e19da0ceb0f3014f14d651ae6f5649a21dbe762d","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAgFsBLMGRdkQjcolEGwCGpBogBsVADYwwAczT4kAFipopKmDJA8+Yhb1yIADFUb4pExjXJyAvhXTYLBYmTE16TCxs7IxmymgCwAA6YOxxXND87FEgEmBE3AopANwx8ewOzACuYBHsJbAAZuZQubHxAEYSaLYA/JF5+fGcRQpo3IwSCgrt7A0QEEpp7AA+7AAKpAb9lRgAPACyvf2DwwBCzbYA8lj9QQB8s+VgVTV1+S5XFTDVfLWdcYO2MAAq3JxJMBFTgNMj3eKMRjcLAAJRgEigo0qQzgMCu0XqXXYSwAjkV4GhRgAKLD2AFOOACADCUNhMDxBPmZIMZDgAEp2ABeS6LCA8VFrGnQuEMthwtBFUhgH6ec7guKPObPV4wd6YkJ2XgddX5BoKCCMADWAFFaFh9UtSHBRhisVjkIaYBgBGxSLwVABdamasB7fVG03miCW+V2uJVCTbb0SXh+g0ms0WsEfLqK663N5PG4vO4p/IAOkL7AAjLIEkt2IX86H8iQ3asABISOD4UZUn0ANTI3EbzfwADFYkrsyq1Q9Q1X2ABmACc5bRVdDdBoNwEa2YrA4oW44XYy+UUDg7FtdsXKceADJ2KaHGgmdJuEM1lXzuciZUwAIidvwtSwqVn0Lc4OW5EJ/zQEDLipcDAPzOUYhcMRJGkJBixnRRlDUDQ5B0PQDCYcDTHMJBrBAWx7EcXxEDQtwPBwPBCDrPxlzwElSAgHBpAwDljCSIk9EpdgNnMe8JHJVlIIWdj+RgNYhBEc4xCgA0EEQEBhL4Ap2DgHAoWqVV2CBEEyHYCBKjGf1DTgfMYhiABadgABEVIEfA0DQLBKQAei8jIYE4fMWy85TGDgLzb24IIvJoNgvN4vwJBUVTkGQEBSVIMSxB/Up2Ac6CdxytAIHKVEQA9ChUvSzKqAE9hAGQCY8AAEzDAQ0hJE5kKUQ8rUroMTzVwKh/iwYMOGAEIlmaX4CXy8IKHYNyPPYR5Kmk9gAHI/M4daYmG0bj3YSoIAqUgMGWw61s2ndOC88jeDgHawBiDdgmyjhOQm+EaB+GbwKJE9OESAR1rSDIFHWihOjuz8NqOk6MAhzo0Ay1gRukVz3KwIk2UhsAXDZGIJAAdxjLdwPzXj/os+NBOLZa2TK8rxF0FDEAAJnkEAlFUdQtFw0h9EMeLFGIqwbDsDLKOcDnaOoTwGJ8cgdBYtS2I4shMA5PUaYEIzQSVkAQtUkAADlgX10zzO1o0jyKrhzHzJCWZkKcpwwnnsM5lnBbwa2rKIkwxbIiXbyo12XCZ5hYECTd7c0j7idJsCCrQCnzCpv3afp9gfPYZAAEIo7RI7GCKSli0sD0xHJCQkFAfdWEisA8DQBAXBcIA==="}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'

const client = createTestClient({
  chain: foundry,
  mode: 'anvil',
  transport: http(), 
})
// ---cut---
const mine = await client.mine({ blocks: 1 }) // [!code focus:10]
```

### Extending with Public & Wallet Actions

When interacting with a Ethereum test node, you may also find yourself wanting to interact with [Public Actions](/docs/actions/public/introduction) and [Wallet Actions](/docs/actions/wallet/introduction) with the same `chain` and `transport`. Instead of creating three different Clients, you can instead just extend the Test Client with those actions:

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"b23101d23883cd80b4cd80d68c92956f0fbc04558b861491cbcec54d7f39e2dc","data":"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"}
// @noErrors
import { createTestClient, http, publicActions, walletActions } from 'viem'
import { foundry } from 'viem/chains'

const client = createTestClient({
  chain: foundry,
  mode: 'anvil',
  transport: http(), 
})
  .extend(publicActions) // [!code hl]
  .extend(walletActions) // [!code hl]

const blockNumber = await client.getBlockNumber() // Public Action
const hash = await client.sendTransaction({ ... }) // Wallet Action
const mine = await client.mine({ blocks: 1 }) // Test Action
```

## Parameters

### mode

* **Type:** `"anvil" | "hardhat" | "ganache"`

Mode of the Test Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"8fb95f240c98b4305c50d5e6546d44a631bc184b18a6c756705b61bcf1dcf26c","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAkYBsBLGMNInbAAOmHYT2AW2gwhIkAEMwRHlwUBuMZPaLGzAK4ChR2ADMeYGFC3jJAI0VpG+APxDRdnRKkGuaHkZFLi53dnsICC4YZXYAH3YABVIYNACzDAAeAFk/AKCQgCEnFwB5LACWOAA+ePZTGAsrG21JAF86hqbrWx0glxgAFR4pOXYwAyl7Ml7JfR4sACUYqDCzYLgYOs9vSRSARwN4NDCACixFUkVRmlI4IQBhRgXlw+PEy+vUsjgASnYALy1ZIQKQ8TaZJ4vGBvNjLNAGUhgQbYGDVWYSDoJLqWHqtCQuRSWDz47z2LgQRgAawAorQsBSUncwjtdt5kFSYBghGxSJYAOYAXUe+CJYEKFOpdIZECZGLZEnMijyIrFEsptPpjJmpJ0WPqYHMuKgnUNjWN8p0ADobewAIwANmksq2NqtlskJD5GQAEoo4G5VZYAGpkHi+/34ABi4mxZu6LS87Da8rd7AAzABOZ0pdhu+V0GiGoSZZisDjcPgCdiF/hQODCXWSfOkjoAMnYdL0aA+pACwUybuq1VOZjAQlOlf4gnYD1408HNuq/yBnHnAhXtTnVbQi6t6LEbUoIDYlwYiAdVGiYH5aHwSEv1Eu/NSTHXDCvuKQAAYqISrowtwPm0FDoKieCEF6x40PQeCnMEPD+v8jApE4QzHNuC4KMoqjqJQ7A+mkWCDFcrBYLKu44s0FDsOsXCbNUNGshI5IatK2rMiSSY6ByXI8mgfI3sKs6ipY6pSlqLqkB6iqNMq/hBuKkqajKcqtqaRrNBp5rNPKrHUsMoxhBMUxkNpCbmRapJlgJ3ZwCyTYSMgtD8YJQqKQ8LC2YB2yOeycAQIijAwAAklAQgmdMpDCQ8olgJ5AgARwcaaXi3HtJZul+fwcDLPy4ICRgYSxWKCXeclBqpYmCo5QAqmAPBenAwTLAFXBesVcVlUlmVpQqvj+IEwRcOmnWlV5PUpTpfVsmQjAOgALJmABMobenwpBjZY3Xdr11UZVNCapradoLTmro2vKXrhhgfoBltYBrTdd3RrGlXTYmIHvQmNFUdYI4XFcNw/Fx1qXYevyg824NgG0YgjORfacKhNCDBh77HlAlIIIgIAPCj8C6OwaNsLO77sAA7jwd5E/lJDiMgJHKHAiNoIKpz4ER9wAPTc6oMBSFaAbc1jjBwNzU4COLlgCRAyEsBY/KItYtGykTyAlZY7Oc2gWA83zfCC8Lovi5LaCm3FfxWmIYgALTsAAItjQg63riC8/zRv4CL2MS++4s0GwNtgAAgsTxxkzu7Dgro4gy2Q6zBewaAQOwCiB2gCjsAAUgAyqUABytuLIkDzsCHiQhdIqSEPWuj6PAcA8OSWx3qQgX8vgROSsEnZ3mQMCTMnEeQLA7BwAYLi6A2yAhyoaja1z7vcxEEBUlaL5oGYgWGqQGBC97OFqNz/xq8gfqkFAopsxzS+86Kl/X1asr8if4+T13/rSJYArhMpcA0QRj8FgThf56EMFLGimw0i/zMDAeANFUiMGTvgduBhO7sEZhHEOgEeBVEXrrfWnsD4+zFtzbseDWDcwztzGW7coCT0qGAX4VpoKKH5DjZAyAQCA2uMeMsit2D22AAAAV4GAKk4c2CYQEAlRWR5BQUG4SkBESIEBUDDiTDgMi0BWmEGIywkitE6IUUokAdBrgMlwFQBGFFhDIxiKjdGO4aKMAMGwUEyZaLtykOwAA5J7Px8MpCs3sdvUwe8vFmB8f4z2EtLZBLAGIMspMzaAgcWhYx75TishkLAIQfij5cD8RQVohJiSqwiRgUpdhbJkQoi7Iipxfg1LaL8EAgpFEnjQGeJAdoACsV5+C3nvIgR0VAemkE3kwAmWSdzHnEbgRAv4QD/m7GQPp/SQJgRwBBYgGyJmFjglgduOA+wYGQnFB6vkkz6RUhxeyUNdi8W5OPASAoYpxXEvcqSMl2BKhVCJNUyl2K/PUodY0e09LKUMjAYykwop7ShdZCadkHLpSci5N5blPnjUSrtBIzEFSYICkFUK4VxgIrILi7aqKfIQqyhirxDKZq7BynlAqe8Ho7Xpd9KyTK6oNSai1eAUQOoeTpRVP6+1dgDXyMNUaEr8W8ulX8uai0VpPQsGQblkrkVJn1Kq0kaZTrnTzDDHQ10Iz3UUlq26kYYz6sNfGY0mNsZ4E1uIbepAUFbDNqwqgp4+xIHTI+a8IykCDKfFM18uNylgAWV+MZf4H7rPIIgZa2zqDgVxpBA51Ajm43grwJCnAqgcHCbvV5RK7mgqZI8xsTKXmuQ+Ypb5dadRMoBQpIFYkQWSTUgapFLKZV/w1LC+FpkfUjv1X0SVDaiU8SxbyVtvb4p6sJX5HipLSDBTChFKl0UlXlVnWyZ1VU1WsA5byIqx7Jp8sZTVVg9VGo/BFW1cVa6eVSpdY+tkcqhohEVV+jdD7WXeHVUtVaYZtWbTvQSsDo7z0fWOno01MhcwtiTFa+1Nq112peo6kdtg4YNRCXYytUA97HiDeeBa6Yhk3jvEgAA7BM58saQCUeo5+KwfSU2fEAhsxAmYs2YF2bm/Z5BDmwSLSciAZzMD/DyWMbC888J1AUA/K+Tgs4JAUPyZQeh8AwAUG6sWeBsiyHYBAMwvrh6pPfAG7pvTED9IWoxiNiAPPRumbjFTia+MZoE0lYTmbQLZokwQKT0FC0gHOKcsgSnk6kRZg0giREmb1L7JkaVNE6IMXMzjEAgwTPsBLmXOpaXg2BsmeeAAHPVzzzGRPsZjeeagqXWaBaWQx1ZqahPpvCzspZ0WoIyY68WxCfx2Cu1y7+6w+WNholOIiUILabx7VcQrHg/IwiEV1ll6raA5G7fm1VJb9E0SQwy4drrFFzsfUuwxYJoTXZsI4UgLhIBYBwBQgsJhx58aOMJooAigxBiJBS8zUJd4nBlrAFYQCDYU5EzzoXYupdy6V1YZ02rrnMyZma6Mnzky/MECIj1kNIW019PTG0LpzBYBMHLWuKOAIMlOOkdk1k8ahDceqa0FTBSiklPYLzTBABCJnWxt5uLgIKVoVXWaNN1s0miENjw3EUEgUAtZWCULwObEAbQ2hAA"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
const client = createTestClient({
  chain: foundry,
  mode: 'anvil', // [!code focus]
  transport: http(), 
})
```

### transport

* **Type:** [Transport](/docs/glossary/types#transport)

[Transport](/docs/clients/intro) of the Test Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"4e4badc509c7ed734cd9f2877e1d0280ddd873fa373d8856bec1203cfe78dec6","data":"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"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
const client = createTestClient({
  chain: foundry,
  mode: 'anvil', 
  transport: http(),  // [!code focus]
})
```

### account (optional)

* **Type:** `Account | Address`

The Account to use for the Client. This will be used for Actions that require an `account` as an argument.

Accepts a [JSON-RPC Account](/docs/accounts/jsonRpc) or [Local Account (Private Key, etc)](/docs/accounts/local/privateKeyToAccount).

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"8b9acd44301c42d7917599140e66b6a3adf18d44fb49086636bfefd305bd2872","data":"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"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
import { privateKeyToAccount } from 'viem/accounts'

const client = createTestClient({
  account: privateKeyToAccount('0x...'), // [!code focus]
  chain: foundry,
  mode: 'anvil',
  transport: http(),
})
```

### chain (optional)

* **Type:** [Chain](/docs/glossary/types#chain)

[Chain](/docs/chains/introduction) of the Test Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"192b60d5c0420f25a94ee63b56a296ad3c2adf5d28e4160bcd3eeba1a19c060a","data":"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"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
const client = createTestClient({
  chain: foundry, // [!code focus]
  mode: 'anvil',
  transport: http(), 
})
```

### cacheTime (optional)

* **Type:** `number`
* **Default:** `client.pollingInterval`

Time (in ms) that cached data will remain in memory.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"1a7e17c11901ed86f3e930756f5af76d1a2cb1eb2ec8d4d92924e01ca9736a4e","data":"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"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
const client = createTestClient({
  cacheTime: 10_000, // [!code focus]
  chain: foundry,
  mode: 'anvil',
  transport: http(),
})
```

### name (optional)

* **Type:** `string`
* **Default:** `"Test Client"`

A name for the Client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"dcb33989b8355dd27779f010699a9cae6dfbd49911b6ce5d1548964482495da5","data":"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"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
const client = createTestClient({
  chain: foundry,
  mode: 'anvil', 
  name: 'Anvil Client',  // [!code focus]
  transport: http(),
})
```

### pollingInterval (optional)

* **Type:** `number`
* **Default:** `4_000`

Frequency (in ms) for polling enabled Actions.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"1ad314c5c96c469e5e1dfca2ad20e00aa5cead0c121e3433b9a6437b692b0693","data":"N4Igdg9gJgpgziAXAbVAFwJ4AcZJACwgDcYAnEAGhDRgA808BjCMONAAkYBsBLGMNInbAAOmHYT2AW2gwhIkAEMwRHlwUBuMZPaLGzAK4ChR2ADMeYGFC3jJAI0VpG+APxDRdnRKkGuaHkZFLi53dnsICC4YZXYAH3YABVIYNACzDAAeAFk/AKCQgCEnFwB5LACWOAA+ePZTGAsrG21JAF86hqbrWx0glxgAFR4pOXYwAyl7Ml7JfR4sACUYqDCzYLgYOs9vSRSARwN4NDCACixFUkVRmlI4IQBhRgXlw+PEy+vUsjgASnYALy1ZIQKQ8TaZJ4vGBvNjLNAGUhgQbYGDVWYSDoJLqWHqtCQuRSWDz47z2LgQRgAawAorQsBSUncwjtdt5kFSYBghGxSJYAOYAXUe+CJYEKFOpdIZECZGLZEnMijyIrFEsptPpjJmpJ0WPqYHMuKgnUNjWN8p0ADobewAIwANmksq2NqtlskJD5GQAEoo4G5VZYAGpkHi+/34ABi4mxZu6LS87Da8rd7AAzABOZ0pdhu+V0GiGoSZZisDjcPgCdiF/hQODCXWSfOkjoAMnYdL0aA+pACwUybuq1VOZjAQlOlf4gnYD1408HNuq/yBnHnAhXtTnVbQi6t6LEbUoIDYlwYiAdVGiYH5aHwSEv1Eu/NSTHXDCvuKQAAYqISrowtwPm0FDoKieCEF6x40PQeCnMEPD+v8jApE4QzHNuC4KMoqjqJQ7A+mkWCDFcrBYLKu44s0FDsOsXCbNUNGshI5IatK2rMiSSY6ByXI8mgfI3sKs6ipY6pSlqLqkB6iqNMq/hBuKkqajKcqtqaRrNBp5rNPKrHUsMoxhBMUxkNpCbmRapJlgJ3ZwCyTYSMgtD8YJQqKQ8LC2YB2yOeycAQIijAwAAklAQgmdMpDCQ8olgJ5AgARwcaaXi3HtJZul+fwcDLPy4ICRgYSxWKCXeclBqpYmCo5QAqmAPBenAwTLAFXBesVcVlUlmVpQqvj+IEwRcOmnWlV5PUpTpfVsmQjAOgALJmABMobenwpBjZY3Xdr11UZVNCapradoLTmro2vKXrhhgfoBltYBrTdd3RrGlXTYmIHvQmNFUdYI4XFcNw/Fx1qXYevyg824NgG0YgjORfacKhNCDBh77HlAlIIIgIAPCj8C6OwaNsLO77sAA7jwd5E/lJDiMgJHKHAiNoIKpz4ER9wAPTc6oMBSFaAbc1jjBwNzU4COLlgCRAyEsBY/KItYtGykTyAlZY7Oc2gWA83zfCC8Lovi5LaCm3FfxWmIYgALTsAAItjQg63riC8/zRv4CL2MS++4s0GwNtgAAgsTxxkzu7Dgro4gy2Q6zBewaAQOwCiB2gCjsAAUgAyqUABytuLIkDzsCHiQhdIqSEPWuj6PAcA8OSWx3qQgX8vgROSsEnZ3mQMCTMnEeQLA7BwAYLi6A2yAhyoaja1z7vcxEEBUlaL5oGYgWGqQGBC97OFqNz/xq8gfqkFAopsxzS+86Kl/X1asr8if4+T13/rSJYArhMpcA0QRj8FgThf56EMFLGimw0i/zMDAeANFUiMGTvgduBhO7sEZhHEOgEeBVEXrrfWnsD4+zFtzbseDWDcwztzGW7coCT0qGAX4VpoKKH5DjZAyAQCA2uMeMsit2D22AAAAV4GAKk4c2CYQEAlRWR5BQUG4SkBESIEBUDDiTDgMi0BWmEGIywkitE6IUUokAdBrgMlwFQBGFFhDIxiKjdGO4aKMAMGwUEyZaLtykOwAA5J7Px8MpCs3sdvUwe8vFmB8f4z2EtLZBLAGIMspMzaAgcWhYx75TishkLAIQfij5cD8RQVohJiSqwiRgUpdhbJkQoi7Iipxfg1LaL8EAgpFEnjQGeJAdoACsV5+C3nvIgR0VAemkE3kwAmWSdzHnEbgRAv4QD/m7GQPp/SQJgRwBBYgGyJmFjglgduOA+wYGQnFB6vkkz6RUhxeyUNdi8W5OPASAoYpxXEvcqSMl2BKhVCJNUyl2K/PUodY0e09LKUMjAYykwop7ShdZCadkHLpSci5N5blPnjUSrtBIzEFSYICkFUK4VxgIrILi7aqKfIQqyhirxDKZq7BynlAqe8Ho7Xpd9KyTK6oNSai1eAUQOoeTpRVP6+1dgDXyMNUaEr8W8ulX8uai0VpPQsGQblkrkVJn1Kq0kaZTrnTzDDHQ10Iz3UUlq26kYYz6sNfGY0mNsZ4E1uIbepAUFbDNqwqgp4+xIHTI+a8IykCDKfFM18uNylgAWV+MZf4H7rPIIgZa2zqDgVxpBA51Ajm43grwJCnAqgcHCbvV5RK7mgqZI8xsTKXmuQ+Ypb5dadRMoBQpIFYkQWSTUgapFLKZV/w1LC+FpkfUjv1X0SVDaiU8SxbyVtvb4p6sJX5HipLSDBTChFKl0UlXlVnWyZ1VU1WsA5byIqx7Jp8sZTVVg9VGo/BFW1cVa6eVSpdY+tkcqhohEVV+jdD7WXeHVUtVaYZtWbTvQSsDo7z0fWOno01MhcwtiTFa+1Nq112peo6kdtg4YNRCXYytUA97HiDeeBa6Yhk3jvEgAA7BM58saQCUeo5+KwfSU2fEAhsxAmYs2YF2bm/Z5BDmwSLSciAZzMD/DyWMbC888J1AUA/K+Tgs4JAUPyZQeh8AwAUG6sWeBsiyHYBAMwvrh6pPfAG7pvTED9IWoxiNiAPPRumbjFTia+MZoE0lYTmbQLZokwQKT0FC0gHOKcsgSn2DkRCAKEKAgyBEGCJOxFI7zM4xAFGA4RwwCMAwOwU4lhpB/FVj61L4j+Q1jAIoFuJoKFVHYB2GA9NzbOZ6RwpAXCQDdo/KsuKVo7mwvYNzDMHSum0dY8tTzzGxlRsmX5nhURGsZduNlrggWlkMfG4JoCGaxM5ui1BGT554vycUxc5OpEWYNIIkRJm9S+yZGlTROiDECt4EGCZ9gJcy51Je8GwNkzzx2jtGxkA4bVuZnYzG274PWaHaQD5tZQn03hZ2Usq7+aYK3eLYhWrrtvu/usL9jYaJTiIlCC2m8e1XEKx4PyMIhFdYfYh2gORHOqdVVp/RNEkM3s8+e6zIXH0RcMWCaE12bDBsoG4bAOAKEFhMOPPjRxhNFAEUGIMRIT3mahLvE4MtYArCAQbCnImedC7F1LuXSurDOlQ9c3aZaAAOFboyfMbc40r3jSzseptx309MbQunMFgEwcta4o4AgyU46R2TWTxqENx6prQVMFKKSUtOdgGvpcy6QfbQg7TfgAPrfnrzRGbs3kAAEI49bG3m4uAgpWjo9e67ZprT2lUBuIoJAoBaysEoXgc2IA2htCAA=="}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// ---cut---
const client = createTestClient({
  chain: foundry,
  mode: 'anvil', 
  pollingInterval: 10_000,  // [!code focus]
  transport: http(),
})
```

### rpcSchema (optional)

* **Type:** `RpcSchema`
* **Default:** `TestRpcSchema`

Typed JSON-RPC schema for the client.

```ts twoslash
// @twoslash-cache: {"v":2,"hash":"b93afda9c0b5575f5172cb273232a82f9807ff20e10e211ec208d71588d9c68e","data":"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"}
import { createTestClient, http } from 'viem'
import { foundry } from 'viem/chains'
// @noErrors
// ---cut---
import { rpcSchema } from 'viem'

type CustomRpcSchema = [{ // [!code focus]
  Method: 'eth_wagmi', // [!code focus]
  Parameters: [string] // [!code focus]
  ReturnType: string // [!code focus]
}] // [!code focus]

const client = createTestClient({
  chain: foundry,
  rpcSchema: rpcSchema<CustomRpcSchema>(), // [!code focus]
  transport: http()
})

const result = await client.request({ // [!code focus]
  method: 'eth_wa // [!code focus] 
//               ^|
  params: ['hello'], // [!code focus]
}) // [!code focus]
```
