fix: allow renaming electron.exe (#15173)
This commit is contained in:
parent
0c711f690e
commit
30ccb6aea5
4 changed files with 39 additions and 0 deletions
10
BUILD.gn
10
BUILD.gn
|
@ -789,6 +789,16 @@ if (is_mac) {
|
||||||
"/DELAYLOAD:api-ms-win-core-winrt-l1-1-0.dll",
|
"/DELAYLOAD:api-ms-win-core-winrt-l1-1-0.dll",
|
||||||
"/DELAYLOAD:api-ms-win-core-winrt-string-l1-1-0.dll",
|
"/DELAYLOAD:api-ms-win-core-winrt-string-l1-1-0.dll",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
# This is to support renaming of electron.exe. node-gyp has hard-coded
|
||||||
|
# executable names which it will recognise as node. This module definition
|
||||||
|
# file claims that the electron executable is in fact named "node.exe",
|
||||||
|
# which is one of the executable names that node-gyp recognizes.
|
||||||
|
# See https://github.com/nodejs/node-gyp/commit/52ceec3a6d15de3a8f385f43dbe5ecf5456ad07a
|
||||||
|
ldflags += [ "/DEF:" + rebase_path("build/electron.def", root_build_dir) ]
|
||||||
|
inputs = [
|
||||||
|
"build/electron.def",
|
||||||
|
]
|
||||||
}
|
}
|
||||||
if (is_linux) {
|
if (is_linux) {
|
||||||
ldflags = [ "-pie" ]
|
ldflags = [ "-pie" ]
|
||||||
|
|
6
build/electron.def
Normal file
6
build/electron.def
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
; This is to support renaming of electron.exe. node-gyp has hard-coded
|
||||||
|
; executable names which it will recognise as node. This module definition
|
||||||
|
; file claims that the electron executable is in fact named "node.exe",
|
||||||
|
; which is one of the executable names that node-gyp recognizes.
|
||||||
|
; See https://github.com/nodejs/node-gyp/commit/52ceec3a6d15de3a8f385f43dbe5ecf5456ad07a
|
||||||
|
NAME node.exe
|
6
spec/fixtures/module/runas-renamed.js
vendored
Normal file
6
spec/fixtures/module/runas-renamed.js
vendored
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
try {
|
||||||
|
require('runas')
|
||||||
|
} catch (e) {
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
process.exit(0)
|
|
@ -1,6 +1,7 @@
|
||||||
const assert = require('assert')
|
const assert = require('assert')
|
||||||
const Module = require('module')
|
const Module = require('module')
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
|
const fs = require('fs')
|
||||||
const { remote } = require('electron')
|
const { remote } = require('electron')
|
||||||
const { BrowserWindow } = remote
|
const { BrowserWindow } = remote
|
||||||
const { closeWindow } = require('./window-helpers')
|
const { closeWindow } = require('./window-helpers')
|
||||||
|
@ -24,6 +25,22 @@ describe('modules support', () => {
|
||||||
done()
|
done()
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if (process.platform === 'win32') {
|
||||||
|
it('can be required if electron.exe is renamed', () => {
|
||||||
|
const { execPath } = remote.process
|
||||||
|
const testExecPath = path.join(path.dirname(execPath), 'test.exe')
|
||||||
|
fs.copyFileSync(execPath, testExecPath)
|
||||||
|
try {
|
||||||
|
const runasFixture = path.join(fixtures, 'module', 'runas-renamed.js')
|
||||||
|
assert.ok(fs.existsSync(runasFixture))
|
||||||
|
const child = require('child_process').spawnSync(testExecPath, [runasFixture])
|
||||||
|
assert.strictEqual(child.status, 0)
|
||||||
|
} finally {
|
||||||
|
fs.unlinkSync(testExecPath)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
// TODO(alexeykuzmin): Disabled during the Chromium 62 (Node.js 9) upgrade.
|
// TODO(alexeykuzmin): Disabled during the Chromium 62 (Node.js 9) upgrade.
|
||||||
|
|
Loading…
Reference in a new issue