CodeStoreOutOfGasError
Represents an error that occurs when a transaction runs out of gas during code storage. This error is typically encountered when the gas provided for storing code is insufficient to complete its execution.
Code store out of gas errors can occur due to:
- Insufficient gas provided for storing large contracts.
- Incorrect estimation of gas required for storing code.
- Contracts with high gas consumption during the deployment phase.
- Non-deterministic gas usage during code storage.
- If TEVM submitted the transaction using
createTransaction: true
and the account being used runs out of gas.
To debug a code store out of gas error:
- Review Gas Estimates: Ensure that the gas estimate for your transaction is accurate and sufficient, especially for large contracts. If you provided explicit gas-related parameters, double-check their values.
- Optimize Contract Code: Refactor your smart contract code to reduce gas consumption during deployment. Consider simplifying complex initialization code.
- Use TEVM Tracing: Utilize TEVM tracing to step through the deployment process and inspect gas usage.
- Estimate Gas Multiple Times: If using TEVM gas estimations, it might make sense to estimate gas many times and take the worst case to set
gasPrice
. Most nodes executeeth_estimateGas
10 times, while TEVM runs it only once. - Use Other Tools: Use other tools such as Foundry. If it works in Foundry, consider opening a bug report.
Example
Param
A human-readable error message.
Param
Additional parameters for the BaseError.
Extends
Constructors
new CodeStoreOutOfGasError()
new CodeStoreOutOfGasError(
message
?,args
?):CodeStoreOutOfGasError
Constructs a CodeStoreOutOfGasError.
Parameters
• message?: string
= 'Code store out of gas error occurred.'
Human-readable error message.
• args?: CodeStoreOutOfGasErrorParameters
= {}
Additional parameters for the BaseError.
Returns
Overrides
GasLimitExceededError
.constructor
Source
packages/errors/src/ethereum/ethereumjs/CodeStoreOutOfGasError.js:65
Properties
_tag
_tag:
string
='GasLimitExceeded'
Same as name, used internally.
Inherited from
Source
packages/errors/src/ethereum/GasLimitExceededError.js:76
cause
cause:
any
Inherited from
Source
packages/errors/src/ethereum/BaseError.js:110
code
code:
number
Error code, analogous to the code in JSON RPC error.
Inherited from
Source
packages/errors/src/ethereum/BaseError.js:108
details
details:
string
Inherited from
Source
packages/errors/src/ethereum/BaseError.js:87
docsPath
docsPath:
undefined
|string
Path to the documentation for this error.
Inherited from
GasLimitExceededError
.docsPath
Source
packages/errors/src/ethereum/BaseError.js:92
message
message:
string
Human-readable error message.
Inherited from
Source
node_modules/.pnpm/typescript@5.4.5/node_modules/typescript/lib/lib.es5.d.ts:1077
meta
meta:
undefined
|object
Optional object containing additional information about the error.
Inherited from
Source
packages/errors/src/ethereum/GasLimitExceededError.js:68
metaMessages
metaMessages:
undefined
|string
[]
Additional meta messages for more context.
Inherited from
GasLimitExceededError
.metaMessages
Source
packages/errors/src/ethereum/BaseError.js:96
name
name:
string
='GasLimitExceeded'
The name of the error, used to discriminate errors.
Inherited from
Source
packages/errors/src/ethereum/GasLimitExceededError.js:83
shortMessage
shortMessage:
string
Inherited from
GasLimitExceededError
.shortMessage
Source
packages/errors/src/ethereum/BaseError.js:100
stack?
optional
stack:string
Inherited from
Source
node_modules/.pnpm/typescript@5.4.5/node_modules/typescript/lib/lib.es5.d.ts:1078
version
version:
string
Inherited from
Source
packages/errors/src/ethereum/BaseError.js:104
EVMErrorMessage
static
EVMErrorMessage:EvmErrorMessage
=EVMErrorMessage.CODESTORE_OUT_OF_GAS
Source
packages/errors/src/ethereum/ethereumjs/CodeStoreOutOfGasError.js:58
prepareStackTrace()?
static
optional
prepareStackTrace: (err
,stackTraces
) =>any
Optional override for formatting stack traces
See
https://v8.dev/docs/stack-trace-api#customizing-stack-traces
Parameters
• err: Error
• stackTraces: CallSite
[]
Returns
any
Inherited from
GasLimitExceededError
.prepareStackTrace
Source
node_modules/.pnpm/@types+node@20.14.2/node_modules/@types/node/globals.d.ts:28
stackTraceLimit
static
stackTraceLimit:number
Inherited from
GasLimitExceededError
.stackTraceLimit
Source
node_modules/.pnpm/@types+node@20.14.2/node_modules/@types/node/globals.d.ts:30
Methods
walk()
walk(
fn
?):unknown
Walks through the error chain.
Parameters
• fn?: Function
A function to execute on each error in the chain.
Returns
unknown
The first error that matches the function, or the original error.
Inherited from
Source
packages/errors/src/ethereum/BaseError.js:133
captureStackTrace()
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
GasLimitExceededError
.captureStackTrace
Source
node_modules/.pnpm/@types+node@20.14.2/node_modules/@types/node/globals.d.ts:21
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
GasLimitExceededError
.captureStackTrace
Source
node_modules/.pnpm/bun-types@1.1.12/node_modules/bun-types/globals.d.ts:1613