blob: c0dab8956593fe74f1257a5204a5ea2f4a8d9678 [file] [log] [blame]
Roman Reissf29762f2015-05-19 11:00:061'use strict';
Brian Whitee505a122011-05-16 01:25:112/*
3 * Tests to verify we're reading in doubles correctly
4 */
Ben Noordhuis7f4aba92012-02-20 12:22:125var common = require('../common');
Brian Whitee505a122011-05-16 01:25:116var ASSERT = require('assert');
7
8/*
9 * Test (64 bit) double
10 */
Ben Noordhuis59a9a9b2011-11-17 13:14:4311function test(clazz) {
12 var buffer = new clazz(8);
Brian Whiteb7c23ac2011-08-09 04:40:1013
Brian Whitee505a122011-05-16 01:25:1114 buffer[0] = 0x55;
15 buffer[1] = 0x55;
16 buffer[2] = 0x55;
17 buffer[3] = 0x55;
18 buffer[4] = 0x55;
19 buffer[5] = 0x55;
20 buffer[6] = 0xd5;
21 buffer[7] = 0x3f;
Brian Whiteb7c23ac2011-08-09 04:40:1022 ASSERT.equal(1.1945305291680097e+103, buffer.readDoubleBE(0));
23 ASSERT.equal(0.3333333333333333, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1124
25 buffer[0] = 1;
26 buffer[1] = 0;
27 buffer[2] = 0;
28 buffer[3] = 0;
29 buffer[4] = 0;
30 buffer[5] = 0;
31 buffer[6] = 0xf0;
32 buffer[7] = 0x3f;
Brian Whiteb7c23ac2011-08-09 04:40:1033 ASSERT.equal(7.291122019655968e-304, buffer.readDoubleBE(0));
34 ASSERT.equal(1.0000000000000002, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1135
36 buffer[0] = 2;
Brian Whiteb7c23ac2011-08-09 04:40:1037 ASSERT.equal(4.778309726801735e-299, buffer.readDoubleBE(0));
38 ASSERT.equal(1.0000000000000004, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1139
40 buffer[0] = 1;
41 buffer[6] = 0;
42 buffer[7] = 0;
Brian Whiteb7c23ac2011-08-09 04:40:1043 ASSERT.equal(7.291122019556398e-304, buffer.readDoubleBE(0));
44 ASSERT.equal(5e-324, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1145
46 buffer[0] = 0xff;
47 buffer[1] = 0xff;
48 buffer[2] = 0xff;
49 buffer[3] = 0xff;
50 buffer[4] = 0xff;
51 buffer[5] = 0xff;
52 buffer[6] = 0x0f;
53 buffer[7] = 0x00;
Brian Whiteb7c23ac2011-08-09 04:40:1054 ASSERT.ok(isNaN(buffer.readDoubleBE(0)));
55 ASSERT.equal(2.225073858507201e-308, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1156
57 buffer[6] = 0xef;
58 buffer[7] = 0x7f;
Brian Whiteb7c23ac2011-08-09 04:40:1059 ASSERT.ok(isNaN(buffer.readDoubleBE(0)));
60 ASSERT.equal(1.7976931348623157e+308, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1161
62 buffer[0] = 0;
63 buffer[1] = 0;
64 buffer[2] = 0;
65 buffer[3] = 0;
66 buffer[4] = 0;
67 buffer[5] = 0;
68 buffer[6] = 0xf0;
69 buffer[7] = 0x3f;
Brian Whiteb7c23ac2011-08-09 04:40:1070 ASSERT.equal(3.03865e-319, buffer.readDoubleBE(0));
71 ASSERT.equal(1, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1172
73 buffer[6] = 0;
74 buffer[7] = 0x40;
Brian Whiteb7c23ac2011-08-09 04:40:1075 ASSERT.equal(3.16e-322, buffer.readDoubleBE(0));
76 ASSERT.equal(2, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1177
78 buffer[7] = 0xc0;
Brian Whiteb7c23ac2011-08-09 04:40:1079 ASSERT.equal(9.5e-322, buffer.readDoubleBE(0));
80 ASSERT.equal(-2, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1181
82 buffer[6] = 0x10;
83 buffer[7] = 0;
Brian Whiteb7c23ac2011-08-09 04:40:1084 ASSERT.equal(2.0237e-320, buffer.readDoubleBE(0));
85 ASSERT.equal(2.2250738585072014e-308, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:1186
87 buffer[6] = 0;
Brian Whiteb7c23ac2011-08-09 04:40:1088 ASSERT.equal(0, buffer.readDoubleBE(0));
89 ASSERT.equal(0, buffer.readDoubleLE(0));
Colton Baker87286cc2011-10-04 22:08:1890 ASSERT.equal(false, 1 / buffer.readDoubleLE(0) < 0);
Brian Whitee505a122011-05-16 01:25:1191
92 buffer[7] = 0x80;
Brian Whiteb7c23ac2011-08-09 04:40:1093 ASSERT.equal(6.3e-322, buffer.readDoubleBE(0));
94 ASSERT.equal(0, buffer.readDoubleLE(0));
Colton Baker87286cc2011-10-04 22:08:1895 ASSERT.equal(true, 1 / buffer.readDoubleLE(0) < 0);
Brian Whitee505a122011-05-16 01:25:1196
97 buffer[6] = 0xf0;
98 buffer[7] = 0x7f;
Brian Whiteb7c23ac2011-08-09 04:40:1099 ASSERT.equal(3.0418e-319, buffer.readDoubleBE(0));
100 ASSERT.equal(Infinity, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:11101
102 buffer[6] = 0xf0;
103 buffer[7] = 0xff;
Brian Whiteb7c23ac2011-08-09 04:40:10104 ASSERT.equal(3.04814e-319, buffer.readDoubleBE(0));
105 ASSERT.equal(-Infinity, buffer.readDoubleLE(0));
Brian Whitee505a122011-05-16 01:25:11106}
107
108
Ben Noordhuis59a9a9b2011-11-17 13:14:43109test(Buffer);