123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 |
- 'use strict'
- const chai = require('chai')
- const dirtyChai = require('dirty-chai')
- const { deprecations, deprecate } = require('electron')
- const { expect } = chai
- chai.use(dirtyChai)
- describe('deprecations', () => {
- beforeEach(() => {
- deprecations.setHandler(null)
- process.throwDeprecation = true
- })
- it('allows a deprecation handler function to be specified', () => {
- const messages = []
- deprecations.setHandler(message => {
- messages.push(message)
- })
- deprecate.log('this is deprecated')
- expect(messages).to.deep.equal(['this is deprecated'])
- })
- it('returns a deprecation handler after one is set', () => {
- const messages = []
- deprecations.setHandler(message => {
- messages.push(message)
- })
- deprecate.log('this is deprecated')
- expect(deprecations.getHandler()).to.be.a('function')
- })
- it('renames a property', () => {
- let msg
- deprecations.setHandler(m => { msg = m })
- const oldProp = 'dingyOldName'
- const newProp = 'shinyNewName'
- let value = 0
- const o = { [newProp]: value }
- expect(o).to.not.have.a.property(oldProp)
- expect(o).to.have.a.property(newProp).that.is.a('number')
- deprecate.renameProperty(o, oldProp, newProp)
- o[oldProp] = ++value
- expect(msg).to.be.a('string')
- expect(msg).to.include(oldProp)
- expect(msg).to.include(newProp)
- expect(o).to.have.a.property(newProp).that.is.equal(value)
- expect(o).to.have.a.property(oldProp).that.is.equal(value)
- })
- it('doesn\'t deprecate a property not on an object', () => {
- const o = {}
- expect(() => {
- deprecate.removeProperty(o, 'iDoNotExist')
- }).to.throw(/iDoNotExist/)
- })
- it('deprecates a property of an object', () => {
- let msg
- deprecations.setHandler(m => { msg = m })
- const prop = 'itMustGo'
- const o = { [prop]: 0 }
- deprecate.removeProperty(o, prop)
- const temp = o[prop]
- expect(temp).to.equal(0)
- expect(msg).to.be.a('string')
- expect(msg).to.include(prop)
- })
- it('warns exactly once when a function is deprecated with no replacement', () => {
- let msg
- deprecations.setHandler(m => { msg = m })
- function oldFn () { return 'hello' }
- const deprecatedFn = deprecate.removeFunction(oldFn, 'oldFn')
- deprecatedFn()
- expect(msg).to.be.a('string')
- expect(msg).to.include('oldFn')
- })
- it('warns exactly once when a function is deprecated with a replacement', () => {
- let msg
- deprecations.setHandler(m => { msg = m })
- function oldFn () { return 'hello' }
- function newFn () { return 'goodbye' }
- const deprecatedFn = deprecate.renameFunction(oldFn, newFn)
- deprecatedFn()
- expect(msg).to.be.a('string')
- expect(msg).to.include('oldFn')
- expect(msg).to.include('newFn')
- })
- it('warns only once per item', () => {
- const messages = []
- deprecations.setHandler(message => messages.push(message))
- const key = 'foo'
- const val = 'bar'
- const o = { [key]: val }
- deprecate.removeProperty(o, key)
- for (let i = 0; i < 3; ++i) {
- expect(o[key]).to.equal(val)
- expect(messages).to.have.length(1)
- }
- })
- it('warns if deprecated property is already set', () => {
- let msg
- deprecations.setHandler(m => { msg = m })
- const oldProp = 'dingyOldName'
- const newProp = 'shinyNewName'
- const o = { [oldProp]: 0 }
- deprecate.renameProperty(o, oldProp, newProp)
- expect(msg).to.be.a('string')
- expect(msg).to.include(oldProp)
- expect(msg).to.include(newProp)
- })
- it('throws an exception if no deprecation handler is specified', () => {
- expect(() => {
- deprecate.log('this is deprecated')
- }).to.throw(/this is deprecated/)
- })
- it('warns when a function is deprecated in favor of a property', () => {
- const warnings = []
- deprecations.setHandler(warning => warnings.push(warning))
- const newProp = 'newProp'
- const mod = {
- _oldGetterFn () { return 'getter' },
- _oldSetterFn () { return 'setter' }
- }
- deprecate.fnToProperty(mod, 'newProp', '_oldGetterFn', '_oldSetterFn')
- mod['oldGetterFn']()
- mod['oldSetterFn']()
- expect(warnings).to.have.lengthOf(2)
- expect(warnings[0]).to.include('oldGetterFn')
- expect(warnings[0]).to.include(newProp)
- expect(warnings[1]).to.include('oldSetterFn')
- expect(warnings[1]).to.include(newProp)
- })
- describe('promisify', () => {
- const expected = 'Hello, world!'
- let promiseFunc
- let warnings
- const enableCallbackWarnings = () => {
- warnings = []
- deprecations.setHandler(warning => warnings.push(warning))
- process.enablePromiseAPIs = true
- }
- beforeEach(() => {
- deprecations.setHandler(null)
- process.throwDeprecation = true
- promiseFunc = param => new Promise((resolve, reject) => resolve(param))
- })
- it('acts as a pass-through for promise-based invocations', async () => {
- enableCallbackWarnings()
- promiseFunc = deprecate.promisify(promiseFunc)
- const actual = await promiseFunc(expected)
- expect(actual).to.equal(expected)
- expect(warnings).to.have.lengthOf(0)
- })
- it('only calls back an error if the callback is called with (err, data)', (done) => {
- enableCallbackWarnings()
- let erringPromiseFunc = () => new Promise((resolve, reject) => {
- reject(new Error('fail'))
- })
- erringPromiseFunc = deprecate.promisify(erringPromiseFunc)
- erringPromiseFunc((err, data) => {
- expect(data).to.be.an('undefined')
- expect(err).to.be.an.instanceOf(Error).with.property('message', 'fail')
- erringPromiseFunc(data => {
- expect(data).to.not.be.an.instanceOf(Error)
- expect(data).to.be.an('undefined')
- done()
- })
- })
- })
- it('warns exactly once for callback-based invocations', (done) => {
- enableCallbackWarnings()
- promiseFunc = deprecate.promisify(promiseFunc)
- let callbackCount = 0
- const invocationCount = 3
- const callback = (actual) => {
- expect(actual).to.equal(expected)
- expect(warnings).to.have.lengthOf(1)
- expect(warnings[0]).to.include('promiseFunc')
- callbackCount += 1
- if (callbackCount === invocationCount) {
- done()
- }
- }
- for (let i = 0; i < invocationCount; i += 1) {
- promiseFunc(expected, callback)
- }
- })
- })
- })
|