electron/spec/static/main.js

165 lines
4.6 KiB
JavaScript
Raw Normal View History

// Disable use of deprecated functions.
2016-03-25 20:03:49 +00:00
process.throwDeprecation = true
2016-03-25 20:03:49 +00:00
const electron = require('electron')
const app = electron.app
const ipcMain = electron.ipcMain
const dialog = electron.dialog
const BrowserWindow = electron.BrowserWindow
const protocol = electron.protocol
const fs = require('fs')
2016-03-25 20:03:49 +00:00
const path = require('path')
const url = require('url')
const util = require('util')
var argv = require('yargs')
.boolean('ci')
.string('g').alias('g', 'grep')
.boolean('i').alias('i', 'invert')
2016-03-25 20:03:49 +00:00
.argv
2013-07-17 08:28:14 +00:00
2016-03-25 20:03:49 +00:00
var window = null
process.port = 0 // will be used by crash-reporter spec.
2013-07-17 08:28:14 +00:00
2016-03-25 20:03:49 +00:00
app.commandLine.appendSwitch('js-flags', '--expose_gc')
app.commandLine.appendSwitch('ignore-certificate-errors')
app.commandLine.appendSwitch('disable-renderer-backgrounding')
2013-07-29 08:35:42 +00:00
// Accessing stdout in the main process will result in the process.stdout
// throwing UnknownSystemError in renderer process sometimes. This line makes
// sure we can reproduce it in renderer process.
2016-03-25 20:03:49 +00:00
process.stdout
2016-01-26 12:26:42 +00:00
// Access console to reproduce #3482.
2016-03-25 20:03:49 +00:00
console
2016-01-26 12:26:42 +00:00
2016-03-25 20:03:49 +00:00
ipcMain.on('message', function (event, arg) {
event.sender.send('message', arg)
})
// Write output to file if OUTPUT_TO_FILE is defined.
const outputToFile = process.env.OUTPUT_TO_FILE
const print = function (_, args) {
let output = util.format.apply(null, args)
if (outputToFile) {
fs.appendFileSync(outputToFile, output + '\n')
} else {
console.error(output)
}
}
ipcMain.on('console.log', print)
ipcMain.on('console.error', print)
2016-03-25 20:03:49 +00:00
ipcMain.on('process.exit', function (event, code) {
process.exit(code)
})
2016-03-25 20:03:49 +00:00
ipcMain.on('eval', function (event, script) {
event.returnValue = eval(script) // eslint-disable-line
2016-03-25 20:03:49 +00:00
})
2016-03-25 20:03:49 +00:00
ipcMain.on('echo', function (event, msg) {
event.returnValue = msg
})
2013-09-22 04:06:41 +00:00
2016-03-25 20:03:49 +00:00
global.isCi = !!argv.ci
if (global.isCi) {
2016-03-25 20:03:49 +00:00
process.removeAllListeners('uncaughtException')
process.on('uncaughtException', function (error) {
console.error(error, error.stack)
process.exit(1)
})
}
// Register app as standard scheme.
global.standardScheme = 'app'
protocol.registerStandardSchemes([global.standardScheme])
2016-03-25 20:03:49 +00:00
app.on('window-all-closed', function () {
app.quit()
})
2016-03-25 20:03:49 +00:00
app.on('ready', function () {
// Test if using protocol module would crash.
2016-03-25 20:03:49 +00:00
electron.protocol.registerStringProtocol('test-if-crashes', function () {})
2016-02-03 20:53:56 +00:00
// Send auto updater errors to window to be verified in specs
electron.autoUpdater.on('error', function (error) {
2016-03-25 20:03:49 +00:00
window.send('auto-updater-error', error.message)
})
2016-02-03 20:53:56 +00:00
2013-07-17 08:28:14 +00:00
window = new BrowserWindow({
2015-04-14 07:59:45 +00:00
title: 'Electron Tests',
2013-08-21 03:35:39 +00:00
show: false,
2013-07-17 08:28:14 +00:00
width: 800,
height: 600,
2016-03-16 16:24:57 +00:00
webPreferences: {
2016-06-29 16:37:10 +00:00
backgroundThrottling: false
}
2016-03-25 20:03:49 +00:00
})
window.loadURL(url.format({
pathname: path.join(__dirname, '/index.html'),
protocol: 'file',
query: {
grep: argv.grep,
2016-03-25 20:03:49 +00:00
invert: argv.invert ? 'true' : ''
}
2016-03-25 20:03:49 +00:00
}))
window.on('unresponsive', function () {
var chosen = dialog.showMessageBox(window, {
type: 'warning',
buttons: ['Close', 'Keep Waiting'],
message: 'Window is not responsing',
detail: 'The window is not responding. Would you like to force close it or just keep waiting?'
2016-03-25 20:03:49 +00:00
})
if (chosen === 0) window.destroy()
})
2015-09-24 07:55:45 +00:00
// For session's download test, listen 'will-download' event in browser, and
// reply the result to renderer for verifying
2016-03-25 20:03:49 +00:00
var downloadFilePath = path.join(__dirname, '..', 'fixtures', 'mock.pdf')
2016-06-29 16:37:10 +00:00
ipcMain.on('set-download-option', function (event, needCancel, preventDefault) {
2016-03-25 20:03:49 +00:00
window.webContents.session.once('will-download', function (e, item) {
2016-06-29 16:37:10 +00:00
if (preventDefault) {
2016-03-25 20:03:49 +00:00
e.preventDefault()
const url = item.getURL()
const filename = item.getFilename()
setImmediate(function () {
try {
2016-03-25 20:03:49 +00:00
item.getURL()
2016-03-28 23:11:00 +00:00
} catch (err) {
2016-03-25 20:03:49 +00:00
window.webContents.send('download-error', url, filename, err.message)
}
2016-03-25 20:03:49 +00:00
})
} else {
2016-03-25 20:03:49 +00:00
item.setSavePath(downloadFilePath)
item.on('done', function (e, state) {
window.webContents.send('download-done',
2016-03-25 20:03:49 +00:00
state,
item.getURL(),
item.getMimeType(),
item.getReceivedBytes(),
item.getTotalBytes(),
item.getContentDisposition(),
2016-07-28 00:52:36 +00:00
item.getFilename(),
item.getSavePath())
2016-03-25 20:03:49 +00:00
})
2016-06-29 16:37:10 +00:00
if (needCancel) item.cancel()
}
2016-03-25 20:03:49 +00:00
})
event.returnValue = 'done'
})
2016-02-24 10:11:09 +00:00
2016-03-25 20:03:49 +00:00
ipcMain.on('executeJavaScript', function (event, code, hasCallback) {
2016-02-24 10:11:09 +00:00
if (hasCallback) {
window.webContents.executeJavaScript(code, (result) => {
2016-03-25 20:03:49 +00:00
window.webContents.send('executeJavaScript-response', result)
})
2016-02-24 10:11:09 +00:00
} else {
2016-03-25 20:03:49 +00:00
window.webContents.executeJavaScript(code)
event.returnValue = 'success'
2016-02-24 10:11:09 +00:00
}
2016-03-25 20:03:49 +00:00
})
})