搭建智能合约测试环境、开发、编译、部署以及JS调用合约

参考: https://yq.aliyun.com/articles/212944#2

目标

1. 了解智能合约

2. 简单环境搭建

3. 能够利用solidity编写Hello World合约

4. 合约部署

5. 与合约互动

开发前的准备

truffle:最活跃的智能合约开发框架。

就像一般网站或App开发一样,在提供公开服务之前,开发者会在自己用于写程序的电脑(又称作本机)或透过测试网络来测试程序执行的效果,测试完成后,才会部署到公开的网络上提供服务。

开发区块链智能合约(程序)的过程也是如此。特别是公开链上所有写入或读取计算结果的操作都需要真金白银(虚拟代币),而且根据网络状况,每个公开链上的操作都需要要一小段反应时间(15秒~数分钟),这些等待颇浪费宝贵的开发时间⏳。

因此在开发的过程中,我们将使用testrpc工具在电脑上模拟智能合约所需的以太坊内存块链测试环境。

testrpc中也包含了Javascript版本的Ethereum虚拟机(Ethereum Virtual Machine),因此可以完整地执行智能合约。

安装所需工具

首先开发机上必须装好Node.js,再使用以下命令安装所需的工具:

$ npm install -g ethereumjs-testrpc truffle

启动Testrpc

安装好后随时可以使用testrpc命令来启动以太坊测试环境。

搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第1张图片
启动testrpc后

testrpc启动后自动建立了10个帐号(Accounts),与每个帐号对应的私钥(Private Key)。每个帐号中都有100个测试用的以太币(Ether)。

建立项目

开启另一个终端窗口,输入以下命令以建立项目:

richard@Rich:~/eth/SmartContractDemo$ ls

HelloWorld

richard@Rich:~/eth/SmartContractDemo$ cd HelloWorld/

richard@Rich:~/eth/SmartContractDemo/HelloWorld$ truffle init (第一条命令)

Downloading...

Unpacking...

Setting up...

Unbox successful. Sweet!

Commands:

  Compile:        truffle compile

  Migrate:        truffle migrate

  Test contracts: truffle test

richard@Rich:~/eth/SmartContractDemo/HelloWorld$ ls

contracts  migrations  test  truffle-config.js  truffle.js

richard@Rich:~/eth/SmartContractDemo/HelloWorld$

目录结构

搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第2张图片

/contracts:存放智能合约原始代码的地方,可以看到里面已经有三个sol文件,我们开发的HelloWorld.sol文件就存放在这里。

/migrations:这是Truffle用来部署智能合约的功能,待会儿我们会修改2_deploy_contracts.js来部署HelloWorld.sol。

/test: 测试智能合约的代码放在这里,支持js与sol测试。

truffle.js:Truffle的设置文档。

编译

现在执行truffle compile(第二条命令)命令,我们可以将HelloWorld.sol原始码编译成Ethereum bytecode

搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第3张图片
编译


搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第4张图片

部署

truffle框架中提供了方便部署合约的脚本。打开migrations/2_deploy_contracts.js文件(脚本使用Javascript编写),将内容修改如下:

varHelloWorld = artifacts.require("HelloWorld");

module.exports =function(deployer){ 

    deployer.deploy(HelloWorld);

};

搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第5张图片

用artifacts.require语句来取得准备部署的合约。使用deployer.deploy语句将合约部署到区块链上。

这边HelloWorld是contract的名称而不是文件名。

因此可以用此语法读入任一.sol文件中的任一合约。

现在执行truffle migrate(第三条命令)命令:

小插曲:


搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第6张图片

在使用truffle migrate进行智能合约test环境发布时如果未配置正确会出现以下异常:

导致上面异常的原因为是因为truffle.js里面未配置链接合约发布的环境地址,找到对应的truffle.js文件,修改代码为类似如下配置即可解决问题:

搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第7张图片

修改后,继续运行

搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第8张图片

合约已经部署到testrpc中。切换到testrpc窗口,可以看到testrpc有反应了。


搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第9张图片

与合约互动

truffle提供命令行工具,执行truffle console命令后,可用Javascript来和部署的合约互动。

HelloWorld.deployed().then(instance => contract = instance)

truffle console中预载了truffle-contract函数库,以方便操作部署到区块链上的合约。

这边使用HelloWorld.deployed().then语句来取得HelloWorld合约的Instance(实例),并存到contract变量中,以方便后续的调用


搭建智能合约测试环境、开发、编译、部署以及JS调用合约_第10张图片

contract.sayHello.call()

truffle-contract提供使用call()来读取只读(read only)的数据,这样就不需提供gas。因此如果遇到的操作需要向区块链写入数据,我们就不能用call语句了。

如此一来,我们已写好并部署完成了第一个智能合约,也验证了合约确实可以运作。

你可能感兴趣的:(搭建智能合约测试环境、开发、编译、部署以及JS调用合约)