Initial commit
[yaffs-website] / node_modules / are-we-there-yet / test / trackerstream.js
1 'use strict'
2 var test = require('tap').test
3 var util = require('util')
4 var stream = require('readable-stream')
5 var TrackerStream = require('../index.js').TrackerStream
6 var testEvent = require('./lib/test-event.js')
7
8 var Sink = function () {
9   stream.Writable.apply(this, arguments)
10 }
11 util.inherits(Sink, stream.Writable)
12 Sink.prototype._write = function (data, encoding, cb) {
13   cb()
14 }
15
16 test('TrackerStream', function (t) {
17   t.plan(9)
18
19   var name = 'test'
20   var track = new TrackerStream(name)
21
22   t.is(track.completed(), 0, 'Nothing todo is 0 completion')
23
24   var todo = 10
25   track = new TrackerStream(name, todo)
26   t.is(track.completed(), 0, 'Nothing done is 0 completion')
27
28   track.pipe(new Sink())
29
30   testEvent(track, 'change', afterCompleteWork)
31   track.write('0123456789')
32   function afterCompleteWork (er, onChangeName) {
33     t.is(er, null, 'write: on change event fired')
34     t.is(onChangeName, name, 'write: on change emits the correct name')
35     t.is(track.completed(), 1, 'write: 100% completed')
36
37     testEvent(track, 'change', afterAddWork)
38     track.addWork(10)
39   }
40   function afterAddWork (er, onChangeName) {
41     t.is(er, null, 'addWork: on change event fired')
42     t.is(track.completed(), 0.5, 'addWork: 50% completed')
43
44     testEvent(track, 'change', afterAllWork)
45     track.write('ABCDEFGHIJKLMNOPQRST')
46   }
47   function afterAllWork (er) {
48     t.is(er, null, 'allWork: on change event fired')
49     t.is(track.completed(), 1, 'allWork: 100% completed')
50   }
51 })