Blame view

node_modules/shimmer/test/init.tap.js 1.1 KB
f7563de62   Palak Handa   first commit
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
  'use strict'
  
  var tap = require('tap')
  var test = tap.test
  var sinon = require('sinon')
  var shimmer = require('../index.js')
  
  test('shimmer initialization', function (t) {
    t.plan(4)
  
    t.doesNotThrow(function () { shimmer() })
  
    var mock = sinon.expectation
      .create('logger')
      .withArgs('no original function undefined to wrap')
      .once()
  
    t.doesNotThrow(function () {
      shimmer({logger: mock})
    }, "initializer doesn't throw")
  
    t.doesNotThrow(function () {
      shimmer.wrap()
    }, "invoking the wrap method with no params doesn't throw")
  
    t.doesNotThrow(function () {
      mock.verify()
    }, 'logger method was called with the expected message')
  })
  
  test('shimmer initialized with non-function logger', function (t) {
    t.plan(2)
  
    var mock = sinon.expectation
      .create('logger')
      .withArgs("new logger isn't a function, not replacing")
      .once()
  
    shimmer({logger: mock})
  
    t.doesNotThrow(function () {
      shimmer({logger: {ham: 'chunx'}})
    }, "even bad initialization doesn't throw")
  
    t.doesNotThrow(function () {
      mock.verify()
    }, 'logger initialization failed in the expected way')
  })