Getting Started with ethereum blockchain development: part-1

Photo by Thought Catalog on Unsplash

This article assumes that the reader has basic understanding of blockchain vocabulary:

In this section, I will try to write basic smart contract and get it deployed on local blockchain.

Smart contract is written in solidity language. Before writing smart contract let’s setup machine for local development.

  1. Node environment: Node installer is available here. You can also use package manager like brew to install node.
Install using Brew: brew install node@8

2. Solc Compiler: Smart contract are compiled by Solc compiler. There are different ways to install Solc compiler. You can also use npm to install it.

npm install -g solc

3. Go Ethereum: Go Ethereum which is referred as geth is command line interface to run ethereum node implemented in Go. You can install geth from here.

4. Truffle framework: Truffle is development environment and test framework for ethereum. You can install truffle using npm.

npm install -g truffle

5. Ganache: What Ganache does is simple, it creates a virtual Ethereum blockchain, and it generates some fake accounts that we will use during development.

npm install -g ganache-cli

Bingo!! Now your local machine is setup for blockchain development.

Let’s create truffle project for your first blockchain application.

We can use truffle command to initialize project: truffle init

Following file and folders will be created:

  • contracts: Folder to keep solidity contracts
  • migrations: JS scripts to deploy solidity contracts
  • test: Truffle test cases
  • truffle.js: Truffle config file

Writing Smart Contract:

  1. Add truffle config file: Add below config to truffle.js. In below config, we are declaring development network, which will connect ethereum node running on localhost and port 8545.
module.exports = {
networks: {
development: {
host: "",
port: 8545,
network_id: "*" // Match any network id

2. Creating a contract: Lets create a simple contract ‘counter.sol’ file in contract folder.

Counter contract defines following things:

I. Events:

What are events in Solidity: Events are dispatched signals that smart contracts can fire. DApps, or anything connected to Ethereum JSON-RPC API(like node js application), can listen to these events and act accordingly.

Counter contract defines two events-

  • CounterIncrementedEvent
  • CounterDecrementedEvent

II. Variable: Like other programming languages, variable is something that holds data.

III. Methods: Counter contract defines three methods to increment, decrement and get counter value.

pragma solidity ^0.4.23;
contract Counter {

event CounterIncrementedEvent(int count);
event CounterDecrementedEvent(int count);
    int private count = 0;
    function incrementCounter() public {
count += 1;
emit CounterIncrementedEvent(count);
    function decrementCounter() public {
count -= 1;
emit CounterDecrementedEvent(count);
    function getCount() public constant returns (int) {
return count;

3. Deployment Script — Add deployment script named as ‘2_initial_migration.js’ for Counter.sol

var Counter = artifacts.require("./Counter.sol");
module.exports = function(deployer) {

4. Write Truffle Test cases: Create test file named as counter_test.js for Counter contract in test folder.

const Counter = artifacts.require("Counter");
contract('Counter test', async (accounts) => {
let instance;
  before(async () => {
instance = await Counter.deployed();//deploy contract
  it("Initial value of counter should be zero", async () => {
let count = await{from: accounts[0]});
assert.equal(count, 0);

5. Running test cases

  • Run ganache-cli: Run below command to run ganache


  • Run truffle tests: In separate Window, run truffle test cases using below command.

truffle test

Yayy!!! You have deployed and tested your first smart contract.

6. Add more tests:

i. Add test for Increment Counter :

it("Should increment counter", async () => {
await instance.incrementCounter({from: accounts[0]});
let count = await{from: accounts[0]});
assert.equal(count, 1);

ii. Add test to verify if event is emitted on Increment Counter:

it("Should emit event on increment counter", async () => {
let reciept = await instance.incrementCounter({from: accounts[0]});
assert.equal(reciept.logs.length, 1);
assert.equal(reciept.logs[0].args.count, 2);

Now you can try adding tests for Decrement Counter :)

Full source code is available on Github: sarveshgs/firstBlockchainApp

In part 2 of this blog, I will demonstrate how to write interaction layer in node js to interact with smart contract using web3.

Getting Started with ethereum blockchain development: Part-2

Happy Coding :)