716cb28430
* chore: bump chromium in DEPS to 1e9f9a24aa12bea9cf194a82a7e249bd1242ec4f * chore: update patches * Make WebContents' theme color a base::Optional<SkColor> https://chromium-review.googlesource.com/c/chromium/src/+/1540022 * update autofill patch for incorrect header includes * Move Shell messages to web_test and rename to BlinkTest. https://chromium-review.googlesource.com/c/chromium/src/+/1525181 * Make PlatformNotificationServiceImpl a KeyedService. https://chromium-review.googlesource.com/c/chromium/src/+/1336150 * Move MediaPlayerId to its own file. https://chromium-review.googlesource.com/c/chromium/src/+/1547057 * Remove net/base/completion_callback.h, which is no longer used https://chromium-review.googlesource.com/c/chromium/src/+/1552821 * AW NS: support file scheme cookies https://chromium-review.googlesource.com/c/chromium/src/+/1533486 * Remove SecurityInfo and adapt remaining consumers https://chromium-review.googlesource.com/c/chromium/src/+/1509455 * Remove deprecated type-specific number to string conversion functions https://chromium-review.googlesource.com/c/chromium/src/+/1545881 * DevTools: Adding new performance histograms for launch of top 4 tools https://chromium-review.googlesource.com/c/chromium/src/+/1506388 * Update include paths for //base/hash/hash.h https://chromium-review.googlesource.com/c/chromium/src/+/1544630 * build: Disable ensure_gn_version gclient hook for mac CI checkout * update patches * use maybe version of v8::String::NewFromTwoByte * bump appveyor image version * fix mac ci hopefully * Convert enum to enum class for MenuAnchorPosition https://chromium-review.googlesource.com/c/chromium/src/+/1530508 * use maybe version of ToObject * RenderViewHost::GetProcess is no longer const * Unrefcount AuthChallengeInfo https://chromium-review.googlesource.com/c/chromium/src/+/1550631 * MenuButtonController takes Button rather than MenuButton https://chromium-review.googlesource.com/c/chromium/src/+/1500935 * add //ui/views_bridge_mac to deps to fix link error * forward declare views::Button in atom::MenuDelegate * more v8 patches * base/{=> hash}/md5.h https://chromium-review.googlesource.com/c/chromium/src/+/1535124 * gfx::{PlatformFontWin => win}::* https://chromium-review.googlesource.com/c/chromium/src/+/1534178 * fix v8 patches * [base] Rename TaskScheduler to ThreadPool https://chromium-review.googlesource.com/c/chromium/src/+/1561552 * use internal_config_base for bytecode_builtins_list_generator avoids windows link errors * FIXME: temporarily disable v8/breakpad integration * FIXME: temporarily disable prevent-will-redirect test * FIXME: disable neon on aarch64 pending crbug.com/953815 * update to account for WebCursor refactor https://chromium-review.googlesource.com/c/chromium/src/+/1562755 * enable stack dumping on appveyor * Revert "FIXME: disable neon on aarch64 pending crbug.com/953815" This reverts commit 57f082026be3d83069f2a2814684abf4dc9e7b53. * fix: remove const qualifiers to match upstream * fix: remove const qualifiers to match upstream in cc files as well * don't throw an error when testing if an object is an object * use non-deprecated Buffer constructor * Remove net::CookieSameSite::DEFAULT_MODE enum value https://chromium-review.googlesource.com/c/chromium/src/+/1567955 * depend on modded dbus-native to work around buffer deprecation https://github.com/sidorares/dbus-native/pull/262 * revert clang roll to fix arm build on linux * fixup! depend on modded dbus-native to work around buffer deprecation need more coffee * update coffee-script * robustify verify-mksnapshot w.r.t. command-line parameters * Revert "robustify verify-mksnapshot w.r.t. command-line parameters" This reverts commit a49af01411f684f6025528d604895c3696e0bc57. * fix mksnapshot by matching args * update patches * TMP: enable rdp on appveyor * Changed ContentBrowserClient::CreateQuotaPermissionContext() to return scoped_refptr. https://chromium-review.googlesource.com/c/chromium/src/+/1569376 * Make content::ResourceType an enum class. https://chromium-review.googlesource.com/c/chromium/src/+/1569345 * fixup! Make content::ResourceType an enum class. * turn off rdp * use net::CompletionRepeatingCallback instead of base::Callback<void(int)> * remove disable_ensure_gn_version_gclient_hook.patch * copy repeating callback instead of std::move * fix lint * add completion_repeating_callback.h include
191 lines
6.4 KiB
JavaScript
191 lines
6.4 KiB
JavaScript
const assert = require('assert')
|
|
const Module = require('module')
|
|
const path = require('path')
|
|
const fs = require('fs')
|
|
const { remote } = require('electron')
|
|
const { BrowserWindow } = remote
|
|
const { closeWindow } = require('./window-helpers')
|
|
const features = process.electronBinding('features')
|
|
|
|
const nativeModulesEnabled = remote.getGlobal('nativeModulesEnabled')
|
|
|
|
describe('modules support', () => {
|
|
const fixtures = path.join(__dirname, 'fixtures')
|
|
|
|
describe('third-party module', () => {
|
|
(nativeModulesEnabled ? describe : describe.skip)('echo', () => {
|
|
it('can be required in renderer', () => {
|
|
require('echo')
|
|
})
|
|
|
|
it('can be required in node binary', function (done) {
|
|
if (!features.isRunAsNodeEnabled()) {
|
|
this.skip()
|
|
done()
|
|
}
|
|
|
|
const echo = path.join(fixtures, 'module', 'echo.js')
|
|
const child = require('child_process').fork(echo)
|
|
child.on('message', (msg) => {
|
|
assert.strictEqual(msg, 'ok')
|
|
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 fixture = path.join(fixtures, 'module', 'echo-renamed.js')
|
|
assert.ok(fs.existsSync(fixture))
|
|
const child = require('child_process').spawnSync(testExecPath, [fixture])
|
|
assert.strictEqual(child.status, 0)
|
|
} finally {
|
|
fs.unlinkSync(testExecPath)
|
|
}
|
|
})
|
|
}
|
|
})
|
|
|
|
// TODO(alexeykuzmin): Disabled during the Chromium 62 (Node.js 9) upgrade.
|
|
// Enable it back when "ffi" module supports Node.js 9.
|
|
// https://github.com/electron/electron/issues/11274
|
|
xdescribe('ffi', () => {
|
|
before(function () {
|
|
if (!nativeModulesEnabled || process.platform === 'win32' ||
|
|
process.arch === 'arm64') {
|
|
this.skip()
|
|
}
|
|
})
|
|
|
|
it('does not crash', () => {
|
|
const ffi = require('ffi')
|
|
const libm = ffi.Library('libm', {
|
|
ceil: ['double', ['double']]
|
|
})
|
|
assert.strictEqual(libm.ceil(1.5), 2)
|
|
})
|
|
})
|
|
|
|
describe('q', () => {
|
|
const Q = require('q')
|
|
describe('Q.when', () => {
|
|
it('emits the fullfil callback', (done) => {
|
|
Q(true).then((val) => {
|
|
assert.strictEqual(val, true)
|
|
done()
|
|
})
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('coffeescript', () => {
|
|
it('can be registered and used to require .coffee files', () => {
|
|
assert.doesNotThrow(() => {
|
|
require('coffeescript').register()
|
|
})
|
|
assert.strictEqual(require('./fixtures/module/test.coffee'), true)
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('global variables', () => {
|
|
describe('process', () => {
|
|
it('can be declared in a module', () => {
|
|
assert.strictEqual(require('./fixtures/module/declare-process'), 'declared process')
|
|
})
|
|
})
|
|
|
|
describe('global', () => {
|
|
it('can be declared in a module', () => {
|
|
assert.strictEqual(require('./fixtures/module/declare-global'), 'declared global')
|
|
})
|
|
})
|
|
|
|
describe('Buffer', () => {
|
|
it('can be declared in a module', () => {
|
|
assert.strictEqual(require('./fixtures/module/declare-buffer'), 'declared Buffer')
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('Module._nodeModulePaths', () => {
|
|
describe('when the path is inside the resources path', () => {
|
|
it('does not include paths outside of the resources path', () => {
|
|
let modulePath = process.resourcesPath
|
|
assert.deepStrictEqual(Module._nodeModulePaths(modulePath), [
|
|
path.join(process.resourcesPath, 'node_modules')
|
|
])
|
|
|
|
modulePath = process.resourcesPath + '-foo'
|
|
const nodeModulePaths = Module._nodeModulePaths(modulePath)
|
|
assert(nodeModulePaths.includes(path.join(modulePath, 'node_modules')))
|
|
assert(nodeModulePaths.includes(path.join(modulePath, '..', 'node_modules')))
|
|
|
|
modulePath = path.join(process.resourcesPath, 'foo')
|
|
assert.deepStrictEqual(Module._nodeModulePaths(modulePath), [
|
|
path.join(process.resourcesPath, 'foo', 'node_modules'),
|
|
path.join(process.resourcesPath, 'node_modules')
|
|
])
|
|
|
|
modulePath = path.join(process.resourcesPath, 'node_modules', 'foo')
|
|
assert.deepStrictEqual(Module._nodeModulePaths(modulePath), [
|
|
path.join(process.resourcesPath, 'node_modules', 'foo', 'node_modules'),
|
|
path.join(process.resourcesPath, 'node_modules')
|
|
])
|
|
|
|
modulePath = path.join(process.resourcesPath, 'node_modules', 'foo', 'bar')
|
|
assert.deepStrictEqual(Module._nodeModulePaths(modulePath), [
|
|
path.join(process.resourcesPath, 'node_modules', 'foo', 'bar', 'node_modules'),
|
|
path.join(process.resourcesPath, 'node_modules', 'foo', 'node_modules'),
|
|
path.join(process.resourcesPath, 'node_modules')
|
|
])
|
|
|
|
modulePath = path.join(process.resourcesPath, 'node_modules', 'foo', 'node_modules', 'bar')
|
|
assert.deepStrictEqual(Module._nodeModulePaths(modulePath), [
|
|
path.join(process.resourcesPath, 'node_modules', 'foo', 'node_modules', 'bar', 'node_modules'),
|
|
path.join(process.resourcesPath, 'node_modules', 'foo', 'node_modules'),
|
|
path.join(process.resourcesPath, 'node_modules')
|
|
])
|
|
})
|
|
})
|
|
|
|
describe('when the path is outside the resources path', () => {
|
|
it('includes paths outside of the resources path', () => {
|
|
const modulePath = path.resolve('/foo')
|
|
assert.deepStrictEqual(Module._nodeModulePaths(modulePath), [
|
|
path.join(modulePath, 'node_modules'),
|
|
path.resolve('/node_modules')
|
|
])
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('require', () => {
|
|
describe('when loaded URL is not file: protocol', () => {
|
|
let w
|
|
|
|
beforeEach(() => {
|
|
w = new BrowserWindow({
|
|
show: false,
|
|
webPreferences: {
|
|
nodeIntegration: true
|
|
}
|
|
})
|
|
})
|
|
|
|
afterEach(async () => {
|
|
await closeWindow(w)
|
|
w = null
|
|
})
|
|
|
|
it('searches for module under app directory', async () => {
|
|
w.loadURL('about:blank')
|
|
const result = await w.webContents.executeJavaScript('typeof require("q").when')
|
|
assert.strictEqual(result, 'function')
|
|
})
|
|
})
|
|
})
|
|
})
|