Merge pull request #5662 from electron/electron-require

Always return internal module when requiring electron
This commit is contained in:
Cheng Zhao 2016-05-24 01:46:36 +00:00
commit 9d924bb6d7
9 changed files with 80 additions and 15 deletions

View file

@ -1,6 +1,6 @@
;(function () { ;(function () {
return function (process, require, asarSource) { return function (process, require, asarSource) {
// Make asar.coffee accessible via "require". // Make asar.js accessible via "require".
process.binding('natives').ELECTRON_ASAR = asarSource process.binding('natives').ELECTRON_ASAR = asarSource
// Monkey-patch the fs module. // Monkey-patch the fs module.

View file

@ -4,29 +4,30 @@ const Module = require('module')
// Clear Node's global search paths. // Clear Node's global search paths.
Module.globalPaths.length = 0 Module.globalPaths.length = 0
// Clear current and parent(init.coffee)'s search paths. // Clear current and parent(init.js)'s search paths.
module.paths = [] module.paths = []
module.parent.paths = [] module.parent.paths = []
// Prevent Node from adding paths outside this app to search paths. // Prevent Node from adding paths outside this app to search paths.
Module._nodeModulePaths = function (from) { Module._nodeModulePaths = function (from) {
var dir, i, part, parts, paths, skipOutsidePaths, splitRe, tip
from = path.resolve(from) from = path.resolve(from)
// If "from" is outside the app then we do nothing. // If "from" is outside the app then we do nothing.
skipOutsidePaths = from.startsWith(process.resourcesPath) const skipOutsidePaths = from.startsWith(process.resourcesPath)
// Following logoic is copied from module.js. // Following logic is copied from module.js.
splitRe = process.platform === 'win32' ? /[\/\\]/ : /\// const splitRe = process.platform === 'win32' ? /[\/\\]/ : /\//
paths = [] const paths = []
parts = from.split(splitRe) const parts = from.split(splitRe)
let tip
let i
for (tip = i = parts.length - 1; i >= 0; tip = i += -1) { for (tip = i = parts.length - 1; i >= 0; tip = i += -1) {
part = parts[tip] const part = parts[tip]
if (part === 'node_modules') { if (part === 'node_modules') {
continue continue
} }
dir = parts.slice(0, tip + 1).join(path.sep) const dir = parts.slice(0, tip + 1).join(path.sep)
if (skipOutsidePaths && !dir.startsWith(process.resourcesPath)) { if (skipOutsidePaths && !dir.startsWith(process.resourcesPath)) {
break break
} }
@ -34,3 +35,15 @@ Module._nodeModulePaths = function (from) {
} }
return paths return paths
} }
// Patch Module._resolveFilename to always require the Electron API when
// require('electron') is done.
const electronPath = path.join(__dirname, '..', process.type, 'api', 'exports', 'electron.js')
const originalResolveFilename = Module._resolveFilename
Module._resolveFilename = function (request, parent, isMain) {
if (request === 'electron') {
return electronPath
} else {
return originalResolveFilename(request, parent, isMain)
}
}

View file

@ -3,10 +3,9 @@ const ChildProcess = require('child_process')
const https = require('https') const https = require('https')
const fs = require('fs') const fs = require('fs')
const path = require('path') const path = require('path')
const remote = require('electron').remote const {remote} = require('electron')
const app = remote.require('electron').app const {app, BrowserWindow, ipcMain} = remote
const BrowserWindow = remote.require('electron').BrowserWindow
const isCI = remote.getGlobal('isCi') const isCI = remote.getGlobal('isCi')
describe('electron module', function () { describe('electron module', function () {
@ -15,6 +14,36 @@ describe('electron module', function () {
require('clipboard') require('clipboard')
}, /Cannot find module 'clipboard'/) }, /Cannot find module 'clipboard'/)
}) })
describe('require("electron")', function () {
let window = null
beforeEach(function () {
if (window != null) {
window.destroy()
}
window = new BrowserWindow({
show: false,
width: 400,
height: 400
})
})
afterEach(function () {
if (window != null) {
window.destroy()
}
window = null
})
it('always returns the internal electron module', function (done) {
ipcMain.once('answer', function () {
done()
})
window.loadURL('file://' + path.join(__dirname, 'fixtures', 'api', 'electron-module-app', 'index.html'))
})
})
}) })
describe('app module', function () { describe('app module', function () {

View file

@ -0,0 +1,14 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script>
require('foo').bar()
require('electron').ipcRenderer.send('answer')
</script>
</head>
<body>
</body>
</html>

View file

View file

@ -0,0 +1,4 @@
{
"name": "electron",
"main": "index.js"
}

View file

@ -0,0 +1 @@
exports.bar = function () {}

View file

@ -0,0 +1,4 @@
{
"name": "foo",
"main": "index.js"
}

View file

@ -3,7 +3,7 @@ const child_process = require('child_process')
const fs = require('fs') const fs = require('fs')
const path = require('path') const path = require('path')
const os = require('os') const os = require('os')
const remote = require('electron').remote const {remote} = require('electron')
describe('node feature', function () { describe('node feature', function () {
var fixtures = path.join(__dirname, 'fixtures') var fixtures = path.join(__dirname, 'fixtures')