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
|
"use strict"
var test = require("tap").test
var util = require("util")
var stream = require("readable-stream")
var TrackerStream = require("../index.js").TrackerStream
var timeoutError = new Error("timeout")
var testEvent = function (obj,event,next) {
var timeout = setTimeout(function(){
obj.removeListener(event, eventHandler)
next(timeoutError)
}, 10)
var eventHandler = function () {
var args = Array.prototype.slice.call(arguments)
args.unshift(null)
clearTimeout(timeout)
next.apply(null, args)
}
obj.once(event, eventHandler)
}
var Sink = function () {
stream.Writable.apply(this,arguments)
}
util.inherits(Sink, stream.Writable)
Sink.prototype._write = function (data, encoding, cb) {
cb()
}
test("TrackerStream", function (t) {
t.plan(9)
var name = "test"
var track = new TrackerStream(name)
t.is(track.completed(), 0, "Nothing todo is 0 completion")
var todo = 10
track = new TrackerStream(name, todo)
t.is(track.completed(), 0, "Nothing done is 0 completion")
track.pipe(new Sink())
testEvent(track, "change", afterCompleteWork)
track.write("0123456789")
function afterCompleteWork(er, onChangeName) {
t.is(er, null, "write: on change event fired")
t.is(onChangeName, name, "write: on change emits the correct name")
t.is(track.completed(), 1, "write: 100% completed")
testEvent(track, "change", afterAddWork)
track.addWork(10)
}
function afterAddWork(er, onChangeName) {
t.is(er, null, "addWork: on change event fired")
t.is(track.completed(), 0.5, "addWork: 50% completed")
testEvent(track, "change", afterAllWork)
track.write("ABCDEFGHIJKLMNOPQRST")
}
function afterAllWork(er) {
t.is(er, null, "allWork: on change event fired")
t.is(track.completed(), 1, "allWork: 100% completed")
}
})
|