test: clean up and augment Tray module spec (#19410)

* spec: clean and add a new tray spec

* address feedback from @nornagon

* destroy tray after every test consistently
This commit is contained in:
Shelley Vohr 2019-07-24 21:22:08 -07:00 committed by GitHub
parent 86c2ea1cb8
commit 539078f281
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1,28 +1,35 @@
import { expect } from 'chai' import { expect } from 'chai'
import { Menu, Tray, nativeImage } from 'electron' import { Menu, Tray, nativeImage } from 'electron'
import { ifdescribe, ifit } from './spec-helpers'
describe('tray module', () => { describe('tray module', () => {
let tray: Tray; let tray: Tray;
beforeEach(() => { beforeEach(() => { tray = new Tray(nativeImage.createEmpty()) })
tray = new Tray(nativeImage.createEmpty())
})
afterEach(() => { afterEach(() => {
tray.destroy()
tray = null as any tray = null as any
}) })
describe('tray.setContextMenu', () => { ifdescribe(process.platform === 'darwin')('tray get/set ignoreDoubleClickEvents', () => {
afterEach(() => { it('returns false by default', () => {
tray.destroy() const ignored = tray.getIgnoreDoubleClickEvents()
expect(ignored).to.be.false('ignored')
}) })
it('accepts menu instance', () => { it('can be set to true', () => {
tray.setContextMenu(new Menu()) tray.setIgnoreDoubleClickEvents(true)
const ignored = tray.getIgnoreDoubleClickEvents()
expect(ignored).to.be.true('not ignored')
})
}) })
it('accepts null', () => { describe('tray.setContextMenu(menu)', () => {
tray.setContextMenu(null) it('accepts both null and Menu as parameters', () => {
expect(() => { tray.setContextMenu(new Menu()) }).to.not.throw()
expect(() => { tray.setContextMenu(null) }).to.not.throw()
}) })
}) })
@ -35,16 +42,8 @@ describe('tray module', () => {
}) })
}) })
describe('tray.popUpContextMenu', () => { describe('tray.popUpContextMenu()', () => {
afterEach(() => { ifit(process.platform === 'win32')('can be called when menu is showing', function (done) {
tray.destroy()
})
before(function () {
if (process.platform !== 'win32') this.skip()
})
it('can be called when menu is showing', (done) => {
tray.setContextMenu(Menu.buildFromTemplate([{ label: 'Test' }])) tray.setContextMenu(Menu.buildFromTemplate([{ label: 'Test' }]))
setTimeout(() => { setTimeout(() => {
tray.popUpContextMenu() tray.popUpContextMenu()
@ -54,31 +53,28 @@ describe('tray module', () => {
}) })
}) })
describe('tray.setImage', () => { describe('tray.getBounds()', () => {
afterEach(() => { tray.destroy() })
ifit(process.platform !== 'linux') ('returns a bounds object', function () {
const bounds = tray.getBounds()
expect(bounds).to.be.an('object').and.to.have.all.keys('x', 'y', 'width', 'height');
})
})
describe('tray.setImage(image)', () => {
it('accepts empty image', () => { it('accepts empty image', () => {
tray.setImage(nativeImage.createEmpty()) tray.setImage(nativeImage.createEmpty())
tray.destroy()
}) })
}) })
describe('tray.setPressedImage', () => { describe('tray.setPressedImage(image)', () => {
it('accepts empty image', () => { it('accepts empty image', () => {
tray.setPressedImage(nativeImage.createEmpty()) tray.setPressedImage(nativeImage.createEmpty())
tray.destroy()
}) })
}) })
describe('tray title get/set', () => { ifdescribe(process.platform === 'darwin')('tray get/set title', () => {
before(function () {
if (process.platform !== 'darwin') this.skip()
})
afterEach(() => {
tray.destroy()
})
it('sets/gets non-empty title', () => { it('sets/gets non-empty title', () => {
const title = 'Hello World!' const title = 'Hello World!'
tray.setTitle(title) tray.setTitle(title)