You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
48 lines
1.1 KiB
48 lines
1.1 KiB
'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')
|
|
})
|
|
|