fcoin/test/utils-test.js
Christopher Jeffrey 4b0519a073
more tests. utils.
2016-05-15 03:33:58 -07:00

111 lines
3.1 KiB
JavaScript

var bn = require('bn.js');
var bcoin = require('../').set('main');
var assert = require('assert');
var utils = bcoin.utils;
describe('Utils', function() {
it('should encode/decode base58', function() {
var arr = new Buffer([ 0, 0, 0, 0xde, 0xad, 0xbe, 0xef ]);
var b = utils.toBase58(arr);
assert.equal(b, '1116h8cQN');
assert.deepEqual(utils.fromBase58(b), arr);
});
it('should translate bits to target', function() {
var bits = 0x1900896c;
var hash = new Buffer(
'672b3f1bb11a994267ea4171069ba0aa4448a840f38e8f340000000000000000',
'hex'
);
var target = utils.fromCompact(bits);
assert(utils.testTarget(target, hash));
});
it('should convert satoshi to btc', function() {
var btc = utils.btc(5460);
assert.equal(btc, '0.0000546');
btc = utils.btc(54678 * 1000000);
assert.equal(btc, '546.78');
btc = utils.btc(5460 * 10000000);
assert.equal(btc, '546');
});
it('should convert btc to satoshi', function() {
var btc = utils.satoshi('0.0000546');
assert(btc === 5460);
btc = utils.satoshi('546.78');
assert(btc === 54678 * 1000000);
btc = utils.satoshi('546');
assert(btc === 5460 * 10000000);
});
var unsigned = [
new bn('ffeeffee'),
new bn('001fffeeffeeffee'),
new bn('eeffeeff'),
new bn('001feeffeeffeeff'),
new bn(0),
new bn(1)
];
var signed = [
new bn('ffeeffee'),
new bn('001fffeeffeeffee'),
new bn('eeffeeff'),
new bn('001feeffeeffeeff'),
new bn(0),
new bn(1),
new bn('ffeeffee').ineg(),
new bn('001fffeeffeeffee').ineg(),
new bn('eeffeeff').ineg(),
new bn('001feeffeeffeeff').ineg(),
new bn(0).ineg(),
new bn(1).ineg()
];
unsigned.forEach(function(num) {
var buf1 = new Buffer(8);
var buf2 = new Buffer(8);
var msg = 'should write+read a ' + num.bitLength() + ' bit unsigned int';
it(msg, function() {
utils.writeU64(buf1, num, 0);
utils.writeU64N(buf2, num.toNumber(), 0);
assert.deepEqual(buf1, buf2);
var n1 = utils.readU64(buf1, 0);
var n2 = utils.readU64N(buf2, 0);
assert.equal(n1.toNumber(), n2);
});
});
signed.forEach(function(num) {
var buf1 = new Buffer(8);
var buf2 = new Buffer(8);
var msg = 'should write+read a ' + num.bitLength()
+ ' bit ' + (num.isNeg() ? 'negative' : 'positive') + ' int';
it(msg, function() {
utils.write64(buf1, num, 0);
utils.write64N(buf2, num.toNumber(), 0);
assert.deepEqual(buf1, buf2);
var n1 = utils.read64(buf1, 0);
var n2 = utils.read64N(buf2, 0);
assert.equal(n1.toNumber(), n2);
});
var msg = 'should write+read a ' + num.bitLength()
+ ' bit ' + (num.isNeg() ? 'negative' : 'positive') + ' int as unsigned';
it(msg, function() {
utils.writeU64(buf1, num, 0);
utils.writeU64N(buf2, num.toNumber(), 0);
assert.deepEqual(buf1, buf2);
var n1 = utils.readU64(buf1, 0);
if (num.isNeg()) {
assert.throws(function() {
utils.readU64N(buf2, 0);
});
} else {
var n2 = utils.readU64N(buf2, 0);
assert.equal(n1.toNumber(), n2);
}
});
});
});