This is the second tutorial in our Hello series.
- Hello Blockchain - write and deploy a smart contract to a Ganache test chain and interact with it using the command line
- Hello Truffle - write and deploy a smart contract to a test chain and interact with it using the Truffle develop console
Truffle is a smart contract framework that makes it easy to build smart contracts and deploy them to a blockchain. In this tutorial you will use the Hello.sol
contract from the Hello Blockchain tutorial, build a Truffle project around it, and use Truffle to deploy and interact with it on the Ganache CLI test chain.
To begin, create a new folder called HelloTruffle, and change into it.
mkdir HelloTruffle
$ cd HelloTruffle
You should have already installed Truffle in the setup for this week, but in case you have not, install it now:
npm install -g truffle
Then, initialize your Truffle package by running:
truffle init
This will create a few subdirectories and files that we will use to configure our deployment.
- contracts/: Directory for Solidity contracts
- migrations/: Directory for scriptable deployment files
- test/: Directory for test files for testing your application and contracts
- truffle.js: Truffle configuration file
To begin, create a new contract called Hello.sol
under the contracts/
folder. Copy and paste the code below (this is the same contract we used in the Hello Blockchain tutorial):
pragma solidity ^0.4.13;
contract Hello {
//this will hold our greeting text
string greeting;
function Hello() public {
//constructor to initialize default greeting to hello
greeting = "hello";
}
function getGreeting() public view returns (string) {
//return the greeting
return greeting;
}
function setGreeting(string _greeting) public {
//set the greeting to user-provided input
greeting = _greeting;
}
}
We'll use a migration to deploy Hello.sol
to the blockchain. To do this, we need to create a new file under the migrations/
folder.
You'll notice there is already a migration called 1_initial_migration.js
here. This deploys Migrations.sol
to the blockchain. With Truffle, migrations run in sequential order based on the number in the file path.
Write the following code in 2_deploy_contracts.js
to deploy Hello.sol
:
var Hello = artifacts.require("./Hello.sol");
module.exports = function(deployer) {
deployer.deploy(Hello);
};
When we run the migrate command in our truffle console, it will initiate the execution of the migrations, which will deploy our contracts to the blockchain.
truffle develop
In a new terminal window, open the same helloTruffle
folder you have your contract in, and run the following to open truffle logs:
truffle develop --log
That window will now display the output of the activity on the chain. Back in your truffle develop console, run the migrate command to migrate the contract to the chain. Because we are already in the truffle develop console, we can run migrate without the "truffle" command. Keep in mind you can also call truffle migrate from outside the develop mode, we have chosen to do it this way to illustrate how truffle's develop mode lets us interact with the contracts in an easier way.
migrate
Now our Hello.sol
contract should have been migrated to the blockchain. Your output should look something like:
Running migration: 1_initial_migration.js
Replacing Migrations...
... 0x4e914e28978087d8d275ffd7fba246a2123f165ac2913e0c8bfd8e1cfb19ff2c
Migrations: 0x8cdaf0cd259887258bc13a92c0a6da92698644c0
Saving successful migration to network...
... 0xd7bc86d31bee32fa3988f1c1eabce403a1b5d570340a3a9cdba53a472ee8c956
Saving artifacts...
Running migration: 2_deploy_contracts.js
Replacing Hello...
... 0xbf8d2bdfe4252bb739e50efda947d991db0afa65e29f5eb9fd23052a4963a715
Hello: 0x345ca3e014aaf5dca488057592ee47305d9b3e10
Saving successful migration to network...
... 0xf36163615f41ef7ed8f4a8f192149a0bf633fe1a2398ce001bf44c43dc7bdda0
Saving artifacts...
and if you look at the terminal running your logs you'll see the blockchain transactions running.
Now, we can interact with it directly to get its address:
Hello.address
You should see a '0x....'
address returned. This is the address of our contract on the chain. Now any player in the network can call the contract by addressing it directly.
If you run the following command you will also see the addresses of the 10 test accounts that truffle has created for us:
web3.eth.accounts
Notice that it returns an array of addresses, these are the default truffle test addresses, and we can use any of them to invoke the contract. We used web3 to access them.
Now, we will call the methods on our contract. We will first begin by creating an instance of the contract. When we did this without Truffle, we had to do all the intermediate steps of compiling and extracting the executable code. Truffle and web3 take care of that for us here and store an instance of our smart contract in an object called app.
Hello.deployed().then(function(instance){ app=instance; })
The Truffle environment may not be kind to breaking the code above across multiple lines.
The objective of the callback above was to capture the instance
of the application created when calling the deployed()
method. To verify that it worked, check the contents of the app
object, which you should recognize from past exercises:
app
Now we can call the methods directly off of app:
app.getGreeting()
should return the default greeting set in your contract, and:
app.setGreeting("Your greeting here", {from:web3.eth.accounts[0]})
should return a transaction receipt like this:
{ tx: '0x2a19e5bd16bb4d82b0528f6eb8867ae7a90fe9d8bc45e68b5f3adafa191ea6f0',
receipt:
{ transactionHash: '0x2a19e5bd16bb4d82b0528f6eb8867ae7a90fe9d8bc45e68b5f3adafa191ea6f0',
transactionIndex: 0,
blockHash: '0x47fb2ae21901b155905848aabc6c6424436d27231f6b79234519e933f0d68524',
blockNumber: 5,
gasUsed: 33864,
cumulativeGasUsed: 33864,
contractAddress: null,
logs: [],
status: '0x01' },
logs: [] }
Now get the greeting again and verify that it did indeed change:
app.getGreeting()
If you look at the output in the log window, you can see the history of all the calls you made to the contract and any blocks you may have added. Truffle also shows you the transaction IDs of the transactions that have been processed. This gives us a good amount of information about what's happening on our chain. In the next lab, we will use the Ganache GUI to get an even better, more navigable look at our chain activity.
To exit the truffle console, run:
.exit