火星链 火星链
Ctrl+D收藏火星链
首页 > NEAR > 正文

TRA:DApp:开发一条龙 测试一条虫?

作者:

时间:1900/1/1 0:00:00

2017年,这一年有点特别,许多先进的技术和新的概念集中在这一年迸发。小程序火了、新零售火了、区块链火了、人工智能火了、物联网也火了。

它们有的是首次面世,也有的是早已默默发展了很久,等待一个契机走向大众。

而这当中出现过一个让人印象深刻的小插曲:

这个回答曾经在网络上红极一时,在开怀大笑的同时也不禁发人深思:新的技术若无法落到具体的应用场景解决问题,终究还是纸上谈兵。

区块链技术更是如此。虽说目前区块链的一些技术瓶颈还有待突破,但开发者们应该积极去探索、多尝试,尤其是在应用方面。其中开发DApp就是一个很好的选择。

不得不提的是,在开发DApp时,大部分开发者都会把重心放在开发的过程中,但实际上,还有同样值得开发者们注意的重要一环:测试。

接下来,我们就以抽奖合约为例,从抽奖合约的整个测试流程代码来讲解如何对合约与接口进行测试。

做好准备,又要开始我们的干货时间了。

DappRadar计划为商业合作伙伴提供DApp商店产品:12月21日消息,DApp商店DappRadar透露,它计划将其B2C DApp商店产品扩展到商业合作伙伴,以其现有的去中心化应用程序数据和分析B2B产品以及与DApp行业主要品牌的长期合作伙伴关系为基础。此前,该公司宣布转向去中心化DApp商店模式,上周推出的原生代币RADAR支持了这一模式。

迄今为止,DappRadar已经与包括MyEtherWallet和Blockchain.com等长期合作伙伴分享其DApp排名数据。考虑到DApp行业的指数级增长,DappRadar打算在此基础上,为希望将DApp功能与完整的现成DApp商店基础架构相集成的企业提供服务。[2021/12/21 7:54:37]

测试准备

首先我们来看一下项目中,test目录中文件结构,lib目录中存放了方便测试调用的封装函数,以base命名,而test根目录的cctime文件包含了主要的测试用例。编写测试用例之前,我们先熟悉一下base文件中的函数,这些函数作为测试工具提供给测试用例调用,封装了合约和访问接口代码。1、初始化函数编写测试用例之前,需要将常用的方法抽离封装,放入base文件中,这里我们使用了supertest和chai作为主要的测试框架,大家可以在源码文件中找到测试文件中的声明。以下是初始化相关的函数:

期权衍生品交易平台Seaweed Finance:Dapp上线时间将推迟:据Seaweed Finance官方消息,为满足Seaweed Dapp链上可查数据完全可追溯,Seaweed 正在与Heco主网共同攻克全节点信息可查解决方案。Seaweed CTO Coke表示,期权交易业务作为Seaweed主营业务,需要保证链上交易数据完全可追溯,以最快速度解决当前Heco主网查询节点上限,是必要而关键的。相信在Heco主网的帮助下,该问题将在本周内得到解决。Seaweed Dapp具体上线时间将于近期在其官网公示。

Seaweed Finance 是首个基于HECO链上的期权衍生品交易平台,通过利用革命性的BSM定价模型和AMM流动性池,Seaweed旨在为DeFi生态系统建立一个强大的金融衍生平台。[2021/3/29 19:25:57]

我们看init方法中,对DApp的id进行了查询,根据应用的名称从主链动态获取当前侧链应用的ID,为后续测试接口的调用初始化DappId数据。接下来我们看一下测试常用的工具函数。2、区块等待在发起一笔交易之后,需要等待交易确认之后再执行下一步的操作,调用sleep函数进行等待,之后继续执行。这个函数在测试流程中会多次使用,因为10秒一个区块的特性,很多的操作需要在区块确认之后获得验证,不仅是写操作,读取的接口依然需要在上一次写操作之后等待区块确认才能获取到最新数据。区块等待相关函数如下所示:

动态 | 今日Dapp新增4个:据DappReview数据显示,今日Dapp新增4个。EOS Dapp活跃用户72997人,交易额9078万元(-47%);Tron Dapp活跃用户38526人,交易额6194万元(+2%);ETH Dapp活跃用户14765人,交易额2278万元(-58%)。过去24小时Dapp交易额:EOS最高的为“鲸交所”(交易额5852万元);Tron最高的为“WINk”(交易额4992万元);ETH最高的为“dYdX”(交易额485万元)。[2019/10/25]

3、账户生成与转账生成随机账户与转账接口也需要测试,我们留意到了在base文件头部定义了创世账户的地址和秘钥,创世账户可以通过asch-js中的合约接口向新生成的账户转账,随机账户有了余额就能够继续调用应用中的自定义合约,进行合约相关的功能测试。账户及转账相关的函数如下:

a.随机账户randomSecret调用randomSecret生成随机字符串作为账户秘钥,我们可以看到AschJS.crypto.getKeys函数能够将字符串格式的秘钥通过非对称加密得出一个包含公钥和私钥的秘钥对,AschJS.crypto.getAddress通过公钥算出账户的地址。randomSecret返回的是一个随机生成但被截取之后的字符串。通常情况下,Asch只支持符合BIP39规范的密钥字符,也就是我们熟悉的“助记词”格式的密码,但这里为了测试方便,直接使用随机的七位字符串,同样可以算出符合规则的公钥,也能计算出地址。当然,随机账户也支持通过指定助记词的方式获取公钥与地址。b.转账转账在DApp以类型2的合约实现,所以这里的转账就是在调用DApp内部的合约,我们可以在giveMoney函数中看到合约调用的格式。合约参数结构如下:

动态 | Dapper Labs新一轮融资筹得1120万美元:区块链游戏CryptoKitties(加密猫)背后公司的Dapper Labs在新一轮融资中筹集了1120万美元,投资者包括Andreessen Horowitz、Digital Currency Group和华纳音乐集团(Warner Music Group)。新一轮融资将用于打造Dapper Labs的新区块链Flow。到目前为止,Dapper Labs已经筹集了3920万美元。(the block)[2019/9/13]

secret为合约调用者的秘钥,String类型。

fee为合约调用手续费,bigNumber类型。

type为合约类型,Number类型,与自定义合约数据对应。

args为合约参数,Array类型。

注意:

我们看到giveMoney调用合约时请求了/transactions/unsigned接口,这个接口可以接受未签名的参数和密钥执行合约,这样做在测试环境虽然没有问题,但是在正式的生产环境中会有很大的风险,我们的私钥内容会有被网络劫持的风险,所以在调用合约时,尽可能避免通过网络传输自己的密钥,而是用本地签名的方式加密参数,然后请求/transactions/signed,这点一定要十分注意。

行情 | 过去24小时EOS Dapp活跃用户95574:据DappReview数据,今日dapp新增9个,过去24小时EOS Dapp活跃用户95574,交易额639.1万EOS/1.57万元;Tron Dapp活跃用户57692,交易额2.466亿TRX/4230万元;ETH Dapp活跃用户10196,交易额1.76万ETH/1760万元;Steem Dapp活跃用户9884,交易额18万Steem/38万元。[2019/2/19]

上面的代码通过接收签名参数调用合约的接口,这个函数发送了命名为transaction的参数,trs是用asch-js前端JavaScript工具库进行签名返回的transaction对象。我们来看一个例子:

使用AschJS.dapp.createInnerTransaction将合约参数通过秘钥secret签名之后传入submitInnerTransaction函数,完成合约调用。与上面giveMoney函数不同的是,createInnerTransaction返回的是通过秘钥签名的内容,将签名后的数据通过网络发送,这样提高了整个传输过程秘钥的安全性。我们来看签名后的transaction参数是什么样子:

与上面未签名调用转账接口的参数对比,本地签名后得出的参数中少了secret属性,多了signature属性,而这个属性把通过sha256算法得出的私钥与整个transaction参数经过哈希计算之后得出,用于后端接口对参数验证。其他的合约调用基本上都按照发布文章合约的结构组织参数,完成合约调用的封装。这样,我们就可以着手编写测试了。合约流程测试

我们现在开始以一个发布文章、用户打赏、结算抽奖和用户领奖整个应用的核心流程进行测试,相关代码如下:

首先,在测试用例before函数中初始化测试变量、DApp数据和创始账户信息作为后续测试函数的基础,然后执行获取频道列表的测试用例。我们使用awaitbase.dappApiGetAsync('/channels')请求一个API,获取到频道列表信息,并用断言库校验结果。下面我们对核心的业务流程进行测试,测试的思路如下:1)创建频道。2)初始化账户。3)在频道里创建包含抽奖模式的文章。4)模拟三个用户各打赏两笔。5)文章结算。6)获奖用户领奖。7)检查各自账户的余额。核心业务流程的代码如下:

上面的代码使用受托人创建了一个新频道,并通过频道查询接口通过交易ID获取到了频道的ID,完成了基本的测试逻辑,同时保存了channelId作为后续创建文章的数据。

注意:awaitbase.onNewBlockAsync()是在等待区块确认之后再继续执行。我们看到最初先给账户转入10500的Token,用于创建频道和更新频道的消耗。打赏文章测试代码如下:

在上面代码中,首先进行账户的初始化,生成了四个账户,一个账户负责创建文章和结算奖励,另外三个作为打赏用户。然后对创建的文章执行两次打赏,为了验证方便,新创建的账户两次打赏的总额为5个Token,创建文章的账户拥有0.2个Token,操作之后扣掉手续费保证在结算之前账户余额都是零,方便验证。另外,我们为了测试需要,将后端关于区块高度的限制暂时去掉,并设置结算区块高度为当前的高度加2,这样,在用户投票之后直接执行结算。提示:测试代码中,创建频道或文章之后,因为需要区块确认,所以我们没有办法立即获取到数据的ID,只能先拿到transactionId,待区块打包之后,再通过查询接口用tid获取实际的数据ID,再进行下一步的操作,测试文件中,会出现很多这样的处理,这也是区块特性所决定的。用户打赏测试代码如下:

上面代码中,用另外三个账户对文章进行了打赏,每个账户打赏两次不同的金额,但总额是5XCT,所以最终文章的抽奖池中,应该是15个XCT,结算结果根据15XCT的总额进行验证,然后验证文章投票额与投票者的余额是否正确,代码如下:

合约中对抽奖模式的结算规则是受托人10%,作者30%,获奖者60%,因为受托人的奖励是平均分给三个账户,所以验证不是那么方便,不过我们只要验证作者和获奖者的奖励额就能确定结算是否正确,那么最终的结果是作者获得4.5个XCT,抽奖人获得9个XCT。验证奖励测试代码如下:

最终,在根目录执行npmtest,等测试运行结束,就能看到应用测试执行的结果了。

总结

上述提及的测试代码也只是完成了核心功能验证,并没有完全覆盖到每一个合约和操作场景,如果读者感兴趣可以尝试在此基础上补充或重构,也欢迎对项目提出改进建议。

标签:RANCTITRAANSsimplyBrandUnicly CryptoPunks CollectionTRAVA价格Translatix

NEAR热门资讯
HTT:关于苹果掉签解决方式

尊敬的BIONE用户:由于BIONEAPP可能会出现掉签的情况,BIONE交易所建议您可使用TestFlight下载以保证后期正常使用.

1900/1/1 0:00:00
LIB:德国政府反对批准Facebook的Libra在欧洲发行

德国的政府已经表示反对在欧盟范围内授权Facebook即将推出的稳定币Libra发展。德国新闻周刊Spiegal9月13日报道,基督教民主联盟(CDU)议员ThomasHeilmann声称政府将.

1900/1/1 0:00:00
STO:比特币减半:你需要知道的一切

摘要:数据预测。 每10分钟创造的比特币数量每4年减少一半。这就是所谓的比特币减半。下一个减半将是比特币的第3次减半,将于2020年5月实施.

1900/1/1 0:00:00
OTC:长顺发内部信:Bit-Z品牌正式升级为BitZ

Bit-Z在中秋前夕进行了品牌升级,Bit-Z的品牌正式升级为BitZ,去掉了中间的“-”。九月恰逢Bit-Z二周年,集团CEO长顺发内部信,他提到,品牌升级不是简单的去掉“-”,而是整个品牌再.

1900/1/1 0:00:00
BTC:金色公开课| 视频 15 未来趋势展望 合规发展 机构用户 生态融合

本期讲师:徐坤OK战略副总裁中国电子学会区块链专家委员中国区块链应用研究中心理事中促会区块链分会副秘书长要点课代表已经总结,赶紧拿小本本记下吧.

1900/1/1 0:00:00
GAME:DragonEx上线 SOG/USDT 交易对

DragonEx上线SOG/USDT交易对2019-09-12亲爱的用户:DragonEx将于2019年9月16日16:00在创新区上线SOG/USDT交易对.

1900/1/1 0:00:00