File: hrtimesecs.js

package info (click to toggle)
node-jsprim 1.4.0-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 228 kB
  • ctags: 191
  • sloc: makefile: 20; sh: 2
file content (112 lines) | stat: -rw-r--r-- 1,942 bytes parent folder | download | duplicates (3)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
 * hrtimediff.js: test hrtimediff() function
 */

var mod_assert = require('assert');
var mod_util = require('util');
var hrtimeNanosec = require('../lib/jsprim').hrtimeNanosec;
var hrtimeMillisec = require('../lib/jsprim').hrtimeMillisec;
var hrtimeMicrosec = require('../lib/jsprim').hrtimeMicrosec;

var test_cases = [
	/*
	 * Passing test cases:
	 */
	{
		in: [ 0, 0 ],
		nano: 0,
		micro: 0,
		milli: 0
	},
	{
		in: [ 0, 1000 ],
		nano: 1000,
		micro: 1,
		milli: 0
	},
	{
		in: [ 0, 1999 ],
		nano: 1999,
		micro: 1,
		milli: 0
	},
	{
		in: [ 1000000000, 0 ],
		nano: 1000000000000000000,
		micro: 1000000000000000,
		milli: 1000000000000
	},
	{
		in: [ 5, 123456789 ],
		nano: 5123456789,
		micro: 5123456,
		milli: 5123
	},
	/*
	 * Failing test cases:
	 */
	{
		in: null,
		out: false
	},
	{
		in: [ -1, 0 ],
		out: false
	},
	{
		in: [ 0, -1 ],
		out: false
	},
	{
		in: [ 0, 1000000000 ],
		out: false
	}
];

test_cases.forEach(function (tc) {
	console.log('%s test case:', tc.out === false ? 'failing' :
	    'passing');

	console.log('\tin = %j', tc.in);

	var nano, micro, milli;
	var failures = 0;

	try {
		nano = hrtimeNanosec(tc.in);
		console.log('\tnano = %j', nano);
	} catch (ex) {
		console.log('\tnano error = %s', ex.toString());
		failures++;
	}

	try {
		micro = hrtimeMicrosec(tc.in);
		console.log('\tmicro = %j', micro);
	} catch (ex) {
		console.log('\tmicro error = %s', ex.toString());
		failures++;
	}

	try {
		milli = hrtimeMillisec(tc.in);
		console.log('\tmilli = %j', milli);
	} catch (ex) {
		console.log('\tmilli error = %s', ex.toString());
		failures++;
	}

	if (tc.out === false) {
		/*
		 * We expected to fail; ensure we did so.
		 */
		mod_assert.strictEqual(failures, 3, 'wanted throw');
	} else {
		/*
		 * Ensure that we returned the expected value:
		 */
		mod_assert.strictEqual(nano, tc.nano);
		mod_assert.strictEqual(micro, tc.micro);
		mod_assert.strictEqual(milli, tc.milli);
	}
});