electron/spec/api-desktop-capturer-spec.js

113 lines
3.3 KiB
JavaScript
Raw Normal View History

const chai = require('chai')
const dirtyChai = require('dirty-chai')
const { desktopCapturer, ipcRenderer, remote } = require('electron')
const { screen } = remote
const features = process.atomBinding('features')
2016-01-12 02:40:23 +00:00
2018-09-13 16:10:51 +00:00
const { expect } = chai
chai.use(dirtyChai)
2017-10-27 00:44:06 +00:00
const isCI = remote.getGlobal('isCi')
2017-10-27 00:44:06 +00:00
describe('desktopCapturer', () => {
before(function () {
if (!features.isDesktopCapturerEnabled() || process.arch.indexOf('arm') === 0) {
// It's been disabled during build time.
this.skip()
return
}
if (isCI && process.platform === 'win32') {
this.skip()
}
})
it('should return a non-empty array of sources', done => {
2016-01-19 18:54:12 +00:00
desktopCapturer.getSources({
2016-01-12 02:40:23 +00:00
types: ['window', 'screen']
2017-10-27 00:44:06 +00:00
}, (error, sources) => {
expect(error).to.be.null()
2018-06-18 15:12:54 +00:00
expect(sources).to.be.an('array').that.is.not.empty()
2016-03-25 20:03:49 +00:00
done()
})
})
2016-01-19 18:57:18 +00:00
it('throws an error for invalid options', done => {
desktopCapturer.getSources(['window', 'screen'], error => {
expect(error.message).to.equal('Invalid options')
2016-08-09 22:31:24 +00:00
done()
})
})
2017-10-27 00:44:06 +00:00
it('does not throw an error when called more than once (regression)', (done) => {
let callCount = 0
const callback = (error, sources) => {
2016-03-25 20:03:49 +00:00
callCount++
expect(error).to.be.null()
2018-06-18 15:12:54 +00:00
expect(sources).to.be.an('array').that.is.not.empty()
2016-03-25 20:03:49 +00:00
if (callCount === 2) done()
}
2016-01-19 18:57:18 +00:00
2018-09-13 16:10:51 +00:00
desktopCapturer.getSources({ types: ['window', 'screen'] }, callback)
desktopCapturer.getSources({ types: ['window', 'screen'] }, callback)
2016-03-25 20:03:49 +00:00
})
it('responds to subsequent calls of different options', done => {
2017-10-27 00:44:06 +00:00
let callCount = 0
const callback = (error, sources) => {
callCount++
expect(error).to.be.null()
if (callCount === 2) done()
}
2018-09-13 16:10:51 +00:00
desktopCapturer.getSources({ types: ['window'] }, callback)
desktopCapturer.getSources({ types: ['screen'] }, callback)
})
it('returns an empty display_id for window sources on Windows and Mac', done => {
// Linux doesn't return any window sources.
if (process.platform !== 'win32' && process.platform !== 'darwin') {
return done()
}
const { BrowserWindow } = remote
const w = new BrowserWindow({ width: 200, height: 200 })
2018-09-13 16:10:51 +00:00
desktopCapturer.getSources({ types: ['window'] }, (error, sources) => {
w.destroy()
expect(error).to.be.null()
2018-06-18 15:12:54 +00:00
expect(sources).to.be.an('array').that.is.not.empty()
2018-09-13 16:10:51 +00:00
for (const { display_id: displayId } of sources) {
2018-06-18 15:12:54 +00:00
expect(displayId).to.be.a('string').and.be.empty()
}
done()
})
})
it('returns display_ids matching the Screen API on Windows and Mac', done => {
if (process.platform !== 'win32' && process.platform !== 'darwin') {
return done()
}
const displays = screen.getAllDisplays()
2018-09-13 16:10:51 +00:00
desktopCapturer.getSources({ types: ['screen'] }, (error, sources) => {
expect(error).to.be.null()
2018-06-18 15:12:54 +00:00
expect(sources).to.be.an('array').of.length(displays.length)
for (let i = 0; i < sources.length; i++) {
expect(sources[i].display_id).to.equal(displays[i].id.toString())
}
done()
})
it('returns empty sources when blocked', done => {
ipcRenderer.send('handle-next-desktop-capturer-get-sources')
desktopCapturer.getSources({ types: ['screen'] }, (error, sources) => {
expect(error).to.be.null()
expect(sources).to.be.empty()
done()
})
})
})
2016-03-25 20:03:49 +00:00
})