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:
parent
86c2ea1cb8
commit
539078f281
1 changed files with 32 additions and 36 deletions
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue