mirror of
				https://github.com/Xahau/xahau.js.git
				synced 2025-11-04 04:55:48 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
const { ShaMap } = require('../src/shamap')
 | 
						|
const { binary, HashPrefix } = require('../src/coretypes')
 | 
						|
const { coreTypes } = require('../src/types')
 | 
						|
const { loadFixture } = require('./utils')
 | 
						|
const { Buffer } = require('buffer/')
 | 
						|
 | 
						|
function now() {
 | 
						|
  return Number(Date.now()) / 1000
 | 
						|
}
 | 
						|
 | 
						|
const ZERO = '0000000000000000000000000000000000000000000000000000000000000000'
 | 
						|
 | 
						|
function makeItem(indexArg) {
 | 
						|
  let str = indexArg
 | 
						|
  while (str.length < 64) {
 | 
						|
    str += '0'
 | 
						|
  }
 | 
						|
  const index = coreTypes.Hash256.from(str)
 | 
						|
  const item = {
 | 
						|
    toBytesSink(sink) {
 | 
						|
      index.toBytesSink(sink)
 | 
						|
    },
 | 
						|
    hashPrefix() {
 | 
						|
      return Buffer.from([1, 3, 3, 7])
 | 
						|
    },
 | 
						|
  }
 | 
						|
  return [index, item]
 | 
						|
}
 | 
						|
 | 
						|
describe('ShaMap', () => {
 | 
						|
  now()
 | 
						|
 | 
						|
  test('hashes to zero when empty', () => {
 | 
						|
    const map = new ShaMap()
 | 
						|
    expect(map.hash().toHex()).toBe(ZERO)
 | 
						|
  })
 | 
						|
  test('creates the same hash no matter which order items are added', () => {
 | 
						|
    let map = new ShaMap()
 | 
						|
    const items = [
 | 
						|
      '0',
 | 
						|
      '1',
 | 
						|
      '11',
 | 
						|
      '7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E20000000000000000',
 | 
						|
      '7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E21000000000000000',
 | 
						|
      '7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E22000000000000000',
 | 
						|
      '7000DE445E22CB9BB7E1717589FA858736BAA5FD192310E23000000000000000',
 | 
						|
      '12',
 | 
						|
      '122',
 | 
						|
    ]
 | 
						|
    items.forEach((i) => map.addItem(...makeItem(i)))
 | 
						|
    const h1 = map.hash()
 | 
						|
    expect(h1.eq(h1)).toBe(true)
 | 
						|
    map = new ShaMap()
 | 
						|
    items.reverse().forEach((i) => map.addItem(...makeItem(i)))
 | 
						|
    expect(map.hash()).toStrictEqual(h1)
 | 
						|
  })
 | 
						|
  function factory(fixture) {
 | 
						|
    test(`recreate account state hash from ${fixture}`, () => {
 | 
						|
      const map = new ShaMap()
 | 
						|
      const ledger = loadFixture(fixture)
 | 
						|
      // const t = now();
 | 
						|
      const leafNodePrefix = HashPrefix.accountStateEntry
 | 
						|
      ledger.accountState
 | 
						|
        .map((e, i) => {
 | 
						|
          if ((i > 1000) & (i % 1000 === 0)) {
 | 
						|
            console.log(e.index)
 | 
						|
            console.log(i)
 | 
						|
          }
 | 
						|
          const bytes = binary.serializeObject(e)
 | 
						|
          return {
 | 
						|
            index: coreTypes.Hash256.from(e.index),
 | 
						|
            hashPrefix() {
 | 
						|
              return leafNodePrefix
 | 
						|
            },
 | 
						|
            toBytesSink(sink) {
 | 
						|
              sink.put(bytes)
 | 
						|
            },
 | 
						|
          }
 | 
						|
        })
 | 
						|
        .forEach((so) => map.addItem(so.index, so))
 | 
						|
      expect(map.hash().toHex()).toBe(ledger.account_hash)
 | 
						|
      // console.log('took seconds: ', (now() - t));
 | 
						|
    })
 | 
						|
  }
 | 
						|
  factory('ledger-full-38129.json')
 | 
						|
  factory('ledger-full-40000.json')
 | 
						|
  // factory('ledger-4320277.json');
 | 
						|
  // factory('14280680.json');
 | 
						|
})
 |