123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- import { assert } from 'chai'
- import { toBufferKey, fromBufferKey, readKey, writeKey } from '../index.js'
- function assertBufferComparison(lesser, greater) {
- for (let i = 0; i < lesser.length; i++) {
- if (lesser[i] < greater[i]) {
- return
- }
- if (lesser[i] > (greater[i] || 0)) {
- assert.fail('Byte ' + i + 'should not be ' + lesser[i] + '>' + greater[i])
- }
- }
- }
- //var inspector = require('inspector'); inspector.open(9330, null, true); debugger
- let seed = 0;
- export function random() {
- seed++;
- let a = seed * 15485863;
- return ((a * a * a) % 2038074743) / 2038074743;
- }
- suite('key buffers', () => {
- test('numbers equivalence', () => {
- assert.strictEqual(fromBufferKey(toBufferKey(4)), 4)
- assert.strictEqual(fromBufferKey(toBufferKey(-4)), -4)
- assert.strictEqual(fromBufferKey(toBufferKey(3.4)), 3.4)
- assert.strictEqual(fromBufferKey(toBufferKey(Math.PI)), Math.PI)
- assert.strictEqual(fromBufferKey(toBufferKey(2002225)), 2002225)
- assert.strictEqual(fromBufferKey(toBufferKey(9377288)), 9377288)
- assert.strictEqual(fromBufferKey(toBufferKey(1503579323825)), 1503579323825)
- assert.strictEqual(fromBufferKey(toBufferKey(1503579323825.3523532)), 1503579323825.3523532)
- assert.strictEqual(fromBufferKey(toBufferKey(-1503579323825)), -1503579323825)
- assert.strictEqual(fromBufferKey(toBufferKey(0.00005032)), 0.00005032)
- assert.strictEqual(fromBufferKey(toBufferKey(-0.00005032)), -0.00005032)
- assert.strictEqual(fromBufferKey(toBufferKey(0.00000000000000000000000005431)), 0.00000000000000000000000005431)
- })
- test('within buffer equivalence', () => {
- let buffer = Buffer.alloc(1024, 0xff);
- let length = writeKey(2002225, buffer, 0);
- let position = length;
- buffer[position++] = 0xff;
- buffer[position++] = 0xff;
- assert.strictEqual(readKey(buffer, 0, length), 2002225);
- length = writeKey('hello, world', buffer, 0);
- assert.strictEqual(readKey(buffer, 0, length), 'hello, world');
- // ensure that reading the string didn't modify the buffer after the string (or is restored at least)
- assert.strictEqual(buffer[length], 0xff);
- });
- test('number comparison', () => {
- assertBufferComparison(toBufferKey(4), toBufferKey(5))
- assertBufferComparison(toBufferKey(1503579323824), toBufferKey(1503579323825))
- assertBufferComparison(toBufferKey(1.4), toBufferKey(2))
- assertBufferComparison(toBufferKey(0.000000001), toBufferKey(0.00000001))
- assertBufferComparison(toBufferKey(-4), toBufferKey(3))
- assertBufferComparison(toBufferKey(0), toBufferKey(1))
- assertBufferComparison(toBufferKey(-0.001), toBufferKey(0))
- assertBufferComparison(toBufferKey(-0.001), toBufferKey(-0.000001))
- assertBufferComparison(toBufferKey(-5236532532532), toBufferKey(-5236532532531))
- })
- test('bigint equivalence', () => {
- assert.strictEqual(fromBufferKey(toBufferKey(-35913040084491349n)), -35913040084491349n)
- assert.strictEqual(fromBufferKey(toBufferKey(6135421331404949076605986n)), 6135421331404949076605986n)
- assert.strictEqual(fromBufferKey(toBufferKey(0xfffffffffffffffffffffn)), 0xfffffffffffffffffffffn)
- assert.strictEqual(fromBufferKey(toBufferKey(12345678901234567890n)), 12345678901234567890n)
- assert.deepEqual(fromBufferKey(toBufferKey([12345678901234567890n, 44])), [12345678901234567890n, 44])
- assert.deepEqual(fromBufferKey(toBufferKey(['hi', 12345678901234567890n])), ['hi', 12345678901234567890n])
- assert.deepEqual(fromBufferKey(toBufferKey([6135421331404949076605986n, 'after'])), [6135421331404949076605986n, 'after'])
- assert.strictEqual(fromBufferKey(toBufferKey(132923456789012345678903533235253252353211125n)), 132923456789012345678903533235253252353211125n)
- assert.strictEqual(fromBufferKey(toBufferKey(352n)), 352)
- let num = 5325n
- for (let i = 0; i < 1100; i++) {
- num *= BigInt(Math.floor(random() * 3 + 1));
- num -= BigInt(Math.floor(random() * 1000));
- assert.strictEqual(BigInt(fromBufferKey(toBufferKey(num))), num)
- assert.strictEqual(BigInt(fromBufferKey(toBufferKey(-num))), -num)
- }
- assert.strictEqual(fromBufferKey(toBufferKey(-352n)), -352)
- })
- test('bigint comparison', () => {
- assertBufferComparison(toBufferKey(0xfffffffffffffffffffffn), toBufferKey(0x100fffffffffffffffffffn))
- assertBufferComparison(toBufferKey(12345678901234567890), toBufferKey(12345678901234567890n))
- assertBufferComparison(toBufferKey(6135421331404949076605986n), toBufferKey(6135421331404949076605987n))
- assertBufferComparison(toBufferKey(-6135421331404949076605986n), toBufferKey(-6135421331404949076605985n))
- assertBufferComparison(toBufferKey(-35913040084491349n), toBufferKey(-35913040084491348n))
- })
- test('string equivalence', () => {
- assert.strictEqual(fromBufferKey(toBufferKey('4')), '4')
- assert.strictEqual(fromBufferKey(toBufferKey('hello')), 'hello')
- assert.strictEqual(fromBufferKey(toBufferKey('')), '')
- assert.strictEqual(fromBufferKey(toBufferKey('\x00')), '\x00')
- assert.strictEqual(fromBufferKey(toBufferKey('\x03test\x01\x00')), '\x03test\x01\x00')
- assert.strictEqual(fromBufferKey(toBufferKey('prance 🧚🏻♀️🩷')), 'prance 🧚🏻♀️🩷')
- })
- test('string comparison', () => {
- assertBufferComparison(toBufferKey('4'), toBufferKey('5'))
- assertBufferComparison(toBufferKey('and'), toBufferKey('bad'))
- assertBufferComparison(toBufferKey('hello'), toBufferKey('hello2'))
- let buffer = Buffer.alloc(1024)
- let end = writeKey(['this is a test', 5.25], buffer, 0)
- })
- test('boolean equivalence', () => {
- assert.strictEqual(fromBufferKey(toBufferKey(true)), true)
- assert.strictEqual(fromBufferKey(toBufferKey(false)), false)
- })
- test('multipart equivalence', () => {
- assert.deepEqual(fromBufferKey(toBufferKey([4, 5])),
- [4, 5])
- assert.deepEqual(fromBufferKey(toBufferKey(['hello', 5.25])),
- ['hello', 5.25])
- assert.deepEqual(fromBufferKey(toBufferKey([true, 1503579323825])),
- [true, 1503579323825])
- assert.deepEqual(fromBufferKey(toBufferKey([-0.2525, 'sec\x00nd'])),
- [-0.2525, 'sec\x00nd'])
- assert.deepEqual(fromBufferKey(toBufferKey([-0.2525, '2nd', '3rd'])),
- [-0.2525, '2nd', '3rd'])
- })
- test('multipart comparison', () => {
- assertBufferComparison(
- Buffer.concat([toBufferKey(4), Buffer.from([30]), toBufferKey(5)]),
- Buffer.concat([toBufferKey(5), Buffer.from([30]), toBufferKey(5)]))
- assertBufferComparison(
- Buffer.concat([toBufferKey(4), Buffer.from([30]), toBufferKey(5)]),
- Buffer.concat([toBufferKey(4), Buffer.from([30]), toBufferKey(6)]))
- assertBufferComparison(
- Buffer.concat([toBufferKey('and'), Buffer.from([30]), toBufferKey(5)]),
- Buffer.concat([toBufferKey('and2'), Buffer.from([30]), toBufferKey(5)]))
- assertBufferComparison(
- Buffer.concat([toBufferKey(4), Buffer.from([30]), toBufferKey('and')]),
- Buffer.concat([toBufferKey(4), Buffer.from([30]), toBufferKey('cat')]))
- })
- test('performance', () => {
- let buffer = Buffer.alloc(1024)
- let start = process.hrtime.bigint()
- let end, value
- for (let i = 0; i < 1000000; i++) {
- end = writeKey('this is a test of a longer string to read and write', buffer, 0)
- }
- console.log('writeKey string time', nextTime(), end)
- for (let i = 0; i < 1000000; i++) {
- value = readKey(buffer, 0, end)
- }
- console.log('readKey string time', nextTime(), value)
- for (let i = 0; i < 1000000; i++) {
- end = writeKey(33456, buffer, 0)
- }
- console.log('writeKey number time', nextTime(), end)
- for (let i = 0; i < 1000000; i++) {
- value = readKey(buffer, 2, end)
- }
- console.log('readKey number time', nextTime(), value)
- for (let i = 0; i < 1000000; i++) {
- end = writeKey(['hello', 33456], buffer, 0)
- }
- console.log('writeKey array time', nextTime(), end, buffer.slice(0, end))
- for (let i = 0; i < 1000000; i++) {
- value = readKey(buffer, 0, end)
- }
- console.log('readKey array time', nextTime(), value)
- function nextTime() {
- let ns = process.hrtime.bigint()
- let elapsed = ns - start
- start = ns
- return Number(elapsed) / 1000000 + 'ns'
- }
- })
- })
|