UNPKG

@usecannon/ganache

Version:

A library and cli to create a local blockchain for fast Ethereum development.

164 lines (137 loc) 4.35 kB
'use strict' const isBuffer = require('is-buffer') const verifyNotFoundError = require('./util').verifyNotFoundError const isTypedArray = require('./util').isTypedArray let db exports.setUp = function (test, testCommon) { test('setUp common', testCommon.setUp) test('setUp db', function (t) { db = testCommon.factory() db.open(t.end.bind(t)) }) } exports.args = function (test, testCommon) { testCommon.promises || test('test argument-less get() throws', function (t) { t.throws( db.get.bind(db), /Error: get\(\) requires a callback argument/, 'no-arg get() throws' ) t.end() }) testCommon.promises || test('test callback-less, 1-arg, get() throws', function (t) { t.throws( db.get.bind(db, 'foo'), /Error: get\(\) requires a callback argument/, 'callback-less, 1-arg get() throws' ) t.end() }) testCommon.promises || test('test callback-less, 3-arg, get() throws', function (t) { t.throws( db.get.bind(db, 'foo', {}), /Error: get\(\) requires a callback argument/, 'callback-less, 2-arg get() throws' ) t.end() }) } exports.get = function (test, testCommon) { test('test simple get()', function (t) { db.put('foo', 'bar', function (err) { t.error(err) db.get('foo', function (err, value) { t.error(err) let result if (!testCommon.encodings) { t.isNot(typeof value, 'string', 'should not be string by default') if (isTypedArray(value)) { result = String.fromCharCode.apply(null, new Uint16Array(value)) } else { t.ok(isBuffer(value)) try { result = value.toString() } catch (e) { t.error(e, 'should not throw when converting value to a string') } } } else { result = value } t.is(result, 'bar') db.get('foo', {}, function (err, value) { // same but with {} t.error(err) let result if (!testCommon.encodings) { t.ok(typeof value !== 'string', 'should not be string by default') if (isTypedArray(value)) { result = String.fromCharCode.apply(null, new Uint16Array(value)) } else { t.ok(isBuffer(value)) try { result = value.toString() } catch (e) { t.error(e, 'should not throw when converting value to a string') } } } else { result = value } t.is(result, 'bar') db.get('foo', { asBuffer: false }, function (err, value) { t.error(err) t.ok(typeof value === 'string', 'should be string if not buffer') t.is(value, 'bar') t.end() }) }) }) }) }) test('test simultaneous get()', function (t) { db.put('hello', 'world', function (err) { t.error(err) let completed = 0 const done = function () { if (++completed === 20) t.end() } for (let i = 0; i < 10; ++i) { db.get('hello', function (err, value) { t.error(err) t.is(value.toString(), 'world') done() }) } for (let i = 0; i < 10; ++i) { db.get('not found', function (err, value) { t.ok(err, 'should error') t.ok(verifyNotFoundError(err), 'should have correct error message') t.ok(typeof value === 'undefined', 'value is undefined') done() }) } }) }) test('test get() not found error is asynchronous', function (t) { t.plan(4) let async = false db.get('not found', function (err, value) { t.ok(err, 'should error') t.ok(verifyNotFoundError(err), 'should have correct error message') t.ok(typeof value === 'undefined', 'value is undefined') t.ok(async, 'callback is asynchronous') }) async = true }) } exports.tearDown = function (test, testCommon) { test('tearDown', function (t) { db.close(testCommon.tearDown.bind(null, t)) }) } exports.all = function (test, testCommon) { exports.setUp(test, testCommon) exports.args(test, testCommon) exports.get(test, testCommon) exports.tearDown(test, testCommon) }