How to Use the Command 'ganache-cli' (with Examples)

How to Use the Command 'ganache-cli' (with Examples)

Ganache-cli is a command-line interface version of Ganache, a personal blockchain for Ethereum development. Ganache is mainly used for testing smart contracts and blockchain applications in a controlled environment. It simulates the Ethereum blockchain on your local machine, enabling developers to perform tests quickly without incurring costs or requiring network connectivity.

Run Ganache

Code:

ganache-cli

Motivation:

Running the basic ganache-cli command starts a Ganache blockchain on your local machine with default settings. This approach is perfect for newcomers who wish to dive into Ethereum development right away or developers looking for a quick way to test simple applications. By using this straightforward command, you can easily simulate a blockchain environment without additional configurations.

Explanation:

The command ‘ganache-cli’ by itself does not specify any parameters or adjustments, meaning it runs with default settings: uses 10 accounts with 100 Ether each for testing, and listens on the default port (8545).

Example output:

Ganache CLI v<version> (ganache-core: <version>)
Available Accounts
==================
(0) 0x<address1> (100 ETH)
(1) 0x<address2> (100 ETH)
...

Run Ganache with a Specific Number of Accounts

Code:

ganache-cli --accounts=5

Motivation:

Certain Ethereum applications or tests might require a specific number of accounts for transaction testing. The --accounts option allows you to specify exactly how many accounts Ganache should generate. This capability proves beneficial in testing scenarios where multiple participants or entities are simulated.

Explanation:

The --accounts flag indicates the number of accounts to be created when the Ganache server starts. In this example, it creates 5 accounts.

Example output:

Ganache CLI v<version> (ganache-core: <version>)
Available Accounts
==================
(0) 0x<address1> (100 ETH)
(1) 0x<address2> (100 ETH)
(2) 0x<address3> (100 ETH)
(3) 0x<address4> (100 ETH)
(4) 0x<address5> (100 ETH)

Run Ganache and Lock Available Accounts by Default

Code:

ganache-cli --secure

Motivation:

For a higher security configuration during testing, you might require all accounts to be locked by default, preventing unauthorized transactions. Using the --secure option, you can simulate scenarios where accounts are only unlocked for specific, tested functions, ensuring tighter control over blockchain operations.

Explanation:

The --secure flag initializes the Ganache server with locked accounts, meaning that any Ether transfers or contract executions require explicit unlocking of accounts.

Example output:

Ganache CLI v<version> (ganache-core: <version>)
[locked accounts]

Run Ganache Server and Unlock Specific Accounts

Code:

ganache-cli --secure --unlock "account_private_key1" --unlock "account_private_key2"

Motivation:

There are cases where while most of the accounts should remain secure, a few need to be accessible to conduct necessary transactions or contract interactions. The combination of --secure and --unlock flags allows a developer to keep most accounts locked but explicitly unlock required accounts.

Explanation:

  • --secure starts Ganache with all accounts locked.
  • --unlock allows you to specify the private keys of accounts to keep unlocked, making them immediately available for transactions.

Example output:

Ganache CLI v<version> (ganache-core: <version>)
Unlocked Accounts
=================
(0) 0x<address1> - account_private_key1
(1) 0x<address2> - account_private_key2
...

Run Ganache with a Specific Account and Balance

Code:

ganache-cli --account="0x<private_key>,1000"

Motivation:

When testing particular scenarios, such as large transactions or smart contract executions that require specific balances, you might need a controlled environment setup. By specifying the account and balance, you can simulate conditions that align with your testing needs.

Explanation:

  • --account allows setting a specific account with a given balance.
  • The parameter format is account_private_key,balance_in_ether, meaning you can define precisely how much Ether each specified account should have.

Example output:

Ganache CLI v<version> (ganache-core: <version>)
Available Accounts
==================
(0) 0x<address> (1000 ETH)
...

Run Ganache with Accounts with a Default Balance

Code:

ganache-cli --defaultBalanceEther=50

Motivation:

Different test cases might require participants or nodes with varying financial capabilities. By adjusting the default balance, you can simulate real-world dynamics where users or entities have different wealth levels.

Explanation:

The --defaultBalanceEther option adjusts the starting balance for each generated account by Ganache. In this example, each account gets a balance of 50 Ether.

Example output:

Ganache CLI v<version> (ganache-core: <version>)
Available Accounts
==================
(0) 0x<address1> (50 ETH)
(1) 0x<address2> (50 ETH)
...

Run Ganache and Log All Requests to stdout

Code:

ganache-cli --verbose

Motivation:

Debugging blockchain applications often requires understanding the flow of requests and transactions. Using the --verbose flag, developers can log all incoming requests to stdout, providing insight into how their applications interact with the Ethereum network.

Explanation:

The --verbose option enables logging of all request activity on the Ganache blockchain, printing detailed transaction and request data to the terminal, aiding in troubleshooting and debugging.

Example output:

Ganache CLI v<version> (ganache-core: <version>)
[request 1]: ...
[request details]
...

Conclusion:

The ganache-cli provides a wide array of configurable options suitable for developing and testing Ethereum applications in a local environment. By exploring these various use cases, developers can tailor their personal blockchain environments to fit specific project needs, ensuring robust and comprehensive app testing. Whether you are starting with default settings, adjusting account balances, or requiring detailed debug logs, ganache-cli equips you with the flexibility and control to mimic real-world blockchain scenarios effectively.

Related Posts

How to use the command 'argos-translate' (with examples)

How to use the command 'argos-translate' (with examples)

Argos Translate is an open-source offline translation library and command-line interface (CLI) tool written in Python.

Read More
How to use the command 'in-toto-record' (with examples)

How to use the command 'in-toto-record' (with examples)

In-toto provides a framework for software supply chain security by allowing users to specify and verify a sequence of steps necessary for production and delivery.

Read More
How to Use the Command 'shellcheck' (with Examples)

How to Use the Command 'shellcheck' (with Examples)

Shellcheck is a powerful static analysis tool to analyze shell scripts.

Read More