UNPKG

1.31 kBJavaScriptView Raw
1'use strict'
2
3const test = require('tap').test
4const async = require('async')
5const summary = require('summary')
6const endpoint = require('endpoint')
7const CollectAndRead = require('./collect-and-read.js')
8
9function diff (data) {
10 const output = []
11 let last = data[0]
12 for (let i = 1; i < data.length; i++) {
13 output.push(data[i] - last)
14 last = data[i]
15 }
16 return output
17}
18
19test('cmd - collect - custom sample interval', function (t) {
20 const cmd = new CollectAndRead({
21 sampleInterval: 100
22 }, '-e', 'setTimeout(() => {}, 1000)')
23
24 cmd.on('error', t.ifError.bind(t))
25 cmd.on('ready', function () {
26 async.parallel({
27 traceEvent (done) {
28 cmd.traceEvent.pipe(endpoint({ objectMode: true }, done))
29 },
30
31 processStat (done) {
32 cmd.processStat.pipe(endpoint({ objectMode: true }, done))
33 }
34 }, function (err, output) {
35 if (err) return t.ifError(err)
36
37 // expect time seperation to be 100ms, allow 100ms error
38 const sampleTimes = output.processStat.map((stat) => stat.timestamp)
39 const timeSeparation = summary(diff(sampleTimes)).mean()
40 t.ok(sampleTimes.length > 0, 'data is outputted')
41 const drift = Math.abs(timeSeparation - 100)
42 t.comment(`drift is ${drift}`)
43 t.ok(drift < 100)
44
45 t.end()
46 })
47 })
48})