123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- // For these tests we use a fake DBus daemon to verify powerMonitor module
- // interaction with the system bus. This requires python-dbusmock installed and
- // running (with the DBUS_SYSTEM_BUS_ADDRESS environment variable set).
- // script/spec-runner.js will take care of spawning the fake DBus daemon and setting
- // DBUS_SYSTEM_BUS_ADDRESS when python-dbusmock is installed.
- //
- // See https://pypi.python.org/pypi/python-dbusmock for more information about
- // python-dbusmock.
- import { expect } from 'chai'
- import * as dbus from 'dbus-native'
- import { ifdescribe } from './spec-helpers'
- import { promisify } from 'util'
- describe('powerMonitor', () => {
- let logindMock: any, dbusMockPowerMonitor: any, getCalls: any, emitSignal: any, reset: any
- // TODO(deepak1556): Enable on arm64 after upgrade, it crashes at the moment.
- ifdescribe(process.platform === 'linux' && process.arch !== 'arm64' && process.env.DBUS_SYSTEM_BUS_ADDRESS != null)('when powerMonitor module is loaded with dbus mock', () => {
- before(async () => {
- const systemBus = dbus.systemBus()
- const loginService = systemBus.getService('org.freedesktop.login1')
- const getInterface = promisify(loginService.getInterface.bind(loginService))
- logindMock = await getInterface('/org/freedesktop/login1', 'org.freedesktop.DBus.Mock')
- getCalls = promisify(logindMock.GetCalls.bind(logindMock))
- emitSignal = promisify(logindMock.EmitSignal.bind(logindMock))
- reset = promisify(logindMock.Reset.bind(logindMock))
- })
- after(async () => {
- await reset()
- })
- function onceMethodCalled (done: () => void) {
- function cb () {
- logindMock.removeListener('MethodCalled', cb)
- }
- done()
- return cb
- }
- before(done => {
- logindMock.on('MethodCalled', onceMethodCalled(done))
- // lazy load powerMonitor after we listen to MethodCalled mock signal
- dbusMockPowerMonitor = require('electron').powerMonitor
- })
- it('should call Inhibit to delay suspend', async () => {
- const calls = await getCalls()
- expect(calls).to.be.an('array').that.has.lengthOf(1)
- expect(calls[0].slice(1)).to.deep.equal([
- 'Inhibit', [
- [[{ type: 's', child: [] }], ['sleep']],
- [[{ type: 's', child: [] }], ['electron']],
- [[{ type: 's', child: [] }], ['Application cleanup before suspend']],
- [[{ type: 's', child: [] }], ['delay']]
- ]
- ])
- })
- describe('when PrepareForSleep(true) signal is sent by logind', () => {
- it('should emit "suspend" event', (done) => {
- dbusMockPowerMonitor.once('suspend', () => done())
- emitSignal('org.freedesktop.login1.Manager', 'PrepareForSleep',
- 'b', [['b', true]])
- })
- describe('when PrepareForSleep(false) signal is sent by logind', () => {
- it('should emit "resume" event', done => {
- dbusMockPowerMonitor.once('resume', () => done())
- emitSignal('org.freedesktop.login1.Manager', 'PrepareForSleep',
- 'b', [['b', false]])
- })
- it('should have called Inhibit again', async () => {
- const calls = await getCalls()
- expect(calls).to.be.an('array').that.has.lengthOf(2)
- expect(calls[1].slice(1)).to.deep.equal([
- 'Inhibit', [
- [[{ type: 's', child: [] }], ['sleep']],
- [[{ type: 's', child: [] }], ['electron']],
- [[{ type: 's', child: [] }], ['Application cleanup before suspend']],
- [[{ type: 's', child: [] }], ['delay']]
- ]
- ])
- })
- })
- })
- describe('when a listener is added to shutdown event', () => {
- before(async () => {
- const calls = await getCalls()
- expect(calls).to.be.an('array').that.has.lengthOf(2)
- dbusMockPowerMonitor.once('shutdown', () => { })
- })
- it('should call Inhibit to delay shutdown', async () => {
- const calls = await getCalls()
- expect(calls).to.be.an('array').that.has.lengthOf(3)
- expect(calls[2].slice(1)).to.deep.equal([
- 'Inhibit', [
- [[{ type: 's', child: [] }], ['shutdown']],
- [[{ type: 's', child: [] }], ['electron']],
- [[{ type: 's', child: [] }], ['Ensure a clean shutdown']],
- [[{ type: 's', child: [] }], ['delay']]
- ]
- ])
- })
- describe('when PrepareForShutdown(true) signal is sent by logind', () => {
- it('should emit "shutdown" event', done => {
- dbusMockPowerMonitor.once('shutdown', () => { done() })
- emitSignal('org.freedesktop.login1.Manager', 'PrepareForShutdown',
- 'b', [['b', true]])
- })
- })
- })
- })
- describe('when powerMonitor module is loaded', () => {
- let powerMonitor: typeof Electron.powerMonitor
- before(() => {
- powerMonitor = require('electron').powerMonitor
- })
- describe('powerMonitor.getSystemIdleState', () => {
- it('gets current system idle state', () => {
- // this function is not mocked out, so we can test the result's
- // form and type but not its value.
- const idleState = powerMonitor.getSystemIdleState(1)
- expect(idleState).to.be.a('string')
- const validIdleStates = [ 'active', 'idle', 'locked', 'unknown' ]
- expect(validIdleStates).to.include(idleState)
- })
- it('does not accept non positive integer threshold', () => {
- expect(() => {
- powerMonitor.getSystemIdleState(-1)
- }).to.throw(/must be greater than 0/)
- expect(() => {
- powerMonitor.getSystemIdleState(NaN)
- }).to.throw(/conversion failure/)
- expect(() => {
- powerMonitor.getSystemIdleState('a' as any)
- }).to.throw(/conversion failure/)
- })
- })
- describe('powerMonitor.getSystemIdleTime', () => {
- it('notify current system idle time', () => {
- const idleTime = powerMonitor.getSystemIdleTime()
- expect(idleTime).to.be.at.least(0)
- })
- })
- })
- })
|