callParams
method. The available call parameters are: forward
gasLimit
forward
parameter allows the sending of a specific amount of coins to a contract when a function is called. This is useful when a contract function requires coins for its execution, such as paying fees or transferring funds. The forward parameter helps you control the resources allocated to the contract call and offers protection against potentially costly operations. const amountToForward = 10;
const { value } = await contract.functions
.return_context_amount()
.callParams({
forward: [amountToForward, BaseAssetId],
})
.call();
expect(new BN(value).toNumber()).toBe(amountToForward);
gasLimit
refers to the maximum amount of gas that can be consumed specifically by the contract call itself, separate from the rest of the transaction. const { minGasPrice } = provider.getGasConfig();
await expect(
contract.functions
.return_context_amount()
.callParams({
forward: [10, BaseAssetId],
gasLimit: 1,
})
.txParams({ gasPrice: minGasPrice })
.call()
).rejects.toThrow(/Gas limit '1' is lower than the required: /);
gasLimit
vs Transaction Parameters gasLimit
gasLimit
parameter sets the maximum gas allowed for the actual contract call, whereas the Transaction gasLimit
(see Transaction Parameters ) sets the maximum gas allowed for the entire transaction and constrains the gasLimit
for the Call. If the Call gasLimit
is set to a value greater than the available Transaction gas, then the entire available Transaction gas will be allocated for the contract call execution. gasLimit
for the Call, the Transaction gasLimit
will be applied. const { minGasPrice } = provider.getGasConfig();
const amountToForward = 10;
const contractCallGasLimit = 100;
const transactionGasLimit = 3_000_000;
const result = await contract.functions
.return_context_amount()
.callParams({
forward: [amountToForward, BaseAssetId],
gasLimit: contractCallGasLimit,
})
.txParams({
gasLimit: transactionGasLimit,
gasPrice: minGasPrice,
})
.call();
const {
transactionResult: { transaction },
value,
} = result;
expect(new BN(value).toNumber()).toBe(10);
expect(new BN(transaction.scriptGasLimit).toNumber()).toBe(transactionGasLimit);