spec: convert smaller specs to expect
This commit is contained in:
parent
003a92e099
commit
9489401e7d
3 changed files with 65 additions and 61 deletions
|
@ -1,11 +1,13 @@
|
||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
/* eslint-disable no-unused-expressions */
|
const chai = require('chai')
|
||||||
|
const dirtyChai = require('dirty-chai')
|
||||||
const {expect} = require('chai')
|
|
||||||
const {nativeImage} = require('electron')
|
const {nativeImage} = require('electron')
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
|
|
||||||
|
const {expect} = chai
|
||||||
|
chai.use(dirtyChai)
|
||||||
|
|
||||||
describe('nativeImage module', () => {
|
describe('nativeImage module', () => {
|
||||||
const ImageFormat = {
|
const ImageFormat = {
|
||||||
PNG: 'png',
|
PNG: 'png',
|
||||||
|
@ -111,16 +113,16 @@ describe('nativeImage module', () => {
|
||||||
expect(empty.toDataURL()).to.equal('data:image/png;base64,')
|
expect(empty.toDataURL()).to.equal('data:image/png;base64,')
|
||||||
expect(empty.toDataURL({scaleFactor: 2.0})).to.equal('data:image/png;base64,')
|
expect(empty.toDataURL({scaleFactor: 2.0})).to.equal('data:image/png;base64,')
|
||||||
expect(empty.getSize()).to.deep.equal({width: 0, height: 0})
|
expect(empty.getSize()).to.deep.equal({width: 0, height: 0})
|
||||||
expect(empty.getBitmap()).to.be.empty
|
expect(empty.getBitmap()).to.be.empty()
|
||||||
expect(empty.getBitmap({scaleFactor: 2.0})).to.be.empty
|
expect(empty.getBitmap({scaleFactor: 2.0})).to.be.empty()
|
||||||
expect(empty.toBitmap()).to.be.empty
|
expect(empty.toBitmap()).to.be.empty()
|
||||||
expect(empty.toBitmap({scaleFactor: 2.0})).to.be.empty
|
expect(empty.toBitmap({scaleFactor: 2.0})).to.be.empty()
|
||||||
expect(empty.toJPEG(100)).to.be.empty
|
expect(empty.toJPEG(100)).to.be.empty()
|
||||||
expect(empty.toPNG()).to.be.empty
|
expect(empty.toPNG()).to.be.empty()
|
||||||
expect(empty.toPNG({scaleFactor: 2.0})).to.be.empty
|
expect(empty.toPNG({scaleFactor: 2.0})).to.be.empty()
|
||||||
|
|
||||||
if (process.platform === 'darwin') {
|
if (process.platform === 'darwin') {
|
||||||
expect(empty.getNativeHandle()).to.be.empty
|
expect(empty.getNativeHandle()).to.be.empty()
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -135,7 +137,7 @@ describe('nativeImage module', () => {
|
||||||
|
|
||||||
const imageB = nativeImage.createFromBuffer(imageA.toPNG())
|
const imageB = nativeImage.createFromBuffer(imageA.toPNG())
|
||||||
expect(imageB.getSize()).to.deep.equal({width: 538, height: 190})
|
expect(imageB.getSize()).to.deep.equal({width: 538, height: 190})
|
||||||
expect(imageA.toBitmap().equals(imageB.toBitmap())).to.be.true
|
expect(imageA.toBitmap().equals(imageB.toBitmap())).to.be.true()
|
||||||
|
|
||||||
const imageC = nativeImage.createFromBuffer(imageA.toJPEG(100))
|
const imageC = nativeImage.createFromBuffer(imageA.toJPEG(100))
|
||||||
expect(imageC.getSize()).to.deep.equal({width: 538, height: 190})
|
expect(imageC.getSize()).to.deep.equal({width: 538, height: 190})
|
||||||
|
@ -214,7 +216,7 @@ describe('nativeImage module', () => {
|
||||||
expect(imageTwo.getSize()).to.deep.equal(
|
expect(imageTwo.getSize()).to.deep.equal(
|
||||||
{width: imageData.width, height: imageData.height})
|
{width: imageData.width, height: imageData.height})
|
||||||
|
|
||||||
expect(imageOne.toBitmap().equals(imageTwo.toBitmap())).to.be.true
|
expect(imageOne.toBitmap().equals(imageTwo.toBitmap())).to.be.true()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('supports a scale factor', () => {
|
it('supports a scale factor', () => {
|
||||||
|
@ -249,7 +251,7 @@ describe('nativeImage module', () => {
|
||||||
expect(imageC.getSize()).to.deep.equal(
|
expect(imageC.getSize()).to.deep.equal(
|
||||||
{width: imageData.width, height: imageData.height})
|
{width: imageData.width, height: imageData.height})
|
||||||
|
|
||||||
expect(imageB.toBitmap().equals(imageC.toBitmap())).to.be.true
|
expect(imageB.toBitmap().equals(imageC.toBitmap())).to.be.true()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('supports a scale factor', () => {
|
it('supports a scale factor', () => {
|
||||||
|
@ -280,21 +282,21 @@ describe('nativeImage module', () => {
|
||||||
it('loads images from paths relative to the current working directory', () => {
|
it('loads images from paths relative to the current working directory', () => {
|
||||||
const imagePath = `.${path.sep}${path.join('spec', 'fixtures', 'assets', 'logo.png')}`
|
const imagePath = `.${path.sep}${path.join('spec', 'fixtures', 'assets', 'logo.png')}`
|
||||||
const image = nativeImage.createFromPath(imagePath)
|
const image = nativeImage.createFromPath(imagePath)
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
expect(image.getSize()).to.deep.equal({width: 538, height: 190})
|
expect(image.getSize()).to.deep.equal({width: 538, height: 190})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('loads images from paths with `.` segments', () => {
|
it('loads images from paths with `.` segments', () => {
|
||||||
const imagePath = `${path.join(__dirname, 'fixtures')}${path.sep}.${path.sep}${path.join('assets', 'logo.png')}`
|
const imagePath = `${path.join(__dirname, 'fixtures')}${path.sep}.${path.sep}${path.join('assets', 'logo.png')}`
|
||||||
const image = nativeImage.createFromPath(imagePath)
|
const image = nativeImage.createFromPath(imagePath)
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
expect(image.getSize()).to.deep.equal({width: 538, height: 190})
|
expect(image.getSize()).to.deep.equal({width: 538, height: 190})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('loads images from paths with `..` segments', () => {
|
it('loads images from paths with `..` segments', () => {
|
||||||
const imagePath = `${path.join(__dirname, 'fixtures', 'api')}${path.sep}..${path.sep}${path.join('assets', 'logo.png')}`
|
const imagePath = `${path.join(__dirname, 'fixtures', 'api')}${path.sep}..${path.sep}${path.join('assets', 'logo.png')}`
|
||||||
const image = nativeImage.createFromPath(imagePath)
|
const image = nativeImage.createFromPath(imagePath)
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
expect(image.getSize()).to.deep.equal({width: 538, height: 190})
|
expect(image.getSize()).to.deep.equal({width: 538, height: 190})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -325,7 +327,7 @@ describe('nativeImage module', () => {
|
||||||
|
|
||||||
const imagePath = path.join(__dirname, 'fixtures', 'assets', 'icon.ico')
|
const imagePath = path.join(__dirname, 'fixtures', 'assets', 'icon.ico')
|
||||||
const image = nativeImage.createFromPath(imagePath)
|
const image = nativeImage.createFromPath(imagePath)
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
expect(image.getSize()).to.deep.equal({width: 256, height: 256})
|
expect(image.getSize()).to.deep.equal({width: 256, height: 256})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -355,7 +357,7 @@ describe('nativeImage module', () => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const image = nativeImage.createFromNamedImage('NSActionTemplate')
|
const image = nativeImage.createFromNamedImage('NSActionTemplate')
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('returns allows an HSL shift for a valid image on darwin', function () {
|
it('returns allows an HSL shift for a valid image on darwin', function () {
|
||||||
|
@ -366,7 +368,7 @@ describe('nativeImage module', () => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const image = nativeImage.createFromNamedImage('NSActionTemplate', [0.5, 0.2, 0.8])
|
const image = nativeImage.createFromNamedImage('NSActionTemplate', [0.5, 0.2, 0.8])
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -425,7 +427,7 @@ describe('nativeImage module', () => {
|
||||||
const cropB = image.crop({width: 25, height: 64, x: 30, y: 40})
|
const cropB = image.crop({width: 25, height: 64, x: 30, y: 40})
|
||||||
expect(cropA.getSize()).to.deep.equal({width: 25, height: 64})
|
expect(cropA.getSize()).to.deep.equal({width: 25, height: 64})
|
||||||
expect(cropB.getSize()).to.deep.equal({width: 25, height: 64})
|
expect(cropB.getSize()).to.deep.equal({width: 25, height: 64})
|
||||||
expect(cropA.toPNG().equals(cropB.toPNG())).to.be.false
|
expect(cropA.toPNG().equals(cropB.toPNG())).to.be.false()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -471,7 +473,7 @@ describe('nativeImage module', () => {
|
||||||
buffer: 'invalid'
|
buffer: 'invalid'
|
||||||
})
|
})
|
||||||
|
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
expect(image.getSize()).to.deep.equal({width: 1, height: 1})
|
expect(image.getSize()).to.deep.equal({width: 1, height: 1})
|
||||||
|
|
||||||
expect(image.toDataURL({scaleFactor: 1.0})).to.equal(imageDataOne.dataUrl)
|
expect(image.toDataURL({scaleFactor: 1.0})).to.equal(imageDataOne.dataUrl)
|
||||||
|
@ -506,7 +508,7 @@ describe('nativeImage module', () => {
|
||||||
dataURL: 'invalid'
|
dataURL: 'invalid'
|
||||||
})
|
})
|
||||||
|
|
||||||
expect(image.isEmpty()).to.be.false
|
expect(image.isEmpty()).to.be.false()
|
||||||
expect(image.getSize()).to.deep.equal({width: 1, height: 1})
|
expect(image.getSize()).to.deep.equal({width: 1, height: 1})
|
||||||
|
|
||||||
expect(image.toDataURL({scaleFactor: 1.0})).to.equal(imageDataOne.dataUrl)
|
expect(image.toDataURL({scaleFactor: 1.0})).to.equal(imageDataOne.dataUrl)
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
const assert = require('assert')
|
const chai = require('chai')
|
||||||
|
const dirtyChai = require('dirty-chai')
|
||||||
const http = require('http')
|
const http = require('http')
|
||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const os = require('os')
|
const os = require('os')
|
||||||
|
@ -10,13 +11,15 @@ const appPath = path.join(__dirname, 'fixtures', 'api', 'net-log')
|
||||||
const dumpFile = path.join(os.tmpdir(), 'net_log.json')
|
const dumpFile = path.join(os.tmpdir(), 'net_log.json')
|
||||||
const dumpFileDynamic = path.join(os.tmpdir(), 'net_log_dynamic.json')
|
const dumpFileDynamic = path.join(os.tmpdir(), 'net_log_dynamic.json')
|
||||||
|
|
||||||
|
const {expect} = chai
|
||||||
|
chai.use(dirtyChai)
|
||||||
const isCI = remote.getGlobal('isCi')
|
const isCI = remote.getGlobal('isCi')
|
||||||
|
|
||||||
describe('netLog module', () => {
|
describe('netLog module', () => {
|
||||||
let server
|
let server
|
||||||
const connections = new Set()
|
const connections = new Set()
|
||||||
|
|
||||||
before((done) => {
|
before(done => {
|
||||||
server = http.createServer()
|
server = http.createServer()
|
||||||
server.listen(0, '127.0.0.1', () => {
|
server.listen(0, '127.0.0.1', () => {
|
||||||
server.url = `http://127.0.0.1:${server.address().port}`
|
server.url = `http://127.0.0.1:${server.address().port}`
|
||||||
|
@ -33,7 +36,7 @@ describe('netLog module', () => {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
after((done) => {
|
after(done => {
|
||||||
for (const connection of connections) {
|
for (const connection of connections) {
|
||||||
connection.destroy()
|
connection.destroy()
|
||||||
}
|
}
|
||||||
|
@ -52,36 +55,35 @@ describe('netLog module', () => {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should begin and end logging to file when .startLogging() and .stopLogging() is called', (done) => {
|
it('should begin and end logging to file when .startLogging() and .stopLogging() is called', done => {
|
||||||
assert(!netLog.currentlyLogging)
|
expect(netLog.currentlyLogging).to.be.false()
|
||||||
assert.equal(netLog.currentlyLoggingPath, '')
|
expect(netLog.currentlyLoggingPath).to.equal('')
|
||||||
|
|
||||||
netLog.startLogging(dumpFileDynamic)
|
netLog.startLogging(dumpFileDynamic)
|
||||||
|
|
||||||
assert(netLog.currentlyLogging)
|
expect(netLog.currentlyLogging).to.be.true()
|
||||||
assert.equal(netLog.currentlyLoggingPath, dumpFileDynamic)
|
expect(netLog.currentlyLoggingPath).to.equal(dumpFileDynamic)
|
||||||
|
|
||||||
netLog.stopLogging((path) => {
|
netLog.stopLogging((path) => {
|
||||||
assert(!netLog.currentlyLogging)
|
expect(netLog.currentlyLogging).to.be.false()
|
||||||
assert.equal(netLog.currentlyLoggingPath, '')
|
expect(netLog.currentlyLoggingPath).to.equal('')
|
||||||
|
|
||||||
assert.equal(path, dumpFileDynamic)
|
expect(path).to.equal(dumpFileDynamic)
|
||||||
|
expect(fs.existsSync(dumpFileDynamic)).to.be.true()
|
||||||
assert(fs.existsSync(dumpFileDynamic))
|
|
||||||
|
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should silence when .stopLogging() is called without calling .startLogging()', (done) => {
|
it('should silence when .stopLogging() is called without calling .startLogging()', done => {
|
||||||
assert(!netLog.currentlyLogging)
|
expect(netLog.currentlyLogging).to.be.false()
|
||||||
assert.equal(netLog.currentlyLoggingPath, '')
|
expect(netLog.currentlyLoggingPath).to.equal('')
|
||||||
|
|
||||||
netLog.stopLogging((path) => {
|
netLog.stopLogging(path => {
|
||||||
assert(!netLog.currentlyLogging)
|
expect(netLog.currentlyLogging).to.be.false()
|
||||||
assert.equal(netLog.currentlyLoggingPath, '')
|
expect(netLog.currentlyLoggingPath).to.equal('')
|
||||||
|
|
||||||
assert.equal(path, '')
|
expect(path).to.equal('')
|
||||||
|
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
|
@ -89,7 +91,7 @@ describe('netLog module', () => {
|
||||||
|
|
||||||
// The following tests are skipped on Linux CI
|
// The following tests are skipped on Linux CI
|
||||||
|
|
||||||
it('should begin and end logging automatically when --log-net-log is passed', (done) => {
|
it('should begin and end logging automatically when --log-net-log is passed', done => {
|
||||||
if (isCI && process.platform === 'linux') {
|
if (isCI && process.platform === 'linux') {
|
||||||
done()
|
done()
|
||||||
return
|
return
|
||||||
|
@ -103,12 +105,12 @@ describe('netLog module', () => {
|
||||||
})
|
})
|
||||||
|
|
||||||
appProcess.once('exit', () => {
|
appProcess.once('exit', () => {
|
||||||
assert(fs.existsSync(dumpFile))
|
expect(fs.existsSync(dumpFile)).to.be.true()
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should begin and end logging automtically when --log-net-log is passed, and behave correctly when .startLogging() and .stopLogging() is called', (done) => {
|
it('should begin and end logging automtically when --log-net-log is passed, and behave correctly when .startLogging() and .stopLogging() is called', done => {
|
||||||
if (isCI && process.platform === 'linux') {
|
if (isCI && process.platform === 'linux') {
|
||||||
done()
|
done()
|
||||||
return
|
return
|
||||||
|
@ -123,18 +125,18 @@ describe('netLog module', () => {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
appProcess.stdout.on('data', (data) => {
|
appProcess.stdout.on('data', data => {
|
||||||
console.log(data.toString())
|
console.log(data.toString())
|
||||||
})
|
})
|
||||||
|
|
||||||
appProcess.once('exit', () => {
|
appProcess.once('exit', () => {
|
||||||
assert(fs.existsSync(dumpFile))
|
expect(fs.existsSync(dumpFile)).to.be.true()
|
||||||
assert(fs.existsSync(dumpFileDynamic))
|
expect(fs.existsSync(dumpFileDynamic)).to.be.true()
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should end logging automatically when only .startLogging() is called', (done) => {
|
it('should end logging automatically when only .startLogging() is called', done => {
|
||||||
if (isCI && process.platform === 'linux') {
|
if (isCI && process.platform === 'linux') {
|
||||||
done()
|
done()
|
||||||
return
|
return
|
||||||
|
@ -149,7 +151,7 @@ describe('netLog module', () => {
|
||||||
})
|
})
|
||||||
|
|
||||||
appProcess.once('exit', () => {
|
appProcess.once('exit', () => {
|
||||||
assert(fs.existsSync(dumpFileDynamic))
|
expect(fs.existsSync(dumpFileDynamic)).to.be.true()
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
//
|
//
|
||||||
// See https://pypi.python.org/pypi/python-dbusmock to read about dbusmock.
|
// See https://pypi.python.org/pypi/python-dbusmock to read about dbusmock.
|
||||||
|
|
||||||
const assert = require('assert')
|
const {expect} = require('chai')
|
||||||
const dbus = require('dbus-native')
|
const dbus = require('dbus-native')
|
||||||
const Promise = require('bluebird')
|
const Promise = require('bluebird')
|
||||||
|
|
||||||
|
@ -27,12 +27,12 @@ const skip = process.platform !== 'linux' ||
|
||||||
before(async () => {
|
before(async () => {
|
||||||
// init app
|
// init app
|
||||||
app.setName(appName)
|
app.setName(appName)
|
||||||
app.setDesktopName(appName + '.desktop')
|
app.setDesktopName(`${appName}.desktop`)
|
||||||
// init dbus
|
// init dbus
|
||||||
const path = '/org/freedesktop/Notifications'
|
const path = '/org/freedesktop/Notifications'
|
||||||
const iface = 'org.freedesktop.DBus.Mock'
|
const iface = 'org.freedesktop.DBus.Mock'
|
||||||
const bus = dbus.sessionBus()
|
const bus = dbus.sessionBus()
|
||||||
console.log('session bus: ' + process.env.DBUS_SESSION_BUS_ADDRESS)
|
console.log(`session bus: ${process.env.DBUS_SESSION_BUS_ADDRESS}`)
|
||||||
const service = bus.getService(serviceName)
|
const service = bus.getService(serviceName)
|
||||||
const getInterface = Promise.promisify(service.getInterface, {context: service})
|
const getInterface = Promise.promisify(service.getInterface, {context: service})
|
||||||
mock = await getInterface(path, iface)
|
mock = await getInterface(path, iface)
|
||||||
|
@ -48,10 +48,10 @@ const skip = process.platform !== 'linux' ||
|
||||||
app.setVersion(realAppVersion)
|
app.setVersion(realAppVersion)
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('Notification module using ' + serviceName, () => {
|
describe(`Notification module using ${serviceName}`, () => {
|
||||||
function onMethodCalled (done) {
|
function onMethodCalled (done) {
|
||||||
function cb (name) {
|
function cb (name) {
|
||||||
console.log('onMethodCalled: ' + name)
|
console.log(`onMethodCalled: ${name}`)
|
||||||
if (name === 'Notify') {
|
if (name === 'Notify') {
|
||||||
mock.removeListener('MethodCalled', cb)
|
mock.removeListener('MethodCalled', cb)
|
||||||
console.log('done')
|
console.log('done')
|
||||||
|
@ -83,7 +83,7 @@ const skip = process.platform !== 'linux' ||
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
before((done) => {
|
before(done => {
|
||||||
mock.on('MethodCalled', onMethodCalled(done))
|
mock.on('MethodCalled', onMethodCalled(done))
|
||||||
// lazy load Notification after we listen to MethodCalled mock signal
|
// lazy load Notification after we listen to MethodCalled mock signal
|
||||||
Notification = require('electron').remote.Notification
|
Notification = require('electron').remote.Notification
|
||||||
|
@ -98,14 +98,14 @@ const skip = process.platform !== 'linux' ||
|
||||||
n.show()
|
n.show()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should call ' + serviceName + ' to show notifications', async () => {
|
it(`should call ${serviceName} to show notifications`, async () => {
|
||||||
const calls = await getCalls()
|
const calls = await getCalls()
|
||||||
assert(calls.length >= 1)
|
expect(calls.length).to.be.at.least(1)
|
||||||
let lastCall = calls[calls.length - 1]
|
let lastCall = calls[calls.length - 1]
|
||||||
let methodName = lastCall[1]
|
let methodName = lastCall[1]
|
||||||
assert.equal(methodName, 'Notify')
|
expect(methodName).to.equal('Notify')
|
||||||
let args = unmarshalDBusNotifyArgs(lastCall[2])
|
let args = unmarshalDBusNotifyArgs(lastCall[2])
|
||||||
assert.deepEqual(args, {
|
expect(args).to.deep.equal({
|
||||||
app_name: appName,
|
app_name: appName,
|
||||||
replaces_id: 0,
|
replaces_id: 0,
|
||||||
app_icon: '',
|
app_icon: '',
|
||||||
|
|
Loading…
Reference in a new issue