之前可以先了解一下另一个模块,看本博客的ethereumjs/ethereumjs-common部分内容

通过tests测试文件能够帮助更好了解API的使用

ethereumjs-block/tests/header.js

const tape = require('tape')
const Common = require('ethereumjs-common')
const utils = require('ethereumjs-util')
const rlp = utils.rlp
const Header = require('../header.js')
const Block = require('../index.js') tape('[Block]: Header functions', function (t) {
t.test('should create with default constructor', function (st) {
function compareDefaultHeader (st, header) {
st.deepEqual(header.parentHash, utils.zeros())
st.equal(header.uncleHash.toString('hex'), utils.SHA3_RLP_ARRAY_S)
st.deepEqual(header.coinbase, utils.zeros())
st.deepEqual(header.stateRoot, utils.zeros())
st.equal(header.transactionsTrie.toString('hex'), utils.SHA3_RLP_S)
st.equal(header.receiptTrie.toString('hex'), utils.SHA3_RLP_S)
st.deepEqual(header.bloom, utils.zeros())
st.deepEqual(header.difficulty, Buffer.from([]))
st.deepEqual(header.number, utils.intToBuffer())
st.deepEqual(header.gasLimit, Buffer.from('ffffffffffffff', 'hex'))
st.deepEqual(header.gasUsed, Buffer.from([]))
st.deepEqual(header.timestamp, Buffer.from([]))
st.deepEqual(header.extraData, Buffer.from([]))
st.deepEqual(header.mixHash, utils.zeros())
st.deepEqual(header.nonce, utils.zeros())
} var header = new Header()
compareDefaultHeader(st, header) var block = new Block()
header = block.header
compareDefaultHeader(st, header) st.end()
}) t.test('should test header initialization', function (st) {
const header1 = new Header(null, { 'chain': 'ropsten' }) //初始化,一种是提供chain/hardfork
const common = new Common('ropsten')
const header2 = new Header(null, { 'common': common })//另一种则是使用common,common和chain不能同时提供,会报错
header1.setGenesisParams()//就是将该区块头设置为规范初始区块头
header2.setGenesisParams()
st.strictEqual(header1.hash().toString('hex'), header2.hash().toString('hex'), 'header hashes match')//因为两个都设置为规范初始区块头,所以相应的值是相同的 st.throws(function () { new Header(null, { 'chain': 'ropsten', 'common': common }) }, /not allowed!$/, 'should throw on initialization with chain and common parameter') // eslint-disable-line
st.end()
}) t.test('should test validateGasLimit', function (st) {//对gasLimit进行验证
const testData = require('./bcBlockGasLimitTest.json').tests
const bcBlockGasLimigTestData = testData.BlockGasLimit2p63m1 Object.keys(bcBlockGasLimigTestData).forEach(key => {
var parentBlock = new Block(rlp.decode(bcBlockGasLimigTestData[key].genesisRLP)) //使用genesisRLP初始化block得到的是父区块
var block = new Block(rlp.decode(bcBlockGasLimigTestData[key].blocks[].rlp)) //使用blocks[0].rlp初始化block得到的是本区块
st.equal(block.header.validateGasLimit(parentBlock), true)
}) st.end()
}) t.test('should test isGenesis', function (st) {
var header = new Header() //查看该区块头是否为初始区块
st.equal(header.isGenesis(), false)
header.number = Buffer.from([]) //通过设置header.number为空buffer数组就能得到是初始区块的结果
st.equal(header.isGenesis(), true)
st.end()
}) const testDataGenesis = require('./genesishashestest.json').test
t.test('should test genesis hashes (mainnet default)', function (st) {
var header = new Header()
header.setGenesisParams()
st.strictEqual(header.hash().toString('hex'), testDataGenesis.genesis_hash, 'genesis hash match')
st.end()
}) t.test('should test genesis parameters (ropsten)', function (st) {
var genesisHeader = new Header(null, { 'chain': 'ropsten' })
genesisHeader.setGenesisParams()
let ropstenStateRoot = '217b0bbcfb72e2d57e28f33cb361b9983513177755dc3f33ce3e7022ed62b77b'
st.strictEqual(genesisHeader.stateRoot.toString('hex'), ropstenStateRoot, 'genesis stateRoot match')
st.end()
})
})

ethereumjs-block/tests/block.js

const tape = require('tape')
const Common = require('ethereumjs-common')
const rlp = require('ethereumjs-util').rlp
const Block = require('../index.js') tape('[Block]: block functions', function (t) {
t.test('should test block initialization', function (st) {
const block1 = new Block(null, { 'chain': 'ropsten' }) //初始化,一种是提供chain/hardfork
const common = new Common('ropsten')
const block2 = new Block(null, { 'common': common })//另一种则是使用common,common和chain不能同时提供,会报错
block1.setGenesisParams()//就是将该区块设置为规范初始区块
block2.setGenesisParams()
st.strictEqual(block1.hash().toString('hex'), block2.hash().toString('hex'), 'block hashes match')//因为两个都设置为规范初始区块,所以相应的值是相同的 st.throws(function () { new Block(null, { 'chain': 'ropsten', 'common': common }) }, /not allowed!$/, 'should throw on initialization with chain and common parameter') // eslint-disable-line
st.end()
}) const testData = require('./testdata.json') function testTransactionValidation (st, block) {
st.equal(block.validateTransactions(), true) //验证区块中的交易 block.genTxTrie(function () {//必须要先生成了前缀树后才能调用验证前缀树的操作
st.equal(block.validateTransactionsTrie(), true)
st.end()
})
} t.test('should test transaction validation', function (st) {
var block = new Block(rlp.decode(testData.blocks[].rlp))
st.plan()
testTransactionValidation(st, block)
}) t.test('should test transaction validation with empty transaction list', function (st) {
var block = new Block()
st.plan()
testTransactionValidation(st, block)
}) const testData2 = require('./testdata2.json')
t.test('should test uncles hash validation', function (st) {
var block = new Block(rlp.decode(testData2.blocks[].rlp))//从区块信息文件生成相同区块
st.equal(block.validateUnclesHash(), true)//验证该区块的叔块hash
st.end()
}) t.test('should test isGenesis (mainnet default)', function (st) {
var block = new Block()
st.notEqual(block.isGenesis(), true) //查看是否为初始区块,为false
block.header.number = Buffer.from([])//决定因素是block.header.number,设置为空数组buffer即可
st.equal(block.isGenesis(), true)
st.end()
}) t.test('should test isGenesis (ropsten)', function (st) {
var block = new Block(null, { 'chain': 'ropsten' })
st.notEqual(block.isGenesis(), true)
block.header.number = Buffer.from([])
st.equal(block.isGenesis(), true)
st.end()
}) const testDataGenesis = require('./genesishashestest.json').test//(初始区块信息)
t.test('should test genesis hashes (mainnet default)', function (st) {
var genesisBlock = new Block()
genesisBlock.setGenesisParams()//设置为初始区块
var rlp = genesisBlock.serialize() //序列化,就是将其生产rlp格式
st.strictEqual(rlp.toString('hex'), testDataGenesis.genesis_rlp_hex, 'rlp hex match')
st.strictEqual(genesisBlock.hash().toString('hex'), testDataGenesis.genesis_hash, 'genesis hash match')
st.end()
}) t.test('should test genesis hashes (ropsten)', function (st) {
var common = new Common('ropsten')
var genesisBlock = new Block(null, { common: common })
genesisBlock.setGenesisParams()
st.strictEqual(genesisBlock.hash().toString('hex'), common.genesis().hash.slice(), 'genesis hash match')
st.end()
}) t.test('should test genesis hashes (rinkeby)', function (st) {
var common = new Common('rinkeby')
var genesisBlock = new Block(null, { common: common })
genesisBlock.setGenesisParams()
st.strictEqual(genesisBlock.hash().toString('hex'), common.genesis().hash.slice(), 'genesis hash match')
st.end()
}) t.test('should test genesis parameters (ropsten)', function (st) {
var genesisBlock = new Block(null, { 'chain': 'ropsten' })
genesisBlock.setGenesisParams()
let ropstenStateRoot = '217b0bbcfb72e2d57e28f33cb361b9983513177755dc3f33ce3e7022ed62b77b'
st.strictEqual(genesisBlock.header.stateRoot.toString('hex'), ropstenStateRoot, 'genesis stateRoot match')
st.end()
}) t.test('should test toJSON', function (st) {
var block = new Block(rlp.decode(testData2.blocks[].rlp))
st.equal(typeof (block.toJSON()), 'object') //返回值为object类型
st.equal(typeof (block.toJSON(true)), 'object')
st.end()
})
})

ethereumjs-block/tests/difficulty.js

const utils = require('ethereumjs-util')
const tape = require('tape')
const Block = require('../')
const BN = utils.BN function normalize (data) {
Object.keys(data).map(function (i) {
if (i !== 'homestead' && typeof (data[i]) === 'string') {
data[i] = utils.isHexPrefixed(data[i]) ? new BN(utils.toBuffer(data[i])) : new BN(data[i])
}
})
} tape('[Header]: difficulty tests', t => {
function runDifficultyTests (test, parentBlock, block, msg) {
normalize(test) var dif = block.header.canonicalDifficulty(parentBlock)//返回区块的规范困难度
t.equal(dif.toString(), test.currentDifficulty.toString(), `test canonicalDifficulty (${msg})`) //从父区块得到的规范困难度与当前区块的困难度应该是相等的
t.assert(block.header.validateDifficulty(parentBlock), `test validateDifficulty (${msg})`) //查看区块头是否符合规范困难度的区块困难度
} const hardforkTestData = {
'chainstart': require('./difficultyFrontier.json').tests,
'homestead': require('./difficultyHomestead.json').tests,
'byzantium': require('./difficultyByzantium.json').tests,
'constantinople': require('./difficultyConstantinople.json').tests
}
for (let hardfork in hardforkTestData) {
const testData = hardforkTestData[hardfork]
for (let testName in testData) {
let test = testData[testName]
let parentBlock = new Block(null, { 'chain': 'mainnet', 'hardfork': hardfork })
parentBlock.header.timestamp = test.parentTimestamp
parentBlock.header.difficulty = test.parentDifficulty
parentBlock.header.uncleHash = test.parentUncles let block = new Block(null, { 'chain': 'mainnet', 'hardfork': hardfork })
block.header.timestamp = test.currentTimestamp
block.header.difficulty = test.currentDifficulty
block.header.number = test.currentBlockNumber runDifficultyTests(test, parentBlock, block, 'fork determination by hardfork param')
}
} const chainTestData = {
'mainnet': require('./difficultyMainNetwork.json').tests,
'ropsten': require('./difficultyRopstenByzantium.json').tests
}
for (let chain in chainTestData) {
const testData = chainTestData[chain]
for (let testName in testData) {
let test = testData[testName]
let parentBlock = new Block(null, { 'chain': chain })
parentBlock.header.timestamp = test.parentTimestamp
parentBlock.header.difficulty = test.parentDifficulty
parentBlock.header.uncleHash = test.parentUncles let block = new Block(null, { 'chain': chain })
block.header.timestamp = test.currentTimestamp
block.header.difficulty = test.currentDifficulty
block.header.number = test.currentBlockNumber runDifficultyTests(test, parentBlock, block, 'fork determination by block number')
}
} t.end()

ethereumjs/ethereumjs-block-3-tests的更多相关文章

  1. ethereumjs/ethereumjs-block-1-简介

    https://github.com/ethereumjs/ethereumjs-block Encoding, decoding and validation of Ethereum's Block ...

  2. NGINX Load Balancing – TCP and UDP Load Balancer

    This chapter describes how to use NGINX Plus and open source NGINX to proxy and load balance TCP and ...

  3. CSS动画划入划出酷炫

    HTML插入 <!DOCTYPE html> <html class="no-js iarouse"> <head> <meta char ...

  4. ethereumjs/ethereumjs-vm-4-tests

    根据代码发现还要了解的模块有: ethereumjs/merkle-patricia-tree -对应数据存储的数据结构 ethereumjs-blockchain —— 区块链 ethereumjs ...

  5. ethereumjs/ethereumjs-block-2-api

    https://github.com/ethereumjs/ethereumjs-block/blob/master/docs/index.md 详细的调用代码可见本博客的ethereumjs/eth ...

  6. ethereumjs/ethereumjs-blockchain-2-test

    https://github.com/ethereumjs/ethereumjs-blockchain/tree/master/test 'use strict' const test = requi ...

  7. ethereumjs/ethereumjs-blockchain-1-简介和API

    https://github.com/ethereumjs/ethereumjs-blockchain SYNOPSIS概要 A module to store and interact with b ...

  8. ethereumjs/ethereumjs-wallet

    Utilities for handling Ethereum keys ethereumjs-wallet A lightweight wallet implementation. At the m ...

  9. ethereumjs/ethereumjs-common-1-简介

    为了了解ethereumjs/ethereumjs-block-3-代码的使用需要了解的一个模块 https://github.com/ethereumjs/ethereumjs-common Com ...

随机推荐

  1. src/main/resources文件夹

    Error starting ApplicationContext. To display the auto-configuration report re-run your application ...

  2. java队列queue的我觉得很好的使用方式

    LinkedList实现了queue接口,通常使用LinkedList 其中关键两个函数:offer().poll() offer()表示“排队”----插入到队列最前,poll()表示轮到了队列最前 ...

  3. HTML5拖拽/拖放(drag & drop)详解

    H5中拖拽属性: draggable: auto | true | false   拖动事件:   - dragstart 在元素开始被拖动时触发 - dragend 在拖动操作完成时触发 - dra ...

  4. idea 常用快捷键 笔记

    1. main方法 输入psv tab或回车 类似的 psf fori (for循环) sout 备注:  通过ctrl+j 可以查询 2. 删除当前行 ctrl + y 3. 复制当前行 ctrl ...

  5. 再谈javascript函数节流

    之前写过但是不记得在哪了,今天同事要一个滑到页面底部加载更多内容的效果,又想起了这玩意儿,确实挺实用和常用的,谨此记之. 函数节流从字面上的意思就是节约函数的执行次数,其实现的主要思想是通过定时器阻断 ...

  6. 001Spring Boot中使用MongoDB

    01.下载MongoDB 点击标题链接,下载windows可用的MongoDB. 02.解压 将下载的压缩包放入C盘根目录(根据自己需要调整目录)---->解压到当前文件夹---->重命名 ...

  7. MvcForum作者称该项目进入缓慢更新

    MvcForum作者在github上发表 This project is no longer actively developed as I don't have the time. As and w ...

  8. hololens DEP2220: 无法删除目标计算机“127.0.0.1”上的文件夹

    Hololens开发调试的过程中,可能会出现 “DEP2220: 无法删除目标计算机“127.0.0.1”上的文件夹“ 的错误导致无法部署,解决办法是进入项目属性页——调试——启动选项,勾选“卸载并重 ...

  9. html5 移动端开发

    移动端开发总结     目录 1.手机与浏览器 2.Viewport(视窗) 3. 媒体查询 4.px,em,rem,pt 5.设备像素比devicePixelRatio 6.移动web中的图标及字体 ...

  10. 由Dialog里面嵌套ListView之后的高度自适应引起的ListView性能优化

    先说ListView给高的正确做法. android:layout_height属性: 必须将ListView的布局高度属性设置为非"wrap_content"(可以是" ...