Welcome to mirror list, hosted at ThFree Co, Russian Federation.

tracker.js « test « are-we-there-yet « node_modules - github.com/npm/cli.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 18c31c32cfda1ee2935aca9c46a790ffadfdf0f5 (plain)
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
"use strict"
var test = require("tap").test
var Tracker = require("../index.js").Tracker

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)
}

test("Tracker", function (t) {
  t.plan(10)

  var name = "test"
  var track = new Tracker(name)

  t.is(track.completed(), 0, "Nothing todo is 0 completion")

  var todo = 100
  track = new Tracker(name, todo)
  t.is(track.completed(), 0, "Nothing done is 0 completion")

  testEvent(track, "change", afterCompleteWork)
  track.completeWork(100)
  function afterCompleteWork(er, onChangeName) {
    t.is(er, null, "completeWork: on change event fired")
    t.is(onChangeName, name, "completeWork: on change emits the correct name")
  }
  t.is(track.completed(), 1, "completeWork: 100% completed")

  testEvent(track, "change", afterAddWork)
  track.addWork(100)
  function afterAddWork(er, onChangeName) {
    t.is(er, null, "addWork: on change event fired")
    t.is(onChangeName, name, "addWork: on change emits the correct name")
  }
  t.is(track.completed(), 0.5, "addWork: 50% completed")


  track.completeWork(200)
  t.is(track.completed(), 1, "completeWork: Over completion is still only 100% complete")

  track = new Tracker(name, todo)
  track.completeWork(50)
  track.finish()
  t.is(track.completed(), 1, "finish: Explicitly finishing moves to 100%")
})