'use strict' var test = require('tape').test var msgpack = require('../') var bl = require('bl') test('encoding/decoding 32-bits float numbers', function (t) { var encoder = msgpack() var allNum = [] allNum.push(-222.42) allNum.push(748364.2) allNum.push(2.2) allNum.forEach(function (num) { t.test('encoding ' + num, function (t) { var buf = encoder.encode(num) var dec = buf.readFloatBE(1) t.equal(buf.length, 5, 'must have 5 bytes') t.equal(buf[0], 0xca, 'must have the proper header') t.true(Math.abs(dec - num) < 0.1, 'must decode correctly') t.end() }) t.test('forceFloat64 encoding ' + num, function (t) { var enc = msgpack({ forceFloat64: true }) var buf = enc.encode(num) var dec = buf.readDoubleBE(1) t.equal(buf.length, 9, 'must have 9 bytes') t.equal(buf[0], 0xcb, 'must have the proper header') t.true(Math.abs(dec - num) < 0.1, 'must decode correctly') t.end() }) t.test('decoding ' + num, function (t) { var buf = new Buffer(5) var dec buf[0] = 0xca buf.writeFloatBE(num, 1) dec = encoder.decode(buf) t.true(Math.abs(dec - num) < 0.1, 'must decode correctly') t.end() }) t.test('mirror test ' + num, function (t) { var dec = encoder.decode(encoder.encode(num)) t.true(Math.abs(dec - num) < 0.1, 'must decode correctly') t.end() }) }) t.end() }) test('decoding an incomplete 32-bits float numbers', function (t) { var encoder = msgpack() var buf = new Buffer(4) buf[0] = 0xca buf = bl().append(buf) var origLength = buf.length t.throws(function () { encoder.decode(buf) }, encoder.IncompleteBufferError, 'must throw IncompleteBufferError') t.equals(buf.length, origLength, 'must not consume any byte') t.end() })