2018-12-20 12:11:17 +00:00
|
|
|
const { remote } = require('electron')
|
|
|
|
const chai = require('chai')
|
|
|
|
const dirtyChai = require('dirty-chai')
|
|
|
|
const fs = require('fs')
|
|
|
|
const path = require('path')
|
|
|
|
|
|
|
|
const { expect } = chai
|
|
|
|
const { app, contentTracing } = remote
|
|
|
|
|
|
|
|
chai.use(dirtyChai)
|
|
|
|
|
|
|
|
const timeout = async (milliseconds) => {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
setTimeout(resolve, milliseconds)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const getPathInATempFolder = (filename) => {
|
|
|
|
return path.join(app.getPath('temp'), filename)
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('contentTracing', () => {
|
|
|
|
beforeEach(function () {
|
|
|
|
// FIXME: The tests are skipped on arm/arm64.
|
|
|
|
if (process.platform === 'linux' &&
|
|
|
|
['arm', 'arm64'].includes(process.arch)) {
|
|
|
|
this.skip()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2019-01-31 02:53:55 +00:00
|
|
|
const record = async (options, outputFilePath, recordTimeInMilliseconds = 1e3) => {
|
|
|
|
await app.whenReady()
|
|
|
|
|
|
|
|
await contentTracing.startRecording(options)
|
|
|
|
await timeout(recordTimeInMilliseconds)
|
|
|
|
const resultFilePath = await contentTracing.stopRecording(outputFilePath)
|
|
|
|
|
|
|
|
return resultFilePath
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO(codebytere): remove when promisification is complete
|
|
|
|
const recordCallback = async (options, outputFilePath, recordTimeInMilliseconds = 1e3) => {
|
|
|
|
await app.whenReady()
|
|
|
|
|
|
|
|
await startRecording(options)
|
|
|
|
await timeout(recordTimeInMilliseconds)
|
|
|
|
const resultFilePath = await stopRecording(outputFilePath)
|
|
|
|
|
|
|
|
return resultFilePath
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO(codebytere): remove when promisification is complete
|
2018-12-20 12:11:17 +00:00
|
|
|
const startRecording = async (options) => {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
contentTracing.startRecording(options, () => {
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-01-31 02:53:55 +00:00
|
|
|
// TODO(codebytere): remove when promisification is complete
|
2018-12-20 12:11:17 +00:00
|
|
|
const stopRecording = async (filePath) => {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
contentTracing.stopRecording(filePath, (resultFilePath) => {
|
|
|
|
resolve(resultFilePath)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const outputFilePath = getPathInATempFolder('trace.json')
|
|
|
|
beforeEach(() => {
|
|
|
|
if (fs.existsSync(outputFilePath)) {
|
|
|
|
fs.unlinkSync(outputFilePath)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('startRecording', function () {
|
|
|
|
this.timeout(5e3)
|
|
|
|
|
|
|
|
const getFileSizeInKiloBytes = (filePath) => {
|
|
|
|
const stats = fs.statSync(filePath)
|
|
|
|
const fileSizeInBytes = stats.size
|
|
|
|
const fileSizeInKiloBytes = fileSizeInBytes / 1024
|
|
|
|
return fileSizeInKiloBytes
|
|
|
|
}
|
|
|
|
|
|
|
|
it('accepts an empty config', async () => {
|
|
|
|
const config = {}
|
|
|
|
await record(config, outputFilePath)
|
|
|
|
|
|
|
|
expect(fs.existsSync(outputFilePath)).to.be.true()
|
|
|
|
|
|
|
|
const fileSizeInKiloBytes = getFileSizeInKiloBytes(outputFilePath)
|
|
|
|
expect(fileSizeInKiloBytes).to.be.above(0,
|
|
|
|
`the trace output file is empty, check "${outputFilePath}"`)
|
|
|
|
})
|
|
|
|
|
2019-01-31 02:53:55 +00:00
|
|
|
// TODO(codebytere): remove when promisification is complete
|
|
|
|
it('accepts an empty config (callback)', async () => {
|
|
|
|
const config = {}
|
|
|
|
await recordCallback(config, outputFilePath)
|
|
|
|
|
|
|
|
expect(fs.existsSync(outputFilePath)).to.be.true()
|
|
|
|
|
|
|
|
const fileSizeInKiloBytes = getFileSizeInKiloBytes(outputFilePath)
|
|
|
|
expect(fileSizeInKiloBytes).to.be.above(0,
|
|
|
|
`the trace output file is empty, check "${outputFilePath}"`)
|
|
|
|
})
|
|
|
|
|
2018-12-20 12:11:17 +00:00
|
|
|
it('accepts a trace config', async () => {
|
|
|
|
// (alexeykuzmin): All categories are excluded on purpose,
|
|
|
|
// so only metadata gets into the output file.
|
|
|
|
const config = {
|
|
|
|
excluded_categories: ['*']
|
|
|
|
}
|
|
|
|
await record(config, outputFilePath)
|
|
|
|
|
|
|
|
expect(fs.existsSync(outputFilePath)).to.be.true()
|
|
|
|
|
|
|
|
// If the `excluded_categories` param above is not respected
|
|
|
|
// the file size will be above 50KB.
|
|
|
|
const fileSizeInKiloBytes = getFileSizeInKiloBytes(outputFilePath)
|
|
|
|
const expectedMaximumFileSize = 10 // Depends on a platform.
|
|
|
|
|
|
|
|
expect(fileSizeInKiloBytes).to.be.above(0,
|
|
|
|
`the trace output file is empty, check "${outputFilePath}"`)
|
|
|
|
expect(fileSizeInKiloBytes).to.be.below(expectedMaximumFileSize,
|
|
|
|
`the trace output file is suspiciously large (${fileSizeInKiloBytes}KB),
|
|
|
|
check "${outputFilePath}"`)
|
|
|
|
})
|
|
|
|
|
2019-01-31 02:53:55 +00:00
|
|
|
// TODO(codebytere): remove when promisification is complete
|
|
|
|
it('accepts a trace config (callback)', async () => {
|
|
|
|
// (alexeykuzmin): All categories are excluded on purpose,
|
|
|
|
// so only metadata gets into the output file.
|
|
|
|
const config = {
|
|
|
|
excluded_categories: ['*']
|
|
|
|
}
|
|
|
|
await recordCallback(config, outputFilePath)
|
|
|
|
|
|
|
|
expect(fs.existsSync(outputFilePath)).to.be.true()
|
|
|
|
|
|
|
|
// If the `excluded_categories` param above is not respected
|
|
|
|
// the file size will be above 50KB.
|
|
|
|
const fileSizeInKiloBytes = getFileSizeInKiloBytes(outputFilePath)
|
|
|
|
const expectedMaximumFileSize = 10 // Depends on a platform.
|
|
|
|
|
|
|
|
expect(fileSizeInKiloBytes).to.be.above(0,
|
|
|
|
`the trace output file is empty, check "${outputFilePath}"`)
|
|
|
|
expect(fileSizeInKiloBytes).to.be.below(expectedMaximumFileSize,
|
|
|
|
`the trace output file is suspiciously large (${fileSizeInKiloBytes}KB),
|
|
|
|
check "${outputFilePath}"`)
|
|
|
|
})
|
|
|
|
|
2018-12-20 12:11:17 +00:00
|
|
|
it('accepts "categoryFilter" and "traceOptions" as a config', async () => {
|
|
|
|
// (alexeykuzmin): All categories are excluded on purpose,
|
|
|
|
// so only metadata gets into the output file.
|
|
|
|
const config = {
|
|
|
|
categoryFilter: '__ThisIsANonexistentCategory__',
|
|
|
|
traceOptions: ''
|
|
|
|
}
|
|
|
|
await record(config, outputFilePath)
|
|
|
|
|
|
|
|
expect(fs.existsSync(outputFilePath)).to.be.true()
|
|
|
|
|
|
|
|
// If the `categoryFilter` param above is not respected
|
|
|
|
// the file size will be above 50KB.
|
|
|
|
const fileSizeInKiloBytes = getFileSizeInKiloBytes(outputFilePath)
|
|
|
|
const expectedMaximumFileSize = 10 // Depends on a platform.
|
|
|
|
|
|
|
|
expect(fileSizeInKiloBytes).to.be.above(0,
|
|
|
|
`the trace output file is empty, check "${outputFilePath}"`)
|
|
|
|
expect(fileSizeInKiloBytes).to.be.below(expectedMaximumFileSize,
|
|
|
|
`the trace output file is suspiciously large (${fileSizeInKiloBytes}KB),
|
|
|
|
check "${outputFilePath}"`)
|
|
|
|
})
|
2019-01-31 02:53:55 +00:00
|
|
|
|
|
|
|
// TODO(codebytere): remove when promisification is complete
|
|
|
|
it('accepts "categoryFilter" and "traceOptions" as a config (callback)', async () => {
|
|
|
|
// (alexeykuzmin): All categories are excluded on purpose,
|
|
|
|
// so only metadata gets into the output file.
|
|
|
|
const config = {
|
|
|
|
categoryFilter: '__ThisIsANonexistentCategory__',
|
|
|
|
traceOptions: ''
|
|
|
|
}
|
|
|
|
await recordCallback(config, outputFilePath)
|
|
|
|
|
|
|
|
expect(fs.existsSync(outputFilePath)).to.be.true()
|
|
|
|
|
|
|
|
// If the `categoryFilter` param above is not respected
|
|
|
|
// the file size will be above 50KB.
|
|
|
|
const fileSizeInKiloBytes = getFileSizeInKiloBytes(outputFilePath)
|
|
|
|
const expectedMaximumFileSize = 10 // Depends on a platform.
|
|
|
|
|
|
|
|
expect(fileSizeInKiloBytes).to.be.above(0,
|
|
|
|
`the trace output file is empty, check "${outputFilePath}"`)
|
|
|
|
expect(fileSizeInKiloBytes).to.be.below(expectedMaximumFileSize,
|
|
|
|
`the trace output file is suspiciously large (${fileSizeInKiloBytes}KB),
|
|
|
|
check "${outputFilePath}"`)
|
|
|
|
})
|
2018-12-20 12:11:17 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
describe('stopRecording', function () {
|
|
|
|
this.timeout(5e3)
|
|
|
|
|
|
|
|
it('calls its callback with a result file path', async () => {
|
|
|
|
const resultFilePath = await record(/* options */ {}, outputFilePath)
|
|
|
|
expect(resultFilePath).to.be.a('string').and.be.equal(outputFilePath)
|
|
|
|
})
|
|
|
|
|
2019-01-31 02:53:55 +00:00
|
|
|
// TODO(codebytere): remove when promisification is complete
|
|
|
|
it('calls its callback with a result file path (callback)', async () => {
|
|
|
|
const resultFilePath = await recordCallback(/* options */ {}, outputFilePath)
|
|
|
|
expect(resultFilePath).to.be.a('string').and.be.equal(outputFilePath)
|
|
|
|
})
|
|
|
|
|
2018-12-20 12:11:17 +00:00
|
|
|
// FIXME(alexeykuzmin): https://github.com/electron/electron/issues/16019
|
|
|
|
xit('creates a temporary file when an empty string is passed', async function () {
|
|
|
|
const resultFilePath = await record(/* options */ {}, /* outputFilePath */ '')
|
|
|
|
expect(resultFilePath).to.be.a('string').that.is.not.empty()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|