Add tests

This commit is contained in:
Rodrigo Q. Saramago 2022-07-11 14:17:54 +02:00
parent 4e69875311
commit eda667cdcd
No known key found for this signature in database
GPG Key ID: 9B36B2525704A359

View File

@ -1,15 +1,15 @@
import { MerkleTree, PartialMerkleTree, TreeEdge } from '../src' import { MerkleTree, MultiProofPath, PartialMerkleTree, TreeEdge } from '../src'
import { assert, should } from 'chai' import { assert, should, expect } from 'chai'
import { createHash } from 'crypto' import { createHash } from 'crypto'
import { it } from 'mocha' import { it } from 'mocha'
import { BaseTree } from '../src/BaseTree'
import defaultHash from '../src/simpleHash'
const sha256Hash = (left, right) => createHash('sha256').update(`${left}${right}`).digest('hex') const sha256Hash = (left, right) => createHash('sha256').update(`${left}${right}`).digest('hex')
const ZERO_ELEMENT = '21663839004416932945382355908790599225266501822907911457504978515578255421292' const ZERO_ELEMENT = '21663839004416932945382355908790599225266501822907911457504978515578255421292'
describe('MerkleTree', () => { describe('MerkleTree', () => {
describe('#constructor', () => { describe('#constructor', () => {
it('should have correct zero root', () => { it('should have correct zero root', () => {
const tree = new MerkleTree(10, []) const tree = new MerkleTree(10, [])
return should().equal(tree.root, '3060353338620102847451617558650138132480') return should().equal(tree.root, '3060353338620102847451617558650138132480')
@ -207,7 +207,6 @@ describe('MerkleTree', () => {
'4986731814143931240516913804278285467648', '4986731814143931240516913804278285467648',
'1918547053077726613961101558405545328640', '1918547053077726613961101558405545328640',
'5444383861051812288142814494928935059456', '5444383861051812288142814494928935059456',
]) ])
}) })
@ -253,7 +252,6 @@ describe('MerkleTree', () => {
'4986731814143931240516913804278285467648', '4986731814143931240516913804278285467648',
'1918547053077726613961101558405545328640', '1918547053077726613961101558405545328640',
'5444383861051812288142814494928935059456', '5444383861051812288142814494928935059456',
]) ])
}) })
}) })
@ -264,6 +262,54 @@ describe('MerkleTree', () => {
}) })
}) })
describe('#multiproof', () => {
it('should return a merkle-multiproof for a range of leaves in a full tree', () => {
const leaves = [...Array(8)].map((_, i) => i + 1)
const tree = new MerkleTree(3, leaves)
assert.deepEqual(tree.multiProof([1, 2, 6]), tree.multiPath([0, 1, 5]))
})
it('should return a merkle-multiproof for a leaf', () => {
const tree = new MerkleTree(6, [1])
assert.deepEqual(tree.multiProof([1]), tree.multiPath([0]))
})
it('should return a merkle-multiproof for a range of leaves', () => {
const tree = new MerkleTree(8, [1, 2, 3, 4])
assert.deepEqual(tree.multiProof([2, 4]), tree.multiPath([1, 3]))
})
})
describe('#verifyMultiProof', () => {
it('should verify a merkle-multiproof for a range of leaves', () => {
const leaves = [...Array(16)].map((_, i) => i + 1)
const tree = new MerkleTree(4, leaves)
const expectedProof: MultiProofPath = {
pathElements: [
10,
13,
'4027992409016347597424110157229339967488',
'1344833971335891992284786489626349010944',
'811683747745882158385481808019325976576',
'770507832213726794990007789733078368256',
],
leafIndices: [2, 3, 8, 13],
pathRoot: '4813607112316126252402222488335589310464',
}
expect(
BaseTree.verifyMultiProof(
tree.root,
tree.levels,
defaultHash,
[3, 4, 9, 14],
expectedProof.pathElements,
expectedProof.leafIndices,
),
).to.be.true
})
})
describe('#getTreeEdge', () => { describe('#getTreeEdge', () => {
it('should return correct treeEdge', () => { it('should return correct treeEdge', () => {
const expectedEdge: TreeEdge = { const expectedEdge: TreeEdge = {
@ -291,6 +337,7 @@ describe('MerkleTree', () => {
should().throw(call, 'Element not found') should().throw(call, 'Element not found')
}) })
}) })
describe('#getTreeSlices', () => { describe('#getTreeSlices', () => {
let fullTree: MerkleTree let fullTree: MerkleTree
before(async () => { before(async () => {
@ -344,7 +391,6 @@ describe('MerkleTree', () => {
'4027992409016347597424110157229339967488', '4027992409016347597424110157229339967488',
'923221781152860005594997320673730232320', '923221781152860005594997320673730232320',
'752191049236692618445397735417537626112', '752191049236692618445397735417537626112',
], ],
[ [
'81822854828781486047086122479545722339328', '81822854828781486047086122479545722339328',
@ -422,7 +468,6 @@ describe('MerkleTree', () => {
dst.insert(10) dst.insert(10)
should().equal(src.root, dst.root) should().equal(src.root, dst.root)
}) })
}) })
}) })