2018-07-23 17:45:01 +10:00
|
|
|
const { describe, it, beforeEach } = require('mocha')
|
2018-06-25 16:25:12 +10:00
|
|
|
const assert = require('assert')
|
2018-12-27 17:49:53 +09:00
|
|
|
const Block = require('..').Block
|
2014-10-16 15:30:57 +11:00
|
|
|
|
2018-06-25 16:25:12 +10:00
|
|
|
const fixtures = require('./fixtures/block')
|
2014-10-16 15:30:57 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('Block', () => {
|
|
|
|
describe('version', () => {
|
|
|
|
it('should be interpreted as an int32le', () => {
|
2018-06-25 16:37:45 +10:00
|
|
|
const blockHex = 'ffffffff0000000000000000000000000000000000000000000000000000000000000000414141414141414141414141414141414141414141414141414141414141414101000000020000000300000000'
|
|
|
|
const block = Block.fromHex(blockHex)
|
2019-04-09 15:09:50 +09:00
|
|
|
assert.strictEqual(-1, block.version)
|
|
|
|
assert.strictEqual(1, block.timestamp)
|
2016-10-12 16:04:03 +02:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('calculateTarget', () => {
|
|
|
|
fixtures.targets.forEach(f => {
|
|
|
|
it('returns ' + f.expected + ' for 0x' + f.bits, () => {
|
2018-06-25 16:37:45 +10:00
|
|
|
const bits = parseInt(f.bits, 16)
|
2015-12-09 13:35:29 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
assert.strictEqual(Block.calculateTarget(bits).toString('hex'), f.expected)
|
2015-12-09 13:35:29 +11:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('fromBuffer/fromHex', () => {
|
|
|
|
fixtures.valid.forEach(f => {
|
|
|
|
it('imports ' + f.description, () => {
|
2018-06-25 16:37:45 +10:00
|
|
|
const block = Block.fromHex(f.hex)
|
2014-10-16 15:30:57 +11:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(block.version, f.version)
|
|
|
|
assert.strictEqual(block.prevHash.toString('hex'), f.prevHash)
|
|
|
|
assert.strictEqual(block.merkleRoot.toString('hex'), f.merkleRoot)
|
2018-12-27 18:26:08 +09:00
|
|
|
if (block.witnessCommit) {
|
|
|
|
assert.strictEqual(block.witnessCommit.toString('hex'), f.witnessCommit)
|
|
|
|
}
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(block.timestamp, f.timestamp)
|
|
|
|
assert.strictEqual(block.bits, f.bits)
|
|
|
|
assert.strictEqual(block.nonce, f.nonce)
|
2017-04-18 11:52:11 +10:00
|
|
|
assert.strictEqual(!block.transactions, f.hex.length === 160)
|
2014-10-16 15:30:57 +11:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
fixtures.invalid.forEach(f => {
|
|
|
|
it('throws on ' + f.exception, () => {
|
|
|
|
assert.throws(() => {
|
2014-10-16 15:30:57 +11:00
|
|
|
Block.fromHex(f.hex)
|
|
|
|
}, new RegExp(f.exception))
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('toBuffer/toHex', () => {
|
|
|
|
fixtures.valid.forEach(f => {
|
2018-06-25 16:37:45 +10:00
|
|
|
let block
|
2014-10-16 15:30:57 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
beforeEach(() => {
|
2014-10-16 15:30:57 +11:00
|
|
|
block = Block.fromHex(f.hex)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
it('exports ' + f.description, () => {
|
2017-04-18 11:56:35 +10:00
|
|
|
assert.strictEqual(block.toHex(true), f.hex.slice(0, 160))
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(block.toHex(), f.hex)
|
2014-10-16 15:30:57 +11:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('getHash/getId', () => {
|
|
|
|
fixtures.valid.forEach(f => {
|
2018-06-25 16:37:45 +10:00
|
|
|
let block
|
2014-10-16 15:30:57 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
beforeEach(() => {
|
2014-10-16 15:30:57 +11:00
|
|
|
block = Block.fromHex(f.hex)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
it('returns ' + f.id + ' for ' + f.description, () => {
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(block.getHash().toString('hex'), f.hash)
|
|
|
|
assert.strictEqual(block.getId(), f.id)
|
2014-10-16 15:30:57 +11:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-10-29 12:12:12 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('getUTCDate', () => {
|
|
|
|
fixtures.valid.forEach(f => {
|
2018-06-25 16:37:45 +10:00
|
|
|
let block
|
2014-10-29 12:12:12 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
beforeEach(() => {
|
2014-10-29 12:12:12 +11:00
|
|
|
block = Block.fromHex(f.hex)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
it('returns UTC date of ' + f.id, () => {
|
2018-06-25 16:37:45 +10:00
|
|
|
const utcDate = block.getUTCDate().getTime()
|
2014-10-29 12:12:12 +11:00
|
|
|
|
2015-05-07 11:29:20 +10:00
|
|
|
assert.strictEqual(utcDate, f.timestamp * 1e3)
|
2014-10-29 12:12:12 +11:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2015-12-08 18:51:35 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('calculateMerkleRoot', () => {
|
|
|
|
it('should throw on zero-length transaction array', () => {
|
|
|
|
assert.throws(() => {
|
2016-05-05 00:42:05 +10:00
|
|
|
Block.calculateMerkleRoot([])
|
|
|
|
}, /Cannot compute merkle root for zero transactions/)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
fixtures.valid.forEach(f => {
|
2016-05-05 00:42:05 +10:00
|
|
|
if (f.hex.length === 160) return
|
|
|
|
|
2018-06-25 16:37:45 +10:00
|
|
|
let block
|
2016-05-05 00:42:05 +10:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
beforeEach(() => {
|
2016-05-05 00:42:05 +10:00
|
|
|
block = Block.fromHex(f.hex)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
it('returns ' + f.merkleRoot + ' for ' + f.id, () => {
|
2016-05-05 00:42:05 +10:00
|
|
|
assert.strictEqual(Block.calculateMerkleRoot(block.transactions).toString('hex'), f.merkleRoot)
|
|
|
|
})
|
2018-12-27 18:26:08 +09:00
|
|
|
|
|
|
|
if (f.witnessCommit) {
|
2019-04-09 15:09:50 +09:00
|
|
|
it('returns witness commit ' + f.witnessCommit + ' for ' + f.id, () => {
|
2018-12-27 18:26:08 +09:00
|
|
|
assert.strictEqual(Block.calculateMerkleRoot(block.transactions, true).toString('hex'), f.witnessCommit)
|
|
|
|
})
|
|
|
|
}
|
2016-05-05 00:42:05 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('checkTxRoots', () => {
|
|
|
|
fixtures.valid.forEach(f => {
|
2016-05-05 00:42:05 +10:00
|
|
|
if (f.hex.length === 160) return
|
|
|
|
|
2018-06-25 16:37:45 +10:00
|
|
|
let block
|
2016-05-05 00:42:05 +10:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
beforeEach(() => {
|
2016-05-05 00:42:05 +10:00
|
|
|
block = Block.fromHex(f.hex)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
it('returns ' + f.valid + ' for ' + f.id, () => {
|
2019-01-17 17:01:15 +09:00
|
|
|
assert.strictEqual(block.checkTxRoots(), true)
|
2016-05-05 00:42:05 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
describe('checkProofOfWork', () => {
|
|
|
|
fixtures.valid.forEach(f => {
|
2018-06-25 16:37:45 +10:00
|
|
|
let block
|
2015-12-08 18:51:35 +11:00
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
beforeEach(() => {
|
2015-12-08 18:51:35 +11:00
|
|
|
block = Block.fromHex(f.hex)
|
|
|
|
})
|
|
|
|
|
2019-04-09 15:09:50 +09:00
|
|
|
it('returns ' + f.valid + ' for ' + f.id, () => {
|
2016-01-04 12:49:28 +11:00
|
|
|
assert.strictEqual(block.checkProofOfWork(), f.valid)
|
2015-12-08 18:51:35 +11:00
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
2014-10-16 15:30:57 +11:00
|
|
|
})
|