floats.js
1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
'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()
})