diff --git a/.eslintrc.json b/.eslintrc.json index 0e448b6bd30..2bec582ff6f 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -19,7 +19,40 @@ "prefer-const": ["error", { "destructuring": "all" }], - "n/no-callback-literal": "off" + "n/no-callback-literal": "off", + "import/newline-after-import": "error", + "import/order": ["error", { + "alphabetize": { + "order": "asc" + }, + "newlines-between": "always", + "pathGroups": [ + { + "pattern": "@electron/internal/**", + "group": "external", + "position": "before" + }, + { + "pattern": "@electron/**", + "group": "external", + "position": "before" + }, + { + "pattern": "{electron,electron/**}", + "group": "external", + "position": "before" + } + ], + "pathGroupsExcludedImportTypes": [], + "distinctGroup": true, + "groups": [ + "external", + "builtin", + ["sibling", "parent"], + "index", + "type" + ] + }] }, "parserOptions": { "ecmaVersion": 6, diff --git a/build/webpack/webpack.config.base.js b/build/webpack/webpack.config.base.js index 9a8a164dd61..b806e43535c 100644 --- a/build/webpack/webpack.config.base.js +++ b/build/webpack/webpack.config.base.js @@ -1,8 +1,9 @@ +const TerserPlugin = require('terser-webpack-plugin'); +const webpack = require('webpack'); +const WrapperPlugin = require('wrapper-webpack-plugin'); + const fs = require('node:fs'); const path = require('node:path'); -const webpack = require('webpack'); -const TerserPlugin = require('terser-webpack-plugin'); -const WrapperPlugin = require('wrapper-webpack-plugin'); const electronRoot = path.resolve(__dirname, '../..'); diff --git a/default_app/default_app.ts b/default_app/default_app.ts index 6a521b9d62b..6cd280bb555 100644 --- a/default_app/default_app.ts +++ b/default_app/default_app.ts @@ -1,5 +1,6 @@ import { shell } from 'electron/common'; import { app, dialog, BrowserWindow, ipcMain } from 'electron/main'; + import * as path from 'node:path'; import * as url from 'node:url'; diff --git a/default_app/main.ts b/default_app/main.ts index 9062cfca8e5..4c3f35719c1 100644 --- a/default_app/main.ts +++ b/default_app/main.ts @@ -4,6 +4,7 @@ import * as fs from 'node:fs'; import { Module } from 'node:module'; import * as path from 'node:path'; import * as url from 'node:url'; + const { app, dialog } = electron; type DefaultAppOptions = { diff --git a/lib/browser/api/app.ts b/lib/browser/api/app.ts index 8c60d6d2a09..ff024def5e8 100644 --- a/lib/browser/api/app.ts +++ b/lib/browser/api/app.ts @@ -1,7 +1,7 @@ -import * as fs from 'fs'; - import { Menu } from 'electron/main'; +import * as fs from 'fs'; + const bindings = process._linkedBinding('electron_browser_app'); const commandLine = process._linkedBinding('electron_common_command_line'); const { app } = bindings; diff --git a/lib/browser/api/auto-updater/auto-updater-win.ts b/lib/browser/api/auto-updater/auto-updater-win.ts index 4b2bac16c0c..255049cec3f 100644 --- a/lib/browser/api/auto-updater/auto-updater-win.ts +++ b/lib/browser/api/auto-updater/auto-updater-win.ts @@ -1,7 +1,9 @@ -import { app } from 'electron/main'; -import { EventEmitter } from 'events'; import * as squirrelUpdate from '@electron/internal/browser/api/auto-updater/squirrel-update-win'; +import { app } from 'electron/main'; + +import { EventEmitter } from 'events'; + class AutoUpdater extends EventEmitter implements Electron.AutoUpdater { updateAvailable: boolean = false; updateURL: string | null = null; diff --git a/lib/browser/api/auto-updater/squirrel-update-win.ts b/lib/browser/api/auto-updater/squirrel-update-win.ts index 07dead8ad74..12f26fe25ad 100644 --- a/lib/browser/api/auto-updater/squirrel-update-win.ts +++ b/lib/browser/api/auto-updater/squirrel-update-win.ts @@ -1,6 +1,6 @@ +import { spawn, ChildProcessWithoutNullStreams } from 'child_process'; import * as fs from 'fs'; import * as path from 'path'; -import { spawn, ChildProcessWithoutNullStreams } from 'child_process'; // i.e. my-app/app-0.1.13/ const appFolder = path.dirname(process.execPath); diff --git a/lib/browser/api/base-window.ts b/lib/browser/api/base-window.ts index 8d9c5899da9..d12c0f5ad59 100644 --- a/lib/browser/api/base-window.ts +++ b/lib/browser/api/base-window.ts @@ -1,6 +1,7 @@ -import { EventEmitter } from 'events'; -import type { BaseWindow as TLWT } from 'electron/main'; import { TouchBar } from 'electron/main'; +import type { BaseWindow as TLWT } from 'electron/main'; + +import { EventEmitter } from 'events'; const { BaseWindow } = process._linkedBinding('electron_browser_base_window') as { BaseWindow: typeof TLWT }; diff --git a/lib/browser/api/browser-window.ts b/lib/browser/api/browser-window.ts index ec6b99e1417..19a98c17565 100644 --- a/lib/browser/api/browser-window.ts +++ b/lib/browser/api/browser-window.ts @@ -1,5 +1,6 @@ import { BaseWindow, WebContents, BrowserView } from 'electron/main'; import type { BrowserWindow as BWT } from 'electron/main'; + const { BrowserWindow } = process._linkedBinding('electron_browser_window') as { BrowserWindow: typeof BWT }; Object.setPrototypeOf(BrowserWindow.prototype, BaseWindow.prototype); diff --git a/lib/browser/api/crash-reporter.ts b/lib/browser/api/crash-reporter.ts index 036ab47906c..ae7744d5c60 100644 --- a/lib/browser/api/crash-reporter.ts +++ b/lib/browser/api/crash-reporter.ts @@ -1,6 +1,7 @@ -import { app } from 'electron/main'; import * as deprecate from '@electron/internal/common/deprecate'; +import { app } from 'electron/main'; + const binding = process._linkedBinding('electron_browser_crash_reporter'); class CrashReporter implements Electron.CrashReporter { diff --git a/lib/browser/api/desktop-capturer.ts b/lib/browser/api/desktop-capturer.ts index 3ea4d6198c4..42a8fd8ab96 100644 --- a/lib/browser/api/desktop-capturer.ts +++ b/lib/browser/api/desktop-capturer.ts @@ -1,4 +1,5 @@ import { BrowserWindow } from 'electron/main'; + const { createDesktopCapturer, isDisplayMediaSystemPickerAvailable } = process._linkedBinding('electron_browser_desktop_capturer'); const deepEqual = (a: ElectronInternal.GetSourcesOptions, b: ElectronInternal.GetSourcesOptions) => JSON.stringify(a) === JSON.stringify(b); diff --git a/lib/browser/api/dialog.ts b/lib/browser/api/dialog.ts index d7d79ca9aee..04d95238c86 100644 --- a/lib/browser/api/dialog.ts +++ b/lib/browser/api/dialog.ts @@ -1,5 +1,6 @@ import { app, BaseWindow } from 'electron/main'; import type { OpenDialogOptions, OpenDialogReturnValue, MessageBoxOptions, SaveDialogOptions, SaveDialogReturnValue, MessageBoxReturnValue, CertificateTrustDialogOptions } from 'electron/main'; + const dialogBinding = process._linkedBinding('electron_browser_dialog'); enum SaveFileDialogProperties { diff --git a/lib/browser/api/exports/electron.ts b/lib/browser/api/exports/electron.ts index 904de54f698..d4bc2b5cd94 100644 --- a/lib/browser/api/exports/electron.ts +++ b/lib/browser/api/exports/electron.ts @@ -1,6 +1,6 @@ -import { defineProperties } from '@electron/internal/common/define-properties'; -import { commonModuleList } from '@electron/internal/common/api/module-list'; import { browserModuleList } from '@electron/internal/browser/api/module-list'; +import { commonModuleList } from '@electron/internal/common/api/module-list'; +import { defineProperties } from '@electron/internal/common/define-properties'; module.exports = {}; diff --git a/lib/browser/api/menu-item.ts b/lib/browser/api/menu-item.ts index ae74948064a..1ff4836caf3 100644 --- a/lib/browser/api/menu-item.ts +++ b/lib/browser/api/menu-item.ts @@ -1,4 +1,5 @@ import * as roles from '@electron/internal/browser/api/menu-item-roles'; + import { Menu, BaseWindow, WebContents, KeyboardEvent } from 'electron/main'; let nextCommandId = 0; diff --git a/lib/browser/api/menu.ts b/lib/browser/api/menu.ts index 48a7f475b1c..c0244cc3c1b 100644 --- a/lib/browser/api/menu.ts +++ b/lib/browser/api/menu.ts @@ -1,7 +1,8 @@ -import { BaseWindow, MenuItem, webContents, Menu as MenuType, MenuItemConstructorOptions } from 'electron/main'; import { sortMenuItems } from '@electron/internal/browser/api/menu-utils'; import { setApplicationMenuWasSet } from '@electron/internal/browser/default-menu'; +import { BaseWindow, MenuItem, webContents, Menu as MenuType, MenuItemConstructorOptions } from 'electron/main'; + const bindings = process._linkedBinding('electron_browser_menu'); const { Menu } = bindings as { Menu: typeof MenuType }; diff --git a/lib/browser/api/message-channel.ts b/lib/browser/api/message-channel.ts index 93fe3e83fcd..1a6b967e35e 100644 --- a/lib/browser/api/message-channel.ts +++ b/lib/browser/api/message-channel.ts @@ -1,5 +1,7 @@ import { MessagePortMain } from '@electron/internal/browser/message-port-main'; + import { EventEmitter } from 'events'; + const { createPair } = process._linkedBinding('electron_browser_message_port'); export default class MessageChannelMain extends EventEmitter implements Electron.MessageChannelMain { diff --git a/lib/browser/api/net-fetch.ts b/lib/browser/api/net-fetch.ts index 4f44f2cc422..54fdc788d6c 100644 --- a/lib/browser/api/net-fetch.ts +++ b/lib/browser/api/net-fetch.ts @@ -1,7 +1,9 @@ -import { ClientRequestConstructorOptions, ClientRequest, IncomingMessage, Session as SessionT } from 'electron/main'; -import { Readable, Writable, isReadable } from 'stream'; import { allowAnyProtocol } from '@electron/internal/common/api/net-client-request'; +import { ClientRequestConstructorOptions, ClientRequest, IncomingMessage, Session as SessionT } from 'electron/main'; + +import { Readable, Writable, isReadable } from 'stream'; + function createDeferredPromise (): { promise: Promise; resolve: (x: T) => void; reject: (e: E) => void; } { let res: (x: T) => void; let rej: (e: E) => void; diff --git a/lib/browser/api/net.ts b/lib/browser/api/net.ts index dd824c990f8..b806aef95e3 100644 --- a/lib/browser/api/net.ts +++ b/lib/browser/api/net.ts @@ -1,6 +1,7 @@ +import { ClientRequest } from '@electron/internal/common/api/net-client-request'; + import { app, IncomingMessage, session } from 'electron/main'; import type { ClientRequestConstructorOptions } from 'electron/main'; -import { ClientRequest } from '@electron/internal/common/api/net-client-request'; const { isOnline } = process._linkedBinding('electron_common_net'); diff --git a/lib/browser/api/protocol.ts b/lib/browser/api/protocol.ts index 1b7f00b433c..cb6a1492eb2 100644 --- a/lib/browser/api/protocol.ts +++ b/lib/browser/api/protocol.ts @@ -1,4 +1,5 @@ import { ProtocolRequest, session } from 'electron/main'; + import { createReadStream } from 'fs'; import { Readable } from 'stream'; import { ReadableStream } from 'stream/web'; diff --git a/lib/browser/api/session.ts b/lib/browser/api/session.ts index 27a2c32f1a9..169f1d1eeab 100644 --- a/lib/browser/api/session.ts +++ b/lib/browser/api/session.ts @@ -1,5 +1,7 @@ import { fetchWithSession } from '@electron/internal/browser/api/net-fetch'; + import { net } from 'electron/main'; + const { fromPartition, fromPath, Session } = process._linkedBinding('electron_browser_session'); const { isDisplayMediaSystemPickerAvailable } = process._linkedBinding('electron_browser_desktop_capturer'); diff --git a/lib/browser/api/share-menu.ts b/lib/browser/api/share-menu.ts index 1a339a16614..a296500390c 100644 --- a/lib/browser/api/share-menu.ts +++ b/lib/browser/api/share-menu.ts @@ -1,4 +1,5 @@ import { BrowserWindow, Menu, SharingItem, PopupOptions } from 'electron/main'; + import { EventEmitter } from 'events'; class ShareMenu extends EventEmitter implements Electron.ShareMenu { diff --git a/lib/browser/api/system-preferences.ts b/lib/browser/api/system-preferences.ts index 33c1a4eb7db..b5485a7361a 100644 --- a/lib/browser/api/system-preferences.ts +++ b/lib/browser/api/system-preferences.ts @@ -1,4 +1,5 @@ import * as deprecate from '@electron/internal/common/deprecate'; + const { systemPreferences } = process._linkedBinding('electron_browser_system_preferences'); if ('getEffectiveAppearance' in systemPreferences) { diff --git a/lib/browser/api/utility-process.ts b/lib/browser/api/utility-process.ts index bee8f1032aa..626ba1643cd 100644 --- a/lib/browser/api/utility-process.ts +++ b/lib/browser/api/utility-process.ts @@ -1,7 +1,9 @@ -import { EventEmitter } from 'events'; -import { Duplex, PassThrough } from 'stream'; -import { Socket } from 'net'; import { MessagePortMain } from '@electron/internal/browser/message-port-main'; + +import { EventEmitter } from 'events'; +import { Socket } from 'net'; +import { Duplex, PassThrough } from 'stream'; + const { _fork } = process._linkedBinding('electron_browser_utility_process'); class ForkUtilityProcess extends EventEmitter implements Electron.UtilityProcess { diff --git a/lib/browser/api/view.ts b/lib/browser/api/view.ts index 2cdf5b59046..581b937d7e6 100644 --- a/lib/browser/api/view.ts +++ b/lib/browser/api/view.ts @@ -1,4 +1,5 @@ import { EventEmitter } from 'events'; + const { View } = process._linkedBinding('electron_browser_view'); Object.setPrototypeOf((View as any).prototype, EventEmitter.prototype); diff --git a/lib/browser/api/web-contents.ts b/lib/browser/api/web-contents.ts index 490e2ece801..4bde139eebc 100644 --- a/lib/browser/api/web-contents.ts +++ b/lib/browser/api/web-contents.ts @@ -1,16 +1,17 @@ -import { app, ipcMain, session, webFrameMain, dialog } from 'electron/main'; -import type { BrowserWindowConstructorOptions, MessageBoxOptions } from 'electron/main'; - -import * as url from 'url'; -import * as path from 'path'; import { openGuestWindow, makeWebPreferences, parseContentTypeFormat } from '@electron/internal/browser/guest-window-manager'; -import { parseFeatures } from '@electron/internal/browser/parse-features-string'; +import { IpcMainImpl } from '@electron/internal/browser/ipc-main-impl'; import { ipcMainInternal } from '@electron/internal/browser/ipc-main-internal'; import * as ipcMainUtils from '@electron/internal/browser/ipc-main-internal-utils'; import { MessagePortMain } from '@electron/internal/browser/message-port-main'; -import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; -import { IpcMainImpl } from '@electron/internal/browser/ipc-main-impl'; +import { parseFeatures } from '@electron/internal/browser/parse-features-string'; import * as deprecate from '@electron/internal/common/deprecate'; +import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; + +import { app, ipcMain, session, webFrameMain, dialog } from 'electron/main'; +import type { BrowserWindowConstructorOptions, MessageBoxOptions } from 'electron/main'; + +import * as path from 'path'; +import * as url from 'url'; // session is not used here, the purpose is to make sure session is initialized // before the webContents module. diff --git a/lib/browser/api/web-frame-main.ts b/lib/browser/api/web-frame-main.ts index 9212c797cb0..ce6023f843f 100644 --- a/lib/browser/api/web-frame-main.ts +++ b/lib/browser/api/web-frame-main.ts @@ -1,5 +1,5 @@ -import { MessagePortMain } from '@electron/internal/browser/message-port-main'; import { IpcMainImpl } from '@electron/internal/browser/ipc-main-impl'; +import { MessagePortMain } from '@electron/internal/browser/message-port-main'; const { WebFrameMain, fromId } = process._linkedBinding('electron_browser_web_frame_main'); diff --git a/lib/browser/default-menu.ts b/lib/browser/default-menu.ts index 16eef15fbee..0cef9aa5c8c 100644 --- a/lib/browser/default-menu.ts +++ b/lib/browser/default-menu.ts @@ -1,5 +1,5 @@ -import { app, Menu } from 'electron/main'; import { shell } from 'electron/common'; +import { app, Menu } from 'electron/main'; const isMac = process.platform === 'darwin'; diff --git a/lib/browser/devtools.ts b/lib/browser/devtools.ts index 47e9272a7bf..f9cd52077af 100644 --- a/lib/browser/devtools.ts +++ b/lib/browser/devtools.ts @@ -1,9 +1,10 @@ -import { dialog, Menu } from 'electron/main'; -import * as fs from 'fs'; - +import { IPC_MESSAGES } from '@electron/internal//common/ipc-messages'; import { ipcMainInternal } from '@electron/internal/browser/ipc-main-internal'; import * as ipcMainUtils from '@electron/internal/browser/ipc-main-internal-utils'; -import { IPC_MESSAGES } from '@electron/internal//common/ipc-messages'; + +import { dialog, Menu } from 'electron/main'; + +import * as fs from 'fs'; const convertToMenuTemplate = function (items: ContextMenuItem[], handler: (id: number) => void) { return items.map(function (item) { diff --git a/lib/browser/guest-view-manager.ts b/lib/browser/guest-view-manager.ts index e054409394f..f05d51b8ca4 100644 --- a/lib/browser/guest-view-manager.ts +++ b/lib/browser/guest-view-manager.ts @@ -1,10 +1,11 @@ -import { webContents } from 'electron/main'; import { ipcMainInternal } from '@electron/internal/browser/ipc-main-internal'; import * as ipcMainUtils from '@electron/internal/browser/ipc-main-internal-utils'; import { parseWebViewWebPreferences } from '@electron/internal/browser/parse-features-string'; -import { syncMethods, asyncMethods, properties, navigationHistorySyncMethods } from '@electron/internal/common/web-view-methods'; import { webViewEvents } from '@electron/internal/browser/web-view-events'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; +import { syncMethods, asyncMethods, properties, navigationHistorySyncMethods } from '@electron/internal/common/web-view-methods'; + +import { webContents } from 'electron/main'; interface GuestInstance { elementInstanceId: number; diff --git a/lib/browser/guest-window-manager.ts b/lib/browser/guest-window-manager.ts index 65526e1c5a9..3f7ddc30366 100644 --- a/lib/browser/guest-window-manager.ts +++ b/lib/browser/guest-window-manager.ts @@ -5,9 +5,10 @@ * out-of-process (cross-origin) are created here. "Embedder" roughly means * "parent." */ +import { parseFeatures } from '@electron/internal/browser/parse-features-string'; + import { BrowserWindow } from 'electron/main'; import type { BrowserWindowConstructorOptions, Referrer, WebContents, LoadURLOptions } from 'electron/main'; -import { parseFeatures } from '@electron/internal/browser/parse-features-string'; type PostData = LoadURLOptions['postData'] export type WindowOpenArgs = { diff --git a/lib/browser/init.ts b/lib/browser/init.ts index 39fdc8cf80d..50327911aac 100644 --- a/lib/browser/init.ts +++ b/lib/browser/init.ts @@ -1,8 +1,9 @@ +import type * as defaultMenuModule from '@electron/internal/browser/default-menu'; + import { EventEmitter } from 'events'; import * as fs from 'fs'; import * as path from 'path'; -import type * as defaultMenuModule from '@electron/internal/browser/default-menu'; import type * as url from 'url'; import type * as v8 from 'v8'; diff --git a/lib/browser/ipc-main-impl.ts b/lib/browser/ipc-main-impl.ts index f3088d93a5a..e80739104b9 100644 --- a/lib/browser/ipc-main-impl.ts +++ b/lib/browser/ipc-main-impl.ts @@ -1,6 +1,7 @@ -import { EventEmitter } from 'events'; import { IpcMainInvokeEvent } from 'electron/main'; +import { EventEmitter } from 'events'; + export class IpcMainImpl extends EventEmitter implements Electron.IpcMain { private _invokeHandlers: Map void> = new Map(); diff --git a/lib/browser/rpc-server.ts b/lib/browser/rpc-server.ts index 48e6ca16b59..4eef7baa1f5 100644 --- a/lib/browser/rpc-server.ts +++ b/lib/browser/rpc-server.ts @@ -1,9 +1,11 @@ -import { clipboard } from 'electron/common'; -import * as fs from 'fs'; import { ipcMainInternal } from '@electron/internal/browser/ipc-main-internal'; import * as ipcMainUtils from '@electron/internal/browser/ipc-main-internal-utils'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; +import { clipboard } from 'electron/common'; + +import * as fs from 'fs'; + // Implements window.close() ipcMainInternal.on(IPC_MESSAGES.BROWSER_WINDOW_CLOSE, function (event) { const window = event.sender.getOwnerBrowserWindow(); diff --git a/lib/common/api/net-client-request.ts b/lib/common/api/net-client-request.ts index 05622af6a8f..1a087ae4764 100644 --- a/lib/common/api/net-client-request.ts +++ b/lib/common/api/net-client-request.ts @@ -1,10 +1,11 @@ -import * as url from 'url'; -import { Readable, Writable } from 'stream'; import type { ClientRequestConstructorOptions, UploadProgress } from 'electron/common'; +import { Readable, Writable } from 'stream'; +import * as url from 'url'; + const { isValidHeaderName, isValidHeaderValue, diff --git a/lib/common/init.ts b/lib/common/init.ts index 9032ed9994b..d6ad120eb93 100644 --- a/lib/common/init.ts +++ b/lib/common/init.ts @@ -1,7 +1,7 @@ -import * as util from 'util'; -import type * as stream from 'stream'; - import timers = require('timers'); +import * as util from 'util'; + +import type * as stream from 'stream'; type AnyFn = (...args: any[]) => any diff --git a/lib/node/init.ts b/lib/node/init.ts index 12c908a6073..8857eabb6bb 100644 --- a/lib/node/init.ts +++ b/lib/node/init.ts @@ -1,3 +1,5 @@ +/* eslint-disable import/newline-after-import */ +/* eslint-disable import/order */ // Initialize ASAR support in fs module. import { wrapFsWithAsar } from './asar-fs-wrapper'; wrapFsWithAsar(require('fs')); diff --git a/lib/renderer/api/exports/electron.ts b/lib/renderer/api/exports/electron.ts index 13ea2fc57a2..d50bc9edbd9 100644 --- a/lib/renderer/api/exports/electron.ts +++ b/lib/renderer/api/exports/electron.ts @@ -1,5 +1,5 @@ -import { defineProperties } from '@electron/internal/common/define-properties'; import { commonModuleList } from '@electron/internal/common/api/module-list'; +import { defineProperties } from '@electron/internal/common/define-properties'; import { rendererModuleList } from '@electron/internal/renderer/api/module-list'; module.exports = {}; diff --git a/lib/renderer/common-init.ts b/lib/renderer/common-init.ts index 4910ca66716..c944125f9fe 100644 --- a/lib/renderer/common-init.ts +++ b/lib/renderer/common-init.ts @@ -1,10 +1,10 @@ -import { ipcRenderer } from 'electron/renderer'; import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; - +import type * as securityWarningsModule from '@electron/internal/renderer/security-warnings'; +import type * as webFrameInitModule from '@electron/internal/renderer/web-frame-init'; import type * as webViewInitModule from '@electron/internal/renderer/web-view/web-view-init'; import type * as windowSetupModule from '@electron/internal/renderer/window-setup'; -import type * as webFrameInitModule from '@electron/internal/renderer/web-frame-init'; -import type * as securityWarningsModule from '@electron/internal/renderer/security-warnings'; + +import { ipcRenderer } from 'electron/renderer'; const { mainFrame } = process._linkedBinding('electron_renderer_web_frame'); const v8Util = process._linkedBinding('electron_common_v8_util'); @@ -49,6 +49,7 @@ if (process.isMainFrame) { } const { webFrameInit } = require('@electron/internal/renderer/web-frame-init') as typeof webFrameInitModule; + webFrameInit(); // Warn about security issues diff --git a/lib/renderer/init.ts b/lib/renderer/init.ts index 8be38b26e5f..7d53e0b7920 100644 --- a/lib/renderer/init.ts +++ b/lib/renderer/init.ts @@ -1,10 +1,10 @@ -import * as path from 'path'; -import { pathToFileURL } from 'url'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; - import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal'; import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils'; +import * as path from 'path'; +import { pathToFileURL } from 'url'; + const Module = require('module') as NodeJS.ModuleInternal; // We do not want to allow use of the VM module in the renderer process as diff --git a/lib/renderer/inspector.ts b/lib/renderer/inspector.ts index 8dd941d3061..023c4ee36b4 100644 --- a/lib/renderer/inspector.ts +++ b/lib/renderer/inspector.ts @@ -1,8 +1,9 @@ +import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; import { internalContextBridge } from '@electron/internal/renderer/api/context-bridge'; import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; import * as ipcRendererUtils from '@electron/internal/renderer/ipc-renderer-internal-utils'; + import { webFrame } from 'electron/renderer'; -import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; const { contextIsolationEnabled } = internalContextBridge; diff --git a/lib/renderer/security-warnings.ts b/lib/renderer/security-warnings.ts index 619641d20ed..1065048a459 100644 --- a/lib/renderer/security-warnings.ts +++ b/lib/renderer/security-warnings.ts @@ -1,5 +1,5 @@ -import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; +import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; const { mainFrame: webFrame } = process._linkedBinding('electron_renderer_web_frame'); diff --git a/lib/renderer/web-frame-init.ts b/lib/renderer/web-frame-init.ts index ac4db7f9a74..47bf2ea2812 100644 --- a/lib/renderer/web-frame-init.ts +++ b/lib/renderer/web-frame-init.ts @@ -1,6 +1,7 @@ -import { webFrame, WebFrame } from 'electron/renderer'; -import * as ipcRendererUtils from '@electron/internal/renderer/ipc-renderer-internal-utils'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; +import * as ipcRendererUtils from '@electron/internal/renderer/ipc-renderer-internal-utils'; + +import { webFrame, WebFrame } from 'electron/renderer'; // All keys of WebFrame that extend Function type WebFrameMethod = { diff --git a/lib/renderer/web-view/guest-view-internal.ts b/lib/renderer/web-view/guest-view-internal.ts index e6d25d51790..ba38adfefa5 100644 --- a/lib/renderer/web-view/guest-view-internal.ts +++ b/lib/renderer/web-view/guest-view-internal.ts @@ -1,6 +1,6 @@ +import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; import * as ipcRendererUtils from '@electron/internal/renderer/ipc-renderer-internal-utils'; -import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; const { mainFrame: webFrame } = process._linkedBinding('electron_renderer_web_frame'); diff --git a/lib/renderer/web-view/web-view-attributes.ts b/lib/renderer/web-view/web-view-attributes.ts index 66d17209a22..18cc238d3f4 100644 --- a/lib/renderer/web-view/web-view-attributes.ts +++ b/lib/renderer/web-view/web-view-attributes.ts @@ -1,5 +1,5 @@ -import type { WebViewImpl } from '@electron/internal/renderer/web-view/web-view-impl'; import { WEB_VIEW_ATTRIBUTES, WEB_VIEW_ERROR_MESSAGES } from '@electron/internal/renderer/web-view/web-view-constants'; +import type { WebViewImpl } from '@electron/internal/renderer/web-view/web-view-impl'; const resolveURL = function (url?: string | null) { return url ? new URL(url, location.href).href : ''; diff --git a/lib/renderer/web-view/web-view-element.ts b/lib/renderer/web-view/web-view-element.ts index 7d2dd14a3f3..6f641976986 100644 --- a/lib/renderer/web-view/web-view-element.ts +++ b/lib/renderer/web-view/web-view-element.ts @@ -8,9 +8,9 @@ // which runs in browserify environment instead of Node environment, all native // modules must be passed from outside, all included files must be plain JS. +import type { SrcAttribute } from '@electron/internal/renderer/web-view/web-view-attributes'; import { WEB_VIEW_ATTRIBUTES, WEB_VIEW_ERROR_MESSAGES } from '@electron/internal/renderer/web-view/web-view-constants'; import { WebViewImpl, WebViewImplHooks, setupMethods } from '@electron/internal/renderer/web-view/web-view-impl'; -import type { SrcAttribute } from '@electron/internal/renderer/web-view/web-view-attributes'; const internals = new WeakMap(); diff --git a/lib/renderer/web-view/web-view-impl.ts b/lib/renderer/web-view/web-view-impl.ts index f5ca329d638..a82e86af439 100644 --- a/lib/renderer/web-view/web-view-impl.ts +++ b/lib/renderer/web-view/web-view-impl.ts @@ -1,8 +1,8 @@ -import type * as guestViewInternalModule from '@electron/internal/renderer/web-view/guest-view-internal'; -import { WEB_VIEW_ATTRIBUTES } from '@electron/internal/renderer/web-view/web-view-constants'; import { syncMethods, asyncMethods, properties } from '@electron/internal/common/web-view-methods'; +import type * as guestViewInternalModule from '@electron/internal/renderer/web-view/guest-view-internal'; import type { WebViewAttribute, PartitionAttribute } from '@electron/internal/renderer/web-view/web-view-attributes'; import { setupWebViewAttributes } from '@electron/internal/renderer/web-view/web-view-attributes'; +import { WEB_VIEW_ATTRIBUTES } from '@electron/internal/renderer/web-view/web-view-constants'; // ID generator. let nextId = 0; diff --git a/lib/renderer/web-view/web-view-init.ts b/lib/renderer/web-view/web-view-init.ts index 29ca6cc959f..c918800273a 100644 --- a/lib/renderer/web-view/web-view-init.ts +++ b/lib/renderer/web-view/web-view-init.ts @@ -1,8 +1,7 @@ -import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; - -import type * as webViewElementModule from '@electron/internal/renderer/web-view/web-view-element'; +import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; import type * as guestViewInternalModule from '@electron/internal/renderer/web-view/guest-view-internal'; +import type * as webViewElementModule from '@electron/internal/renderer/web-view/web-view-element'; const v8Util = process._linkedBinding('electron_common_v8_util'); const { mainFrame: webFrame } = process._linkedBinding('electron_renderer_web_frame'); diff --git a/lib/renderer/window-setup.ts b/lib/renderer/window-setup.ts index 9dc539edb6a..9f48ea3941e 100644 --- a/lib/renderer/window-setup.ts +++ b/lib/renderer/window-setup.ts @@ -1,6 +1,6 @@ -import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; -import { internalContextBridge } from '@electron/internal/renderer/api/context-bridge'; import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; +import { internalContextBridge } from '@electron/internal/renderer/api/context-bridge'; +import { ipcRendererInternal } from '@electron/internal/renderer/ipc-renderer-internal'; const { contextIsolationEnabled } = internalContextBridge; diff --git a/lib/sandboxed_renderer/init.ts b/lib/sandboxed_renderer/init.ts index 83ddf4a1bd6..6762945a628 100644 --- a/lib/sandboxed_renderer/init.ts +++ b/lib/sandboxed_renderer/init.ts @@ -1,9 +1,9 @@ +import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; +import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal'; +import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils'; + import * as events from 'events'; import { setImmediate, clearImmediate } from 'timers'; -import { IPC_MESSAGES } from '@electron/internal/common/ipc-messages'; - -import type * as ipcRendererUtilsModule from '@electron/internal/renderer/ipc-renderer-internal-utils'; -import type * as ipcRendererInternalModule from '@electron/internal/renderer/ipc-renderer-internal'; declare const binding: { get: (name: string) => any; diff --git a/lib/utility/api/net.ts b/lib/utility/api/net.ts index b5237e8233f..70228ee0e5f 100644 --- a/lib/utility/api/net.ts +++ b/lib/utility/api/net.ts @@ -1,7 +1,8 @@ +import { fetchWithSession } from '@electron/internal/browser/api/net-fetch'; +import { ClientRequest } from '@electron/internal/common/api/net-client-request'; + import { IncomingMessage } from 'electron/utility'; import type { ClientRequestConstructorOptions } from 'electron/utility'; -import { ClientRequest } from '@electron/internal/common/api/net-client-request'; -import { fetchWithSession } from '@electron/internal/browser/api/net-fetch'; const { isOnline, resolveHost } = process._linkedBinding('electron_common_net'); diff --git a/lib/utility/init.ts b/lib/utility/init.ts index ddd935f483a..1c7e5e8a4b4 100644 --- a/lib/utility/init.ts +++ b/lib/utility/init.ts @@ -1,8 +1,8 @@ +import { ParentPort } from '@electron/internal/utility/parent-port'; + import { EventEmitter } from 'events'; import { pathToFileURL } from 'url'; -import { ParentPort } from '@electron/internal/utility/parent-port'; - const v8Util = process._linkedBinding('electron_common_v8_util'); const entryScript: string = v8Util.getHiddenValue(process, '_serviceStartupScript'); diff --git a/lib/utility/parent-port.ts b/lib/utility/parent-port.ts index 1ce54aac5d6..3cb484e3ad9 100644 --- a/lib/utility/parent-port.ts +++ b/lib/utility/parent-port.ts @@ -1,5 +1,7 @@ -import { EventEmitter } from 'events'; import { MessagePortMain } from '@electron/internal/browser/message-port-main'; + +import { EventEmitter } from 'events'; + const { createParentPort } = process._linkedBinding('electron_utility_parent_port'); export class ParentPort extends EventEmitter implements Electron.ParentPort { diff --git a/npm/cli.js b/npm/cli.js index 09f4677bc93..7dbb3d5a3c0 100755 --- a/npm/cli.js +++ b/npm/cli.js @@ -1,9 +1,9 @@ #!/usr/bin/env node -const electron = require('./'); - const proc = require('child_process'); +const electron = require('./'); + const child = proc.spawn(electron, process.argv.slice(2), { stdio: 'inherit', windowsHide: false }); child.on('close', function (code, signal) { if (code === null) { diff --git a/npm/install.js b/npm/install.js index fcd76531336..a0c177dea41 100755 --- a/npm/install.js +++ b/npm/install.js @@ -1,13 +1,15 @@ #!/usr/bin/env node -const { version } = require('./package'); +const { downloadArtifact } = require('@electron/get'); + +const extract = require('extract-zip'); const childProcess = require('child_process'); const fs = require('fs'); const os = require('os'); const path = require('path'); -const extract = require('extract-zip'); -const { downloadArtifact } = require('@electron/get'); + +const { version } = require('./package'); if (process.env.ELECTRON_SKIP_BINARY_DOWNLOAD) { process.exit(0); diff --git a/script/create-api-json.js b/script/create-api-json.js index 4f3b5ecfc22..26198efc26d 100644 --- a/script/create-api-json.js +++ b/script/create-api-json.js @@ -1,4 +1,5 @@ const { parseDocs } = require('@electron/docs-parser'); + const fs = require('node:fs'); const path = require('node:path'); diff --git a/script/doc-only-change.js b/script/doc-only-change.js index ace463d484d..20333382e6e 100644 --- a/script/doc-only-change.js +++ b/script/doc-only-change.js @@ -1,5 +1,8 @@ -const args = require('minimist')(process.argv.slice(2)); const { Octokit } = require('@octokit/rest'); +const minimist = require('minimist'); + +const args = minimist(process.argv.slice(2)); + const octokit = new Octokit(); async function checkIfDocOnlyChange () { diff --git a/script/generate-version-json.js b/script/generate-version-json.js index dcd69e2d11d..df01d640bc4 100644 --- a/script/generate-version-json.js +++ b/script/generate-version-json.js @@ -1,6 +1,7 @@ -const fs = require('node:fs'); const semver = require('semver'); +const fs = require('node:fs'); + const outputPath = process.argv[2]; const currentVersion = process.argv[3]; diff --git a/script/gn-asar-hash.js b/script/gn-asar-hash.js index ad341cb2cd9..86337d669ec 100644 --- a/script/gn-asar-hash.js +++ b/script/gn-asar-hash.js @@ -1,4 +1,5 @@ const asar = require('@electron/asar'); + const crypto = require('node:crypto'); const fs = require('node:fs'); diff --git a/script/gn-asar.js b/script/gn-asar.js index 29a1b99108e..717f7aaa2c1 100644 --- a/script/gn-asar.js +++ b/script/gn-asar.js @@ -1,4 +1,5 @@ const asar = require('@electron/asar'); + const assert = require('node:assert'); const fs = require('node:fs'); const os = require('node:os'); diff --git a/script/gn-check.js b/script/gn-check.js index a437fbab4db..542b1fbdeb7 100644 --- a/script/gn-check.js +++ b/script/gn-check.js @@ -4,9 +4,12 @@ Usage: $ node ./script/gn-check.js [--outDir=dirName] */ +const minimist = require('minimist'); + const cp = require('node:child_process'); const path = require('node:path'); -const args = require('minimist')(process.argv.slice(2), { string: ['outDir'] }); + +const args = minimist(process.argv.slice(2), { string: ['outDir'] }); const { getOutDir } = require('./lib/utils'); diff --git a/script/lib/azput.js b/script/lib/azput.js index 3879c4feb4a..c2a986e424f 100644 --- a/script/lib/azput.js +++ b/script/lib/azput.js @@ -1,5 +1,8 @@ /* eslint-disable camelcase */ + const { BlobServiceClient } = require('@azure/storage-blob'); +const minimist = require('minimist'); + const path = require('node:path'); const { ELECTRON_ARTIFACTS_BLOB_STORAGE } = process.env; @@ -10,7 +13,7 @@ if (!ELECTRON_ARTIFACTS_BLOB_STORAGE) { const blobServiceClient = BlobServiceClient.fromConnectionString(ELECTRON_ARTIFACTS_BLOB_STORAGE); -const args = require('minimist')(process.argv.slice(2)); +const args = minimist(process.argv.slice(2)); let { prefix = '/', key_prefix = '', _: files } = args; if (prefix && !prefix.endsWith(path.sep)) prefix = path.resolve(prefix) + path.sep; diff --git a/script/lib/utils.js b/script/lib/utils.js index 3684812ecd3..25521af9b4d 100644 --- a/script/lib/utils.js +++ b/script/lib/utils.js @@ -1,5 +1,6 @@ const chalk = require('chalk'); const { GitProcess } = require('dugite'); + const fs = require('node:fs'); const os = require('node:os'); const path = require('node:path'); diff --git a/script/lint.js b/script/lint.js index 25f4642cb3d..20a2da96f5c 100755 --- a/script/lint.js +++ b/script/lint.js @@ -1,14 +1,16 @@ #!/usr/bin/env node -const crypto = require('node:crypto'); -const { GitProcess } = require('dugite'); -const childProcess = require('node:child_process'); -const { ESLint } = require('eslint'); -const fs = require('node:fs'); -const minimist = require('minimist'); -const path = require('node:path'); const { getCodeBlocks } = require('@electron/lint-roller/dist/lib/markdown'); +const { GitProcess } = require('dugite'); +const { ESLint } = require('eslint'); +const minimist = require('minimist'); + +const childProcess = require('node:child_process'); +const crypto = require('node:crypto'); +const fs = require('node:fs'); +const path = require('node:path'); + const { chunkFilenames, findMatchingFiles } = require('./lib/utils'); const ELECTRON_ROOT = path.normalize(path.dirname(__dirname)); diff --git a/script/nan-spec-runner.js b/script/nan-spec-runner.js index 858ab66a0be..c10ed6e9094 100644 --- a/script/nan-spec-runner.js +++ b/script/nan-spec-runner.js @@ -1,3 +1,5 @@ +const minimist = require('minimist'); + const cp = require('node:child_process'); const fs = require('node:fs'); const path = require('node:path'); @@ -13,7 +15,7 @@ if (!require.main) { throw new Error('Must call the nan spec runner directly'); } -const args = require('minimist')(process.argv.slice(2), { +const args = minimist(process.argv.slice(2), { string: ['only'] }); diff --git a/script/node-spec-runner.js b/script/node-spec-runner.js index 3d904e9a669..60564137910 100644 --- a/script/node-spec-runner.js +++ b/script/node-spec-runner.js @@ -1,20 +1,23 @@ +const minimist = require('minimist'); + const cp = require('node:child_process'); const fs = require('node:fs'); const path = require('node:path'); -const args = require('minimist')(process.argv.slice(2), { +const utils = require('./lib/utils'); +const DISABLED_TESTS = require('./node-disabled-tests.json'); + +const args = minimist(process.argv.slice(2), { boolean: ['default', 'validateDisabled'], string: ['jUnitDir'] }); const BASE = path.resolve(__dirname, '../..'); -const DISABLED_TESTS = require('./node-disabled-tests.json'); + const NODE_DIR = path.resolve(BASE, 'third_party', 'electron_node'); const JUNIT_DIR = args.jUnitDir ? path.resolve(args.jUnitDir) : null; const TAP_FILE_NAME = 'test.tap'; -const utils = require('./lib/utils'); - if (!require.main) { throw new Error('Must call the node spec runner directly'); } diff --git a/script/prepare-appveyor.js b/script/prepare-appveyor.js index 9c9591ae860..d1f61040046 100644 --- a/script/prepare-appveyor.js +++ b/script/prepare-appveyor.js @@ -1,9 +1,12 @@ +const { Octokit } = require('@octokit/rest'); +const got = require('got'); + const assert = require('node:assert'); const fs = require('node:fs'); -const got = require('got'); const path = require('node:path'); + const { handleGitCall, ELECTRON_DIR } = require('./lib/utils.js'); -const { Octokit } = require('@octokit/rest'); + const octokit = new Octokit(); const APPVEYOR_IMAGES_URL = 'https://ci.appveyor.com/api/build-clouds'; diff --git a/script/push-patch.js b/script/push-patch.js index 8a0296c4b9b..b32f46c3eba 100644 --- a/script/push-patch.js +++ b/script/push-patch.js @@ -1,4 +1,5 @@ const { appCredentialsFromString, getTokenForRepo } = require('@electron/github-app-auth'); + const cp = require('node:child_process'); async function main () { diff --git a/script/release/bin/cleanup-release.ts b/script/release/bin/cleanup-release.ts index 8f1420d2e3d..a659031c39c 100644 --- a/script/release/bin/cleanup-release.ts +++ b/script/release/bin/cleanup-release.ts @@ -1,4 +1,5 @@ import { parseArgs } from 'node:util'; + import { cleanReleaseArtifacts } from '../release-artifact-cleanup'; const { values: { tag: _tag, releaseID } } = parseArgs({ diff --git a/script/release/bin/publish-to-npm.ts b/script/release/bin/publish-to-npm.ts index 9026384cb28..484bece93c6 100644 --- a/script/release/bin/publish-to-npm.ts +++ b/script/release/bin/publish-to-npm.ts @@ -1,13 +1,13 @@ import { Octokit } from '@octokit/rest'; -import * as childProcess from 'node:child_process'; -import * as fs from 'node:fs'; -import * as path from 'node:path'; import * as semver from 'semver'; import * as temp from 'temp'; -import { getCurrentBranch, ELECTRON_DIR } from '../../lib/utils'; -import { getElectronVersion } from '../../lib/get-version'; +import * as childProcess from 'node:child_process'; +import * as fs from 'node:fs'; +import * as path from 'node:path'; +import { getElectronVersion } from '../../lib/get-version'; +import { getCurrentBranch, ELECTRON_DIR } from '../../lib/utils'; import { getAssetContents } from '../get-asset'; import { createGitHubTokenStrategy } from '../github-token'; import { ELECTRON_ORG, ELECTRON_REPO, ElectronReleaseRepo, NIGHTLY_REPO } from '../types'; diff --git a/script/release/find-github-release.ts b/script/release/find-github-release.ts index 4b625a05b11..830501e7e06 100644 --- a/script/release/find-github-release.ts +++ b/script/release/find-github-release.ts @@ -1,4 +1,5 @@ import { Octokit } from '@octokit/rest'; + import { createGitHubTokenStrategy } from './github-token'; import { ELECTRON_ORG, ELECTRON_REPO, ElectronReleaseRepo, NIGHTLY_REPO } from './types'; diff --git a/script/release/get-asset.ts b/script/release/get-asset.ts index 0a129f84c35..bc0ca69343d 100644 --- a/script/release/get-asset.ts +++ b/script/release/get-asset.ts @@ -1,5 +1,6 @@ import { Octokit } from '@octokit/rest'; import got from 'got'; + import { createGitHubTokenStrategy } from './github-token'; import { ELECTRON_ORG, ElectronReleaseRepo } from './types'; diff --git a/script/release/get-url-hash.ts b/script/release/get-url-hash.ts index 19e3fb3a6ce..b4fc10b053b 100644 --- a/script/release/get-url-hash.ts +++ b/script/release/get-url-hash.ts @@ -1,4 +1,5 @@ import got from 'got'; + import * as url from 'node:url'; const HASHER_FUNCTION_HOST = 'electron-artifact-hasher.azurewebsites.net'; diff --git a/script/release/notes/index.ts b/script/release/notes/index.ts index d993d1ba1d4..a6e7ebf01c3 100755 --- a/script/release/notes/index.ts +++ b/script/release/notes/index.ts @@ -1,15 +1,15 @@ #!/usr/bin/env node +import { Octokit } from '@octokit/rest'; import { GitProcess } from 'dugite'; -import { basename } from 'node:path'; import { valid, compare, gte, lte } from 'semver'; -import { ELECTRON_DIR } from '../../lib/utils'; -import { get, render } from './notes'; - -import { Octokit } from '@octokit/rest'; -import { createGitHubTokenStrategy } from '../github-token'; +import { basename } from 'node:path'; import { parseArgs } from 'node:util'; + +import { get, render } from './notes'; +import { ELECTRON_DIR } from '../../lib/utils'; +import { createGitHubTokenStrategy } from '../github-token'; import { ELECTRON_ORG, ELECTRON_REPO } from '../types'; const octokit = new Octokit({ diff --git a/script/release/notes/notes.ts b/script/release/notes/notes.ts index 7e73d5203c5..2c5e97f3334 100644 --- a/script/release/notes/notes.ts +++ b/script/release/notes/notes.ts @@ -1,11 +1,11 @@ #!/usr/bin/env node -import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'node:fs'; -import { resolve as _resolve } from 'node:path'; - import { Octokit } from '@octokit/rest'; import { GitProcess } from 'dugite'; +import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'node:fs'; +import { resolve as _resolve } from 'node:path'; + import { ELECTRON_DIR } from '../../lib/utils'; import { createGitHubTokenStrategy } from '../github-token'; import { ELECTRON_ORG, ELECTRON_REPO } from '../types'; diff --git a/script/release/prepare-release.ts b/script/release/prepare-release.ts index 269e3ea7ed8..b58e476369f 100755 --- a/script/release/prepare-release.ts +++ b/script/release/prepare-release.ts @@ -1,14 +1,15 @@ import { Octokit } from '@octokit/rest'; import * as chalk from 'chalk'; import { GitProcess } from 'dugite'; + import { execSync } from 'node:child_process'; import { join } from 'node:path'; -import { runReleaseCIJobs } from './run-release-ci-jobs'; -import releaseNotesGenerator from './notes'; -import { getCurrentBranch, ELECTRON_DIR } from '../lib/utils.js'; import { createGitHubTokenStrategy } from './github-token'; +import releaseNotesGenerator from './notes'; +import { runReleaseCIJobs } from './run-release-ci-jobs'; import { ELECTRON_ORG, ElectronReleaseRepo, VersionBumpType } from './types'; +import { getCurrentBranch, ELECTRON_DIR } from '../lib/utils.js'; const pass = chalk.green('✓'); const fail = chalk.red('✗'); diff --git a/script/release/release.ts b/script/release/release.ts index 4fc9d1396c6..1438577fae8 100755 --- a/script/release/release.ts +++ b/script/release/release.ts @@ -4,17 +4,18 @@ import { BlobServiceClient } from '@azure/storage-blob'; import { Octokit } from '@octokit/rest'; import * as chalk from 'chalk'; import got from 'got'; -import { execSync, ExecSyncOptions } from 'node:child_process'; -import { statSync, createReadStream, writeFileSync, close } from 'node:fs'; -import { join } from 'node:path'; import { gte } from 'semver'; import { track as trackTemp } from 'temp'; -import { ELECTRON_DIR } from '../lib/utils'; -import { getElectronVersion } from '../lib/get-version'; +import { execSync, ExecSyncOptions } from 'node:child_process'; +import { statSync, createReadStream, writeFileSync, close } from 'node:fs'; +import { join } from 'node:path'; + import { getUrlHash } from './get-url-hash'; import { createGitHubTokenStrategy } from './github-token'; import { ELECTRON_ORG, ELECTRON_REPO, ElectronReleaseRepo, NIGHTLY_REPO } from './types'; +import { getElectronVersion } from '../lib/get-version'; +import { ELECTRON_DIR } from '../lib/utils'; const temp = trackTemp(); diff --git a/script/release/run-release-ci-jobs.ts b/script/release/run-release-ci-jobs.ts index 6799314f24a..c4f6acc5ef5 100644 --- a/script/release/run-release-ci-jobs.ts +++ b/script/release/run-release-ci-jobs.ts @@ -1,5 +1,6 @@ import { Octokit } from '@octokit/rest'; import got, { OptionsOfTextResponseBody } from 'got'; + import * as assert from 'node:assert'; import { createGitHubTokenStrategy } from './github-token'; diff --git a/script/release/uploaders/upload-to-github.ts b/script/release/uploaders/upload-to-github.ts index 43a1dcbf240..b801ded782a 100644 --- a/script/release/uploaders/upload-to-github.ts +++ b/script/release/uploaders/upload-to-github.ts @@ -1,5 +1,7 @@ import { Octokit } from '@octokit/rest'; + import * as fs from 'node:fs'; + import { createGitHubTokenStrategy } from '../github-token'; import { ELECTRON_ORG, ELECTRON_REPO, ElectronReleaseRepo, NIGHTLY_REPO } from '../types'; diff --git a/script/release/version-bumper.ts b/script/release/version-bumper.ts index ef86e222989..c7ae8bb0525 100644 --- a/script/release/version-bumper.ts +++ b/script/release/version-bumper.ts @@ -2,7 +2,9 @@ import { valid, coerce, inc } from 'semver'; -import { getElectronVersion } from '../lib/get-version'; +import { parseArgs } from 'node:util'; + +import { VersionBumpType } from './types'; import { isNightly, isAlpha, @@ -12,8 +14,7 @@ import { nextBeta, isStable } from './version-utils'; -import { VersionBumpType } from './types'; -import { parseArgs } from 'node:util'; +import { getElectronVersion } from '../lib/get-version'; // run the script async function main () { diff --git a/script/release/version-utils.ts b/script/release/version-utils.ts index 8ebb22e38b2..67ffac650d8 100644 --- a/script/release/version-utils.ts +++ b/script/release/version-utils.ts @@ -1,5 +1,5 @@ -import * as semver from 'semver'; import { GitProcess } from 'dugite'; +import * as semver from 'semver'; import { ELECTRON_DIR } from '../lib/utils'; diff --git a/script/run-clang-tidy.ts b/script/run-clang-tidy.ts index 6a5ba9c2c79..b4a544da2e9 100644 --- a/script/run-clang-tidy.ts +++ b/script/run-clang-tidy.ts @@ -1,13 +1,14 @@ -import * as childProcess from 'node:child_process'; -import * as fs from 'node:fs'; import * as minimist from 'minimist'; -import * as os from 'node:os'; -import * as path from 'node:path'; import * as streamChain from 'stream-chain'; import * as streamJson from 'stream-json'; import { ignore as streamJsonIgnore } from 'stream-json/filters/Ignore'; import { streamArray as streamJsonStreamArray } from 'stream-json/streamers/StreamArray'; +import * as childProcess from 'node:child_process'; +import * as fs from 'node:fs'; +import * as os from 'node:os'; +import * as path from 'node:path'; + import { chunkFilenames, findMatchingFiles } from './lib/utils'; const SOURCE_ROOT = path.normalize(path.dirname(__dirname)); diff --git a/script/spec-runner.js b/script/spec-runner.js index 6937a47dae9..e506d9b0e0b 100755 --- a/script/spec-runner.js +++ b/script/spec-runner.js @@ -1,19 +1,23 @@ #!/usr/bin/env node const { ElectronVersions, Installer } = require('@electron/fiddle-core'); + const chalk = require('chalk'); +const { hashElement } = require('folder-hash'); +const minimist = require('minimist'); + const childProcess = require('node:child_process'); const crypto = require('node:crypto'); const fs = require('node:fs'); -const { hashElement } = require('folder-hash'); const os = require('node:os'); const path = require('node:path'); + const unknownFlags = []; const pass = chalk.green('✓'); const fail = chalk.red('✗'); -const args = require('minimist')(process.argv, { +const args = minimist(process.argv, { string: ['runners', 'target', 'electronVersion'], unknown: arg => unknownFlags.push(arg) }); diff --git a/script/split-tests.js b/script/split-tests.js index 43a03977581..d91fa207092 100644 --- a/script/split-tests.js +++ b/script/split-tests.js @@ -1,6 +1,7 @@ -const fs = require('node:fs'); const glob = require('glob'); +const fs = require('node:fs'); + const currentShard = parseInt(process.argv[2], 10); const shardCount = parseInt(process.argv[3], 10); diff --git a/script/start.js b/script/start.js index 6c081a0ccd8..4f158e3f931 100644 --- a/script/start.js +++ b/script/start.js @@ -1,5 +1,7 @@ const cp = require('node:child_process'); + const utils = require('./lib/utils'); + const electronPath = utils.getAbsoluteElectronExec(); const child = cp.spawn(electronPath, process.argv.slice(2), { stdio: 'inherit' }); diff --git a/spec/api-app-spec.ts b/spec/api-app-spec.ts index b9101965f9b..7eb6c4260c8 100644 --- a/spec/api-app-spec.ts +++ b/spec/api-app-spec.ts @@ -1,18 +1,21 @@ +import { app, BrowserWindow, Menu, session, net as electronNet, WebContents, utilityProcess } from 'electron/main'; + import { assert, expect } from 'chai'; +import * as semver from 'semver'; +import split = require('split') + import * as cp from 'node:child_process'; -import * as https from 'node:https'; -import * as http from 'node:http'; -import * as net from 'node:net'; +import { once } from 'node:events'; import * as fs from 'node:fs'; +import * as http from 'node:http'; +import * as https from 'node:https'; +import * as net from 'node:net'; import * as path from 'node:path'; import { promisify } from 'node:util'; -import { app, BrowserWindow, Menu, session, net as electronNet, WebContents, utilityProcess } from 'electron/main'; -import { closeWindow, closeAllWindows } from './lib/window-helpers'; -import { ifdescribe, ifit, listen, waitUntil } from './lib/spec-helpers'; + import { collectStreamBody, getResponse } from './lib/net-helpers'; -import { once } from 'node:events'; -import split = require('split') -import * as semver from 'semver'; +import { ifdescribe, ifit, listen, waitUntil } from './lib/spec-helpers'; +import { closeWindow, closeAllWindows } from './lib/window-helpers'; const fixturesPath = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-auto-updater-spec.ts b/spec/api-auto-updater-spec.ts index e558dbf5175..1174a01fff2 100644 --- a/spec/api-auto-updater-spec.ts +++ b/spec/api-auto-updater-spec.ts @@ -1,8 +1,11 @@ import { autoUpdater } from 'electron/main'; + import { expect } from 'chai'; -import { ifit, ifdescribe } from './lib/spec-helpers'; + import { once } from 'node:events'; +import { ifit, ifdescribe } from './lib/spec-helpers'; + ifdescribe(!process.mas)('autoUpdater module', function () { describe('checkForUpdates', function () { ifit(process.platform === 'win32')('emits an error on Windows if the feed URL is not set', async function () { diff --git a/spec/api-autoupdater-darwin-spec.ts b/spec/api-autoupdater-darwin-spec.ts index e8bc14745b1..24925c503c5 100644 --- a/spec/api-autoupdater-darwin-spec.ts +++ b/spec/api-autoupdater-darwin-spec.ts @@ -1,16 +1,19 @@ -import { expect } from 'chai'; -import * as cp from 'node:child_process'; -import * as http from 'node:http'; -import * as express from 'express'; -import * as fs from 'node:fs'; -import * as path from 'node:path'; -import * as psList from 'ps-list'; -import { AddressInfo } from 'node:net'; -import { ifdescribe, ifit } from './lib/spec-helpers'; -import { copyMacOSFixtureApp, getCodesignIdentity, shouldRunCodesignTests, signApp, spawn } from './lib/codesign-helpers'; -import * as uuid from 'uuid'; import { autoUpdater, systemPreferences } from 'electron'; + +import { expect } from 'chai'; +import * as express from 'express'; +import * as psList from 'ps-list'; +import * as uuid from 'uuid'; + +import * as cp from 'node:child_process'; +import * as fs from 'node:fs'; +import * as http from 'node:http'; +import { AddressInfo } from 'node:net'; +import * as path from 'node:path'; + +import { copyMacOSFixtureApp, getCodesignIdentity, shouldRunCodesignTests, signApp, spawn } from './lib/codesign-helpers'; import { withTempDirectory } from './lib/fs-helpers'; +import { ifdescribe, ifit } from './lib/spec-helpers'; // We can only test the auto updater on darwin non-component builds ifdescribe(shouldRunCodesignTests)('autoUpdater behavior', function () { diff --git a/spec/api-browser-view-spec.ts b/spec/api-browser-view-spec.ts index dc193b083e7..93a0f830a0a 100644 --- a/spec/api-browser-view-spec.ts +++ b/spec/api-browser-view-spec.ts @@ -1,10 +1,13 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; import { BrowserView, BrowserWindow, screen, webContents } from 'electron/main'; -import { closeWindow } from './lib/window-helpers'; -import { defer, ifit, startRemoteControlApp } from './lib/spec-helpers'; -import { ScreenCapture, hasCapturableScreen } from './lib/screen-helpers'; + +import { expect } from 'chai'; + import { once } from 'node:events'; +import * as path from 'node:path'; + +import { ScreenCapture, hasCapturableScreen } from './lib/screen-helpers'; +import { defer, ifit, startRemoteControlApp } from './lib/spec-helpers'; +import { closeWindow } from './lib/window-helpers'; describe('BrowserView module', () => { const fixtures = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-browser-window-spec.ts b/spec/api-browser-window-spec.ts index 0572ec78990..8ef5211bb82 100755 --- a/spec/api-browser-window-spec.ts +++ b/spec/api-browser-window-spec.ts @@ -1,21 +1,23 @@ -import { expect } from 'chai'; -import * as childProcess from 'node:child_process'; -import * as path from 'node:path'; -import * as fs from 'node:fs'; -import * as qs from 'node:querystring'; -import * as http from 'node:http'; -import * as nodeUrl from 'node:url'; -import * as os from 'node:os'; -import { AddressInfo } from 'node:net'; import { app, BrowserWindow, BrowserView, dialog, ipcMain, OnBeforeSendHeadersListenerDetails, net, protocol, screen, webContents, webFrameMain, session, WebContents, WebFrameMain } from 'electron/main'; +import { expect } from 'chai'; + +import * as childProcess from 'node:child_process'; +import { once } from 'node:events'; +import * as fs from 'node:fs'; +import * as http from 'node:http'; +import { AddressInfo } from 'node:net'; +import * as os from 'node:os'; +import * as path from 'node:path'; +import * as qs from 'node:querystring'; +import { setTimeout as syncSetTimeout } from 'node:timers'; +import { setTimeout } from 'node:timers/promises'; +import * as nodeUrl from 'node:url'; + import { emittedUntil, emittedNTimes } from './lib/events-helpers'; +import { HexColors, hasCapturableScreen, ScreenCapture } from './lib/screen-helpers'; import { ifit, ifdescribe, defer, listen } from './lib/spec-helpers'; import { closeWindow, closeAllWindows } from './lib/window-helpers'; -import { HexColors, hasCapturableScreen, ScreenCapture } from './lib/screen-helpers'; -import { once } from 'node:events'; -import { setTimeout } from 'node:timers/promises'; -import { setTimeout as syncSetTimeout } from 'node:timers'; const fixtures = path.resolve(__dirname, 'fixtures'); const mainFixtures = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-clipboard-spec.ts b/spec/api-clipboard-spec.ts index 544b7fe5c47..3befd1a9545 100644 --- a/spec/api-clipboard-spec.ts +++ b/spec/api-clipboard-spec.ts @@ -1,9 +1,12 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; -import { Buffer } from 'node:buffer'; -import { ifdescribe, ifit } from './lib/spec-helpers'; import { clipboard, nativeImage } from 'electron/common'; +import { expect } from 'chai'; + +import { Buffer } from 'node:buffer'; +import * as path from 'node:path'; + +import { ifdescribe, ifit } from './lib/spec-helpers'; + // FIXME(zcbenz): Clipboard tests are failing on WOA. ifdescribe(process.platform !== 'win32' || process.arch !== 'arm64')('clipboard module', () => { const fixtures = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-content-tracing-spec.ts b/spec/api-content-tracing-spec.ts index a026472b7ce..b584b1a8182 100644 --- a/spec/api-content-tracing-spec.ts +++ b/spec/api-content-tracing-spec.ts @@ -1,8 +1,11 @@ -import { expect } from 'chai'; import { app, contentTracing, TraceConfig, TraceCategoriesAndOptions } from 'electron/main'; + +import { expect } from 'chai'; + import * as fs from 'node:fs'; import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; + import { ifdescribe } from './lib/spec-helpers'; // FIXME: The tests are skipped on linux arm/arm64 diff --git a/spec/api-context-bridge-spec.ts b/spec/api-context-bridge-spec.ts index 62609060e8e..d82470ab8bf 100644 --- a/spec/api-context-bridge-spec.ts +++ b/spec/api-context-bridge-spec.ts @@ -1,15 +1,17 @@ import { BrowserWindow, ipcMain } from 'electron/main'; import { contextBridge } from 'electron/renderer'; + import { expect } from 'chai'; + +import * as cp from 'node:child_process'; +import { once } from 'node:events'; import * as fs from 'node:fs'; import * as http from 'node:http'; import * as os from 'node:os'; import * as path from 'node:path'; -import * as cp from 'node:child_process'; -import { closeWindow } from './lib/window-helpers'; import { listen } from './lib/spec-helpers'; -import { once } from 'node:events'; +import { closeWindow } from './lib/window-helpers'; const fixturesPath = path.resolve(__dirname, 'fixtures', 'api', 'context-bridge'); diff --git a/spec/api-crash-reporter-spec.ts b/spec/api-crash-reporter-spec.ts index fe7e7cb5ed8..7dd31a9917d 100644 --- a/spec/api-crash-reporter-spec.ts +++ b/spec/api-crash-reporter-spec.ts @@ -1,15 +1,18 @@ -import { expect } from 'chai'; -import * as childProcess from 'node:child_process'; -import * as http from 'node:http'; -import * as Busboy from 'busboy'; -import * as path from 'node:path'; -import { ifdescribe, ifit, defer, startRemoteControlApp, repeatedly, listen } from './lib/spec-helpers'; import { app } from 'electron/main'; + +import * as Busboy from 'busboy'; +import { expect } from 'chai'; +import * as uuid from 'uuid'; + +import * as childProcess from 'node:child_process'; import { EventEmitter } from 'node:events'; import * as fs from 'node:fs'; -import * as uuid from 'uuid'; +import * as http from 'node:http'; +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import { ifdescribe, ifit, defer, startRemoteControlApp, repeatedly, listen } from './lib/spec-helpers'; + const isWindowsOnArm = process.platform === 'win32' && process.arch === 'arm64'; const isLinuxOnArm = process.platform === 'linux' && process.arch.includes('arm'); diff --git a/spec/api-debugger-spec.ts b/spec/api-debugger-spec.ts index c05644c98fa..b274af9e3ea 100644 --- a/spec/api-debugger-spec.ts +++ b/spec/api-debugger-spec.ts @@ -1,11 +1,14 @@ +import { BrowserWindow } from 'electron/main'; + import { expect } from 'chai'; + +import { once } from 'node:events'; import * as http from 'node:http'; import * as path from 'node:path'; -import { BrowserWindow } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; + import { emittedUntil } from './lib/events-helpers'; import { listen } from './lib/spec-helpers'; -import { once } from 'node:events'; +import { closeAllWindows } from './lib/window-helpers'; describe('debugger module', () => { const fixtures = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-desktop-capturer-spec.ts b/spec/api-desktop-capturer-spec.ts index 5c6eadf0d1b..5bb4943183b 100644 --- a/spec/api-desktop-capturer-spec.ts +++ b/spec/api-desktop-capturer-spec.ts @@ -1,9 +1,11 @@ -import { expect } from 'chai'; import { screen, desktopCapturer, BrowserWindow } from 'electron/main'; + +import { expect } from 'chai'; + import { once } from 'node:events'; import { setTimeout } from 'node:timers/promises'; -import { ifdescribe, ifit } from './lib/spec-helpers'; +import { ifdescribe, ifit } from './lib/spec-helpers'; import { closeAllWindows } from './lib/window-helpers'; ifdescribe(!process.arch.includes('arm') && process.platform !== 'win32')('desktopCapturer', () => { diff --git a/spec/api-dialog-spec.ts b/spec/api-dialog-spec.ts index a375c871647..b38118820e0 100644 --- a/spec/api-dialog-spec.ts +++ b/spec/api-dialog-spec.ts @@ -1,9 +1,12 @@ -import { expect } from 'chai'; import { dialog, BaseWindow, BrowserWindow } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; -import { ifit } from './lib/spec-helpers'; + +import { expect } from 'chai'; + import { setTimeout } from 'node:timers/promises'; +import { ifit } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; + describe('dialog module', () => { describe('showOpenDialog', () => { afterEach(closeAllWindows); diff --git a/spec/api-global-shortcut-spec.ts b/spec/api-global-shortcut-spec.ts index b1c009329db..2025c151dda 100644 --- a/spec/api-global-shortcut-spec.ts +++ b/spec/api-global-shortcut-spec.ts @@ -1,5 +1,7 @@ -import { expect } from 'chai'; import { globalShortcut } from 'electron/main'; + +import { expect } from 'chai'; + import { ifdescribe } from './lib/spec-helpers'; ifdescribe(process.platform !== 'win32')('globalShortcut module', () => { diff --git a/spec/api-in-app-purchase-spec.ts b/spec/api-in-app-purchase-spec.ts index 72b892b2fa9..6092f7ffc49 100644 --- a/spec/api-in-app-purchase-spec.ts +++ b/spec/api-in-app-purchase-spec.ts @@ -1,5 +1,7 @@ -import { expect } from 'chai'; import { inAppPurchase } from 'electron/main'; + +import { expect } from 'chai'; + import { ifdescribe } from './lib/spec-helpers'; describe('inAppPurchase module', function () { diff --git a/spec/api-ipc-main-spec.ts b/spec/api-ipc-main-spec.ts index b9bcb155e3d..869591f1d78 100644 --- a/spec/api-ipc-main-spec.ts +++ b/spec/api-ipc-main-spec.ts @@ -1,10 +1,13 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; -import * as cp from 'node:child_process'; -import { closeAllWindows } from './lib/window-helpers'; -import { defer } from './lib/spec-helpers'; import { ipcMain, BrowserWindow } from 'electron/main'; + +import { expect } from 'chai'; + +import * as cp from 'node:child_process'; import { once } from 'node:events'; +import * as path from 'node:path'; + +import { defer } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; describe('ipc main module', () => { const fixtures = path.join(__dirname, 'fixtures'); diff --git a/spec/api-ipc-renderer-spec.ts b/spec/api-ipc-renderer-spec.ts index 333b316366e..2db75ef3a31 100644 --- a/spec/api-ipc-renderer-spec.ts +++ b/spec/api-ipc-renderer-spec.ts @@ -1,8 +1,11 @@ -import { expect } from 'chai'; import { ipcMain, BrowserWindow } from 'electron/main'; -import { closeWindow } from './lib/window-helpers'; + +import { expect } from 'chai'; + import { once } from 'node:events'; +import { closeWindow } from './lib/window-helpers'; + describe('ipcRenderer module', () => { let w: BrowserWindow; before(async () => { diff --git a/spec/api-ipc-spec.ts b/spec/api-ipc-spec.ts index c650a6195a1..38ff8f14ae6 100644 --- a/spec/api-ipc-spec.ts +++ b/spec/api-ipc-spec.ts @@ -1,10 +1,13 @@ -import { EventEmitter, once } from 'node:events'; -import { expect } from 'chai'; import { BrowserWindow, ipcMain, IpcMainInvokeEvent, MessageChannelMain, WebContents } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; -import { defer, listen } from './lib/spec-helpers'; -import * as path from 'node:path'; + +import { expect } from 'chai'; + +import { EventEmitter, once } from 'node:events'; import * as http from 'node:http'; +import * as path from 'node:path'; + +import { defer, listen } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; const v8Util = process._linkedBinding('electron_common_v8_util'); const fixturesPath = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-media-handler-spec.ts b/spec/api-media-handler-spec.ts index 0a0319e1a55..1d67866ead3 100644 --- a/spec/api-media-handler-spec.ts +++ b/spec/api-media-handler-spec.ts @@ -1,8 +1,11 @@ -import { expect } from 'chai'; import { BrowserWindow, session, desktopCapturer } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; + +import { expect } from 'chai'; + import * as http from 'node:http'; + import { ifit, listen } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; describe('setDisplayMediaRequestHandler', () => { afterEach(closeAllWindows); diff --git a/spec/api-menu-item-spec.ts b/spec/api-menu-item-spec.ts index 0071a3904e1..e385b4773d6 100644 --- a/spec/api-menu-item-spec.ts +++ b/spec/api-menu-item-spec.ts @@ -1,5 +1,7 @@ import { BrowserWindow, app, Menu, MenuItem, MenuItemConstructorOptions } from 'electron/main'; + import { expect } from 'chai'; + import { ifdescribe } from './lib/spec-helpers'; import { closeAllWindows } from './lib/window-helpers'; import { roleList, execute } from '../lib/browser/api/menu-item-roles'; diff --git a/spec/api-menu-spec.ts b/spec/api-menu-spec.ts index 019f5b43a2e..cc0d1ef3584 100644 --- a/spec/api-menu-spec.ts +++ b/spec/api-menu-spec.ts @@ -1,12 +1,15 @@ -import * as cp from 'node:child_process'; -import * as path from 'node:path'; -import { assert, expect } from 'chai'; import { BrowserWindow, Menu, MenuItem } from 'electron/main'; -import { sortMenuItems } from '../lib/browser/api/menu-utils'; + +import { assert, expect } from 'chai'; + +import * as cp from 'node:child_process'; +import { once } from 'node:events'; +import * as path from 'node:path'; +import { setTimeout } from 'node:timers/promises'; + import { ifit } from './lib/spec-helpers'; import { closeWindow } from './lib/window-helpers'; -import { once } from 'node:events'; -import { setTimeout } from 'node:timers/promises'; +import { sortMenuItems } from '../lib/browser/api/menu-utils'; const fixturesPath = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-native-image-spec.ts b/spec/api-native-image-spec.ts index d498214942a..bbd30cff7aa 100644 --- a/spec/api-native-image-spec.ts +++ b/spec/api-native-image-spec.ts @@ -1,8 +1,11 @@ -import { expect } from 'chai'; import { nativeImage } from 'electron/common'; -import { ifdescribe, ifit, itremote, useRemoteContext } from './lib/spec-helpers'; + +import { expect } from 'chai'; + import * as path from 'node:path'; +import { ifdescribe, ifit, itremote, useRemoteContext } from './lib/spec-helpers'; + describe('nativeImage module', () => { const fixturesPath = path.join(__dirname, 'fixtures'); diff --git a/spec/api-native-theme-spec.ts b/spec/api-native-theme-spec.ts index a6abb6762cc..2d2a3a3b00d 100644 --- a/spec/api-native-theme-spec.ts +++ b/spec/api-native-theme-spec.ts @@ -1,5 +1,7 @@ -import { expect } from 'chai'; import { nativeTheme, BrowserWindow, ipcMain } from 'electron/main'; + +import { expect } from 'chai'; + import { once } from 'node:events'; import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; diff --git a/spec/api-net-custom-protocols-spec.ts b/spec/api-net-custom-protocols-spec.ts index d9ffc43d818..374bea81147 100644 --- a/spec/api-net-custom-protocols-spec.ts +++ b/spec/api-net-custom-protocols-spec.ts @@ -1,7 +1,10 @@ -import { expect } from 'chai'; import { net, protocol } from 'electron/main'; -import * as url from 'node:url'; + +import { expect } from 'chai'; + import * as path from 'node:path'; +import * as url from 'node:url'; + import { defer } from './lib/spec-helpers'; describe('net module custom protocols', () => { diff --git a/spec/api-net-log-spec.ts b/spec/api-net-log-spec.ts index fc570f22975..40781d59549 100644 --- a/spec/api-net-log-spec.ts +++ b/spec/api-net-log-spec.ts @@ -1,13 +1,16 @@ +import { session, net } from 'electron/main'; + import { expect } from 'chai'; -import * as http from 'node:http'; + +import * as ChildProcess from 'node:child_process'; +import { once } from 'node:events'; import * as fs from 'node:fs'; +import * as http from 'node:http'; +import { Socket } from 'node:net'; import * as os from 'node:os'; import * as path from 'node:path'; -import * as ChildProcess from 'node:child_process'; -import { session, net } from 'electron/main'; -import { Socket } from 'node:net'; + import { ifit, listen } from './lib/spec-helpers'; -import { once } from 'node:events'; const appPath = path.join(__dirname, 'fixtures', 'api', 'net-log'); const dumpFile = path.join(os.tmpdir(), 'net_log.json'); diff --git a/spec/api-net-session-spec.ts b/spec/api-net-session-spec.ts index 82d6b5b9853..42525be2c0e 100644 --- a/spec/api-net-session-spec.ts +++ b/spec/api-net-session-spec.ts @@ -1,6 +1,9 @@ -import { expect } from 'chai'; -import * as dns from 'node:dns'; import { net, session, BrowserWindow, ClientRequestConstructorOptions } from 'electron/main'; + +import { expect } from 'chai'; + +import * as dns from 'node:dns'; + import { collectStreamBody, getResponse, respondNTimes, respondOnce } from './lib/net-helpers'; // See https://github.com/nodejs/node/issues/40702. diff --git a/spec/api-net-spec.ts b/spec/api-net-spec.ts index 7aa6ad86397..5d98385d60f 100644 --- a/spec/api-net-spec.ts +++ b/spec/api-net-spec.ts @@ -1,9 +1,12 @@ -import { expect } from 'chai'; import { net, ClientRequest, ClientRequestConstructorOptions, utilityProcess } from 'electron/main'; + +import { expect } from 'chai'; + +import { once } from 'node:events'; import * as http from 'node:http'; import * as path from 'node:path'; -import { once } from 'node:events'; import { setTimeout } from 'node:timers/promises'; + import { collectStreamBody, collectStreamBodyBuffer, getResponse, kOneKiloByte, kOneMegaByte, randomBuffer, randomString, respondNTimes, respondOnce } from './lib/net-helpers'; const utilityFixturePath = path.resolve(__dirname, 'fixtures', 'api', 'utility-process', 'api-net-spec.js'); diff --git a/spec/api-notification-dbus-spec.ts b/spec/api-notification-dbus-spec.ts index d470bbd20c2..a601296536e 100644 --- a/spec/api-notification-dbus-spec.ts +++ b/spec/api-notification-dbus-spec.ts @@ -6,13 +6,16 @@ // // See https://pypi.python.org/pypi/python-dbusmock to read about dbusmock. +import { nativeImage } from 'electron/common'; +import { app } from 'electron/main'; + import { expect } from 'chai'; import * as dbus from 'dbus-native'; -import { app } from 'electron/main'; -import { nativeImage } from 'electron/common'; -import { ifdescribe } from './lib/spec-helpers'; -import { promisify } from 'node:util'; + import * as path from 'node:path'; +import { promisify } from 'node:util'; + +import { ifdescribe } from './lib/spec-helpers'; const fixturesPath = path.join(__dirname, 'fixtures'); diff --git a/spec/api-notification-spec.ts b/spec/api-notification-spec.ts index 27188358fbd..27d7417a13d 100644 --- a/spec/api-notification-spec.ts +++ b/spec/api-notification-spec.ts @@ -1,6 +1,9 @@ -import { expect } from 'chai'; import { Notification } from 'electron/main'; + +import { expect } from 'chai'; + import { once } from 'node:events'; + import { ifit } from './lib/spec-helpers'; describe('Notification module', () => { diff --git a/spec/api-power-monitor-spec.ts b/spec/api-power-monitor-spec.ts index 8bd6c275725..47a2e6cdab7 100644 --- a/spec/api-power-monitor-spec.ts +++ b/spec/api-power-monitor-spec.ts @@ -8,10 +8,12 @@ // python-dbusmock. import { expect } from 'chai'; import * as dbus from 'dbus-native'; -import { ifdescribe, startRemoteControlApp } from './lib/spec-helpers'; -import { promisify } from 'node:util'; -import { setTimeout } from 'node:timers/promises'; + import { once } from 'node:events'; +import { setTimeout } from 'node:timers/promises'; +import { promisify } from 'node:util'; + +import { ifdescribe, startRemoteControlApp } from './lib/spec-helpers'; describe('powerMonitor', () => { let logindMock: any, dbusMockPowerMonitor: any, getCalls: any, emitSignal: any, reset: any; diff --git a/spec/api-power-save-blocker-spec.ts b/spec/api-power-save-blocker-spec.ts index 36a35726ad6..ea5091e0026 100644 --- a/spec/api-power-save-blocker-spec.ts +++ b/spec/api-power-save-blocker-spec.ts @@ -1,6 +1,7 @@ -import { expect } from 'chai'; import { powerSaveBlocker } from 'electron/main'; +import { expect } from 'chai'; + describe('powerSaveBlocker module', () => { it('can be started and stopped', () => { expect(powerSaveBlocker.isStarted(-1)).to.be.false('is started'); diff --git a/spec/api-process-spec.ts b/spec/api-process-spec.ts index 3a9a068cee8..156bb6b4100 100644 --- a/spec/api-process-spec.ts +++ b/spec/api-process-spec.ts @@ -1,9 +1,12 @@ +import { BrowserWindow } from 'electron'; +import { app } from 'electron/main'; + +import { expect } from 'chai'; + import * as fs from 'node:fs'; import * as path from 'node:path'; -import { expect } from 'chai'; -import { BrowserWindow } from 'electron'; + import { defer } from './lib/spec-helpers'; -import { app } from 'electron/main'; import { closeAllWindows } from './lib/window-helpers'; describe('process module', () => { diff --git a/spec/api-protocol-spec.ts b/spec/api-protocol-spec.ts index c2c42db0918..1ebcd855fd3 100644 --- a/spec/api-protocol-spec.ts +++ b/spec/api-protocol-spec.ts @@ -1,20 +1,23 @@ +import { protocol, webContents, WebContents, session, BrowserWindow, ipcMain, net } from 'electron/main'; + import { expect } from 'chai'; import { v4 } from 'uuid'; -import { protocol, webContents, WebContents, session, BrowserWindow, ipcMain, net } from 'electron/main'; + import * as ChildProcess from 'node:child_process'; -import * as path from 'node:path'; -import * as url from 'node:url'; -import * as http from 'node:http'; +import { EventEmitter, once } from 'node:events'; import * as fs from 'node:fs'; +import * as http from 'node:http'; +import * as path from 'node:path'; import * as qs from 'node:querystring'; import * as stream from 'node:stream'; import * as streamConsumers from 'node:stream/consumers'; import * as webStream from 'node:stream/web'; -import { EventEmitter, once } from 'node:events'; -import { closeAllWindows, closeWindow } from './lib/window-helpers'; -import { WebmGenerator } from './lib/video-helpers'; -import { listen, defer, ifit } from './lib/spec-helpers'; import { setTimeout } from 'node:timers/promises'; +import * as url from 'node:url'; + +import { listen, defer, ifit } from './lib/spec-helpers'; +import { WebmGenerator } from './lib/video-helpers'; +import { closeAllWindows, closeWindow } from './lib/window-helpers'; const fixturesPath = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-safe-storage-spec.ts b/spec/api-safe-storage-spec.ts index 721d6227583..b8d9c1358ad 100644 --- a/spec/api-safe-storage-spec.ts +++ b/spec/api-safe-storage-spec.ts @@ -1,10 +1,13 @@ -import * as cp from 'node:child_process'; -import * as path from 'node:path'; import { safeStorage } from 'electron/main'; + import { expect } from 'chai'; -import { ifdescribe } from './lib/spec-helpers'; -import * as fs from 'node:fs'; + +import * as cp from 'node:child_process'; import { once } from 'node:events'; +import * as fs from 'node:fs'; +import * as path from 'node:path'; + +import { ifdescribe } from './lib/spec-helpers'; describe('safeStorage module', () => { it('safeStorage before and after app is ready', async () => { diff --git a/spec/api-screen-spec.ts b/spec/api-screen-spec.ts index 8ff1b489d39..1c3141c4e67 100644 --- a/spec/api-screen-spec.ts +++ b/spec/api-screen-spec.ts @@ -1,6 +1,7 @@ -import { expect } from 'chai'; import { Display, screen, desktopCapturer } from 'electron/main'; +import { expect } from 'chai'; + describe('screen module', () => { describe('methods reassignment', () => { it('works for a selected method', () => { diff --git a/spec/api-service-workers-spec.ts b/spec/api-service-workers-spec.ts index c5376130b5e..2fef6b0d658 100644 --- a/spec/api-service-workers-spec.ts +++ b/spec/api-service-workers-spec.ts @@ -1,11 +1,14 @@ +import { session, webContents, WebContents } from 'electron/main'; + +import { expect } from 'chai'; +import { v4 } from 'uuid'; + +import { on, once } from 'node:events'; import * as fs from 'node:fs'; import * as http from 'node:http'; import * as path from 'node:path'; -import { session, webContents, WebContents } from 'electron/main'; -import { expect } from 'chai'; -import { v4 } from 'uuid'; + import { listen } from './lib/spec-helpers'; -import { on, once } from 'node:events'; const partition = 'service-workers-spec'; diff --git a/spec/api-session-spec.ts b/spec/api-session-spec.ts index 2a169f70dcd..aa7cf118361 100644 --- a/spec/api-session-spec.ts +++ b/spec/api-session-spec.ts @@ -1,18 +1,21 @@ +import { app, session, BrowserWindow, net, ipcMain, Session, webFrameMain, WebFrameMain } from 'electron/main'; + +import * as auth from 'basic-auth'; import { expect } from 'chai'; +import * as send from 'send'; + +import * as ChildProcess from 'node:child_process'; import * as crypto from 'node:crypto'; +import { once } from 'node:events'; +import * as fs from 'node:fs'; import * as http from 'node:http'; import * as https from 'node:https'; import * as path from 'node:path'; -import * as fs from 'node:fs'; -import * as ChildProcess from 'node:child_process'; -import { app, session, BrowserWindow, net, ipcMain, Session, webFrameMain, WebFrameMain } from 'electron/main'; -import * as send from 'send'; -import * as auth from 'basic-auth'; -import { closeAllWindows } from './lib/window-helpers'; -import { defer, listen } from './lib/spec-helpers'; -import { once } from 'node:events'; import { setTimeout } from 'node:timers/promises'; +import { defer, listen } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; + describe('session module', () => { const fixtures = path.resolve(__dirname, 'fixtures'); const url = 'http://127.0.0.1'; diff --git a/spec/api-shell-spec.ts b/spec/api-shell-spec.ts index 57a652a0070..3883bf79ddd 100644 --- a/spec/api-shell-spec.ts +++ b/spec/api-shell-spec.ts @@ -1,13 +1,16 @@ -import { BrowserWindow, app } from 'electron/main'; import { shell } from 'electron/common'; -import { closeAllWindows } from './lib/window-helpers'; -import { ifdescribe, ifit, listen } from './lib/spec-helpers'; -import * as http from 'node:http'; +import { BrowserWindow, app } from 'electron/main'; + +import { expect } from 'chai'; + +import { once } from 'node:events'; import * as fs from 'node:fs'; +import * as http from 'node:http'; import * as os from 'node:os'; import * as path from 'node:path'; -import { expect } from 'chai'; -import { once } from 'node:events'; + +import { ifdescribe, ifit, listen } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; describe('shell module', () => { describe('shell.openExternal()', () => { diff --git a/spec/api-subframe-spec.ts b/spec/api-subframe-spec.ts index 043141a12c8..66b5dcc00e8 100644 --- a/spec/api-subframe-spec.ts +++ b/spec/api-subframe-spec.ts @@ -1,11 +1,14 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; -import * as http from 'node:http'; -import { emittedNTimes } from './lib/events-helpers'; -import { closeWindow } from './lib/window-helpers'; import { app, BrowserWindow, ipcMain } from 'electron/main'; -import { ifdescribe, listen } from './lib/spec-helpers'; + +import { expect } from 'chai'; + import { once } from 'node:events'; +import * as http from 'node:http'; +import * as path from 'node:path'; + +import { emittedNTimes } from './lib/events-helpers'; +import { ifdescribe, listen } from './lib/spec-helpers'; +import { closeWindow } from './lib/window-helpers'; describe('renderer nodeIntegrationInSubFrames', () => { const generateTests = (description: string, webPreferences: any) => { diff --git a/spec/api-system-preferences-spec.ts b/spec/api-system-preferences-spec.ts index adedba89532..05de0b91e85 100644 --- a/spec/api-system-preferences-spec.ts +++ b/spec/api-system-preferences-spec.ts @@ -1,5 +1,7 @@ -import { expect } from 'chai'; import { systemPreferences } from 'electron/main'; + +import { expect } from 'chai'; + import { ifdescribe } from './lib/spec-helpers'; describe('systemPreferences module', () => { diff --git a/spec/api-touch-bar-spec.ts b/spec/api-touch-bar-spec.ts index 2d54eef0629..c64583afd64 100644 --- a/spec/api-touch-bar-spec.ts +++ b/spec/api-touch-bar-spec.ts @@ -1,8 +1,11 @@ -import * as path from 'node:path'; import { BaseWindow, BrowserWindow, TouchBar } from 'electron/main'; -import { closeWindow } from './lib/window-helpers'; + import { expect } from 'chai'; +import * as path from 'node:path'; + +import { closeWindow } from './lib/window-helpers'; + const { TouchBarButton, TouchBarColorPicker, TouchBarGroup, TouchBarLabel, TouchBarOtherItemsProxy, TouchBarPopover, TouchBarScrubber, TouchBarSegmentedControl, TouchBarSlider, TouchBarSpacer } = TouchBar; describe('TouchBar module', () => { diff --git a/spec/api-tray-spec.ts b/spec/api-tray-spec.ts index 067d529330c..f56ba1e695b 100644 --- a/spec/api-tray-spec.ts +++ b/spec/api-tray-spec.ts @@ -1,10 +1,13 @@ -import { expect } from 'chai'; -import { Menu, Tray } from 'electron/main'; import { nativeImage } from 'electron/common'; -import { ifdescribe, ifit } from './lib/spec-helpers'; +import { Menu, Tray } from 'electron/main'; + +import { expect } from 'chai'; + import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import { ifdescribe, ifit } from './lib/spec-helpers'; + describe('tray module', () => { let tray: Tray; diff --git a/spec/api-utility-process-spec.ts b/spec/api-utility-process-spec.ts index d283b41f4c5..2a12a45790f 100644 --- a/spec/api-utility-process-spec.ts +++ b/spec/api-utility-process-spec.ts @@ -1,14 +1,17 @@ -import { expect } from 'chai'; -import * as childProcess from 'node:child_process'; -import * as path from 'node:path'; +import { systemPreferences } from 'electron'; import { BrowserWindow, MessageChannelMain, utilityProcess, app } from 'electron/main'; + +import { expect } from 'chai'; + +import * as childProcess from 'node:child_process'; +import { once } from 'node:events'; +import * as path from 'node:path'; +import { setImmediate } from 'node:timers/promises'; +import { pathToFileURL } from 'node:url'; + +import { respondOnce, randomString, kOneKiloByte } from './lib/net-helpers'; import { ifit, startRemoteControlApp } from './lib/spec-helpers'; import { closeWindow } from './lib/window-helpers'; -import { respondOnce, randomString, kOneKiloByte } from './lib/net-helpers'; -import { once } from 'node:events'; -import { pathToFileURL } from 'node:url'; -import { setImmediate } from 'node:timers/promises'; -import { systemPreferences } from 'electron'; const fixturesPath = path.resolve(__dirname, 'fixtures', 'api', 'utility-process'); const isWindowsOnArm = process.platform === 'win32' && process.arch === 'arm64'; diff --git a/spec/api-view-spec.ts b/spec/api-view-spec.ts index 9d7f39bf4d6..4faebbd648c 100644 --- a/spec/api-view-spec.ts +++ b/spec/api-view-spec.ts @@ -1,7 +1,9 @@ -import { expect } from 'chai'; -import { closeWindow } from './lib/window-helpers'; import { BaseWindow, View } from 'electron/main'; +import { expect } from 'chai'; + +import { closeWindow } from './lib/window-helpers'; + describe('View', () => { let w: BaseWindow; afterEach(async () => { diff --git a/spec/api-web-contents-spec.ts b/spec/api-web-contents-spec.ts index 805f5875de1..1e4e40e6a7b 100644 --- a/spec/api-web-contents-spec.ts +++ b/spec/api-web-contents-spec.ts @@ -1,16 +1,20 @@ +import { BrowserWindow, ipcMain, webContents, session, app, BrowserView, WebContents } from 'electron/main'; + import { expect } from 'chai'; -import { AddressInfo } from 'node:net'; -import * as path from 'node:path'; + +import { once } from 'node:events'; import * as fs from 'node:fs'; import * as http from 'node:http'; -import * as url from 'node:url'; -import { BrowserWindow, ipcMain, webContents, session, app, BrowserView, WebContents } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; -import { ifdescribe, defer, waitUntil, listen, ifit } from './lib/spec-helpers'; -import { once } from 'node:events'; +import { AddressInfo } from 'node:net'; +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import * as url from 'node:url'; + +import { ifdescribe, defer, waitUntil, listen, ifit } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; const pdfjs = require('pdfjs-dist'); + const fixturesPath = path.resolve(__dirname, 'fixtures'); const features = process._linkedBinding('electron_common_features'); diff --git a/spec/api-web-contents-view-spec.ts b/spec/api-web-contents-view-spec.ts index 1525986b774..958775067e0 100644 --- a/spec/api-web-contents-view-spec.ts +++ b/spec/api-web-contents-view-spec.ts @@ -1,10 +1,12 @@ -import { expect } from 'chai'; import { BaseWindow, BrowserWindow, View, WebContentsView, webContents, screen } from 'electron/main'; + +import { expect } from 'chai'; + import { once } from 'node:events'; -import { closeAllWindows } from './lib/window-helpers'; -import { defer, ifdescribe, waitUntil } from './lib/spec-helpers'; import { HexColors, ScreenCapture, hasCapturableScreen, nextFrameTime } from './lib/screen-helpers'; +import { defer, ifdescribe, waitUntil } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; describe('WebContentsView', () => { afterEach(closeAllWindows); diff --git a/spec/api-web-frame-main-spec.ts b/spec/api-web-frame-main-spec.ts index e78f1a0876b..54c95c9ef47 100644 --- a/spec/api-web-frame-main-spec.ts +++ b/spec/api-web-frame-main-spec.ts @@ -1,13 +1,16 @@ +import { BrowserWindow, WebFrameMain, webFrameMain, ipcMain, app, WebContents } from 'electron/main'; + import { expect } from 'chai'; + +import { once } from 'node:events'; import * as http from 'node:http'; import * as path from 'node:path'; +import { setTimeout } from 'node:timers/promises'; import * as url from 'node:url'; -import { BrowserWindow, WebFrameMain, webFrameMain, ipcMain, app, WebContents } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; + import { emittedNTimes } from './lib/events-helpers'; import { defer, ifit, listen, waitUntil } from './lib/spec-helpers'; -import { once } from 'node:events'; -import { setTimeout } from 'node:timers/promises'; +import { closeAllWindows } from './lib/window-helpers'; describe('webFrameMain module', () => { const fixtures = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-web-frame-spec.ts b/spec/api-web-frame-spec.ts index 1a56225eefe..3aa2e906a2d 100644 --- a/spec/api-web-frame-spec.ts +++ b/spec/api-web-frame-spec.ts @@ -1,8 +1,11 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; import { BrowserWindow, ipcMain, WebContents } from 'electron/main'; -import { defer } from './lib/spec-helpers'; + +import { expect } from 'chai'; + import { once } from 'node:events'; +import * as path from 'node:path'; + +import { defer } from './lib/spec-helpers'; describe('webFrame module', () => { const fixtures = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-web-request-spec.ts b/spec/api-web-request-spec.ts index e8b17f55b66..6a754765885 100644 --- a/spec/api-web-request-spec.ts +++ b/spec/api-web-request-spec.ts @@ -1,16 +1,19 @@ +import { ipcMain, protocol, session, WebContents, webContents } from 'electron/main'; + import { expect } from 'chai'; +import * as WebSocket from 'ws'; + +import { once } from 'node:events'; +import * as fs from 'node:fs'; import * as http from 'node:http'; import * as http2 from 'node:http2'; -import * as qs from 'node:querystring'; -import * as path from 'node:path'; -import * as fs from 'node:fs'; -import * as url from 'node:url'; -import * as WebSocket from 'ws'; -import { ipcMain, protocol, session, WebContents, webContents } from 'electron/main'; import { Socket } from 'node:net'; -import { listen, defer } from './lib/spec-helpers'; -import { once } from 'node:events'; +import * as path from 'node:path'; +import * as qs from 'node:querystring'; import { ReadableStream } from 'node:stream/web'; +import * as url from 'node:url'; + +import { listen, defer } from './lib/spec-helpers'; const fixturesPath = path.resolve(__dirname, 'fixtures'); diff --git a/spec/api-web-utils-spec.ts b/spec/api-web-utils-spec.ts index a369d15146e..a9d9411d7ae 100644 --- a/spec/api-web-utils-spec.ts +++ b/spec/api-web-utils-spec.ts @@ -1,7 +1,11 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; import { BrowserWindow } from 'electron/main'; + +import { expect } from 'chai'; + +import * as path from 'node:path'; + import { defer } from './lib/spec-helpers'; + // import { once } from 'node:events'; describe('webUtils module', () => { diff --git a/spec/asar-integrity-spec.ts b/spec/asar-integrity-spec.ts index 4e4c9dbf34a..3323dc961ed 100644 --- a/spec/asar-integrity-spec.ts +++ b/spec/asar-integrity-spec.ts @@ -1,16 +1,18 @@ +import { getRawHeader } from '@electron/asar'; +import { flipFuses, FuseV1Config, FuseV1Options, FuseVersion } from '@electron/fuses'; +import { resedit } from '@electron/packager/dist/resedit'; + import { expect } from 'chai'; +import * as originalFs from 'node:original-fs'; + import * as cp from 'node:child_process'; import * as nodeCrypto from 'node:crypto'; -import * as originalFs from 'node:original-fs'; import * as fs from 'node:fs'; import * as os from 'node:os'; import * as path from 'node:path'; -import { ifdescribe } from './lib/spec-helpers'; -import { getRawHeader } from '@electron/asar'; -import { resedit } from '@electron/packager/dist/resedit'; -import { flipFuses, FuseV1Config, FuseV1Options, FuseVersion } from '@electron/fuses'; import { copyApp } from './lib/fs-helpers'; +import { ifdescribe } from './lib/spec-helpers'; const bufferReplace = (haystack: Buffer, needle: string, replacement: string, throwOnMissing = true): Buffer => { const needleBuffer = Buffer.from(needle); diff --git a/spec/asar-spec.ts b/spec/asar-spec.ts index 879ed287b8c..1fcf630973c 100644 --- a/spec/asar-spec.ts +++ b/spec/asar-spec.ts @@ -1,12 +1,15 @@ +import { BrowserWindow, ipcMain } from 'electron/main'; + import { expect } from 'chai'; + +import { once } from 'node:events'; +import * as importedFs from 'node:fs'; import * as path from 'node:path'; import * as url from 'node:url'; import { Worker } from 'node:worker_threads'; -import { BrowserWindow, ipcMain } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; + import { getRemoteContext, ifdescribe, ifit, itremote, useRemoteContext } from './lib/spec-helpers'; -import * as importedFs from 'node:fs'; -import { once } from 'node:events'; +import { closeAllWindows } from './lib/window-helpers'; describe('asar package', () => { const fixtures = path.join(__dirname, 'fixtures'); diff --git a/spec/autofill-spec.ts b/spec/autofill-spec.ts index 5e551125881..9868e9d633e 100644 --- a/spec/autofill-spec.ts +++ b/spec/autofill-spec.ts @@ -1,9 +1,12 @@ import { BrowserWindow } from 'electron'; -import * as path from 'node:path'; + import { expect } from 'chai'; -import { closeAllWindows } from './lib/window-helpers'; + +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import { closeAllWindows } from './lib/window-helpers'; + const fixturesPath = path.resolve(__dirname, 'fixtures'); describe('autofill', () => { diff --git a/spec/chromium-spec.ts b/spec/chromium-spec.ts index 91ba65b6a73..5f49ff5559f 100644 --- a/spec/chromium-spec.ts +++ b/spec/chromium-spec.ts @@ -1,20 +1,23 @@ -import { expect } from 'chai'; -import { BrowserWindow, WebContents, webFrameMain, session, ipcMain, app, protocol, webContents, dialog, MessageBoxOptions } from 'electron/main'; +import { MediaAccessPermissionRequest } from 'electron'; import { clipboard } from 'electron/common'; -import { closeAllWindows } from './lib/window-helpers'; -import * as https from 'node:https'; -import * as http from 'node:http'; -import * as path from 'node:path'; -import * as fs from 'node:fs'; -import * as url from 'node:url'; +import { BrowserWindow, WebContents, webFrameMain, session, ipcMain, app, protocol, webContents, dialog, MessageBoxOptions } from 'electron/main'; + +import { expect } from 'chai'; +import * as ws from 'ws'; + import * as ChildProcess from 'node:child_process'; import { EventEmitter, once } from 'node:events'; -import { ifit, ifdescribe, defer, itremote, listen } from './lib/spec-helpers'; -import { PipeTransport } from './pipe-transport'; -import * as ws from 'ws'; -import { setTimeout } from 'node:timers/promises'; +import * as fs from 'node:fs'; +import * as http from 'node:http'; +import * as https from 'node:https'; import { AddressInfo } from 'node:net'; -import { MediaAccessPermissionRequest } from 'electron'; +import * as path from 'node:path'; +import { setTimeout } from 'node:timers/promises'; +import * as url from 'node:url'; + +import { ifit, ifdescribe, defer, itremote, listen } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; +import { PipeTransport } from './pipe-transport'; const features = process._linkedBinding('electron_common_features'); diff --git a/spec/crash-spec.ts b/spec/crash-spec.ts index 6a83b3d3aa6..ff8489b050d 100644 --- a/spec/crash-spec.ts +++ b/spec/crash-spec.ts @@ -1,7 +1,9 @@ import { expect } from 'chai'; + import * as cp from 'node:child_process'; import * as fs from 'node:fs'; import * as path from 'node:path'; + import { ifit } from './lib/spec-helpers'; const fixturePath = path.resolve(__dirname, 'fixtures', 'crash-cases'); diff --git a/spec/deprecate-spec.ts b/spec/deprecate-spec.ts index b8e3ae9b1d8..3ba8429f620 100644 --- a/spec/deprecate-spec.ts +++ b/spec/deprecate-spec.ts @@ -1,4 +1,5 @@ import { expect } from 'chai'; + import * as deprecate from '../lib/common/deprecate'; describe('deprecate', () => { diff --git a/spec/esm-spec.ts b/spec/esm-spec.ts index 2a0eb148efa..da63b686f63 100644 --- a/spec/esm-spec.ts +++ b/spec/esm-spec.ts @@ -1,6 +1,8 @@ -import { expect } from 'chai'; -import * as cp from 'node:child_process'; import { BrowserWindow } from 'electron'; + +import { expect } from 'chai'; + +import * as cp from 'node:child_process'; import * as fs from 'node:fs'; import * as os from 'node:os'; import * as path from 'node:path'; diff --git a/spec/extensions-spec.ts b/spec/extensions-spec.ts index fdde8341c38..6d78104cde9 100644 --- a/spec/extensions-spec.ts +++ b/spec/extensions-spec.ts @@ -1,13 +1,16 @@ -import { expect } from 'chai'; import { app, session, BrowserWindow, ipcMain, WebContents, Extension, Session } from 'electron/main'; -import { closeAllWindows, closeWindow } from './lib/window-helpers'; + +import { expect } from 'chai'; +import * as WebSocket from 'ws'; + +import { once } from 'node:events'; +import * as fs from 'node:fs/promises'; import * as http from 'node:http'; import * as path from 'node:path'; -import * as fs from 'node:fs/promises'; -import * as WebSocket from 'ws'; + import { emittedNTimes, emittedUntil } from './lib/events-helpers'; import { ifit, listen, waitUntil } from './lib/spec-helpers'; -import { once } from 'node:events'; +import { closeAllWindows, closeWindow } from './lib/window-helpers'; const uuid = require('uuid'); diff --git a/spec/fixtures/api/context-bridge/context-bridge-mutability/main.js b/spec/fixtures/api/context-bridge/context-bridge-mutability/main.js index 3422a3fd56e..41e4ac1222f 100644 --- a/spec/fixtures/api/context-bridge/context-bridge-mutability/main.js +++ b/spec/fixtures/api/context-bridge/context-bridge-mutability/main.js @@ -1,4 +1,5 @@ const { app, BrowserWindow } = require('electron'); + const path = require('node:path'); let win; diff --git a/spec/fixtures/api/mixed-sandbox-app/main.js b/spec/fixtures/api/mixed-sandbox-app/main.js index 5182dd66dc6..b4fd323b93c 100644 --- a/spec/fixtures/api/mixed-sandbox-app/main.js +++ b/spec/fixtures/api/mixed-sandbox-app/main.js @@ -1,4 +1,5 @@ const { app, BrowserWindow, ipcMain } = require('electron'); + const net = require('node:net'); const path = require('node:path'); diff --git a/spec/fixtures/api/relaunch/main.js b/spec/fixtures/api/relaunch/main.js index d66d30921bf..c566dd5cefc 100644 --- a/spec/fixtures/api/relaunch/main.js +++ b/spec/fixtures/api/relaunch/main.js @@ -1,4 +1,5 @@ const { app } = require('electron'); + const net = require('node:net'); const socketPath = process.platform === 'win32' ? '\\\\.\\pipe\\electron-app-relaunch' : '/tmp/electron-app-relaunch'; diff --git a/spec/fixtures/api/safe-storage/decrypt-app/main.js b/spec/fixtures/api/safe-storage/decrypt-app/main.js index 3476034455d..fe983e4d549 100644 --- a/spec/fixtures/api/safe-storage/decrypt-app/main.js +++ b/spec/fixtures/api/safe-storage/decrypt-app/main.js @@ -1,4 +1,5 @@ const { app, safeStorage } = require('electron'); + const { promises: fs } = require('node:fs'); const path = require('node:path'); diff --git a/spec/fixtures/api/safe-storage/encrypt-app/main.js b/spec/fixtures/api/safe-storage/encrypt-app/main.js index a9f6d261c02..1bb90b65d3b 100644 --- a/spec/fixtures/api/safe-storage/encrypt-app/main.js +++ b/spec/fixtures/api/safe-storage/encrypt-app/main.js @@ -1,4 +1,5 @@ const { app, safeStorage } = require('electron'); + const { promises: fs } = require('node:fs'); const path = require('node:path'); diff --git a/spec/fixtures/api/singleton-userdata/main.js b/spec/fixtures/api/singleton-userdata/main.js index 2d4a4878663..a0ec2f90a23 100644 --- a/spec/fixtures/api/singleton-userdata/main.js +++ b/spec/fixtures/api/singleton-userdata/main.js @@ -1,4 +1,5 @@ const { app } = require('electron'); + const fs = require('node:fs'); const path = require('node:path'); diff --git a/spec/fixtures/api/utility-process/api-net-spec.js b/spec/fixtures/api/utility-process/api-net-spec.js index a97259cdf7f..cc0628273df 100644 --- a/spec/fixtures/api/utility-process/api-net-spec.js +++ b/spec/fixtures/api/utility-process/api-net-spec.js @@ -2,15 +2,18 @@ /* eslint-disable camelcase */ require('ts-node/register'); -const chai_1 = require('chai'); const main_1 = require('electron/main'); -const http = require('node:http'); -const url = require('node:url'); + +const chai_1 = require('chai'); + const node_events_1 = require('node:events'); +const http = require('node:http'); const promises_1 = require('node:timers/promises'); -const net_helpers_1 = require('../../../lib/net-helpers'); +const url = require('node:url'); const v8 = require('node:v8'); +const net_helpers_1 = require('../../../lib/net-helpers'); + v8.setFlagsFromString('--expose_gc'); chai_1.use(require('chai-as-promised')); chai_1.use(require('dirty-chai')); diff --git a/spec/fixtures/api/utility-process/dns-result-order.js b/spec/fixtures/api/utility-process/dns-result-order.js index 74d1219003c..413aaec5813 100644 --- a/spec/fixtures/api/utility-process/dns-result-order.js +++ b/spec/fixtures/api/utility-process/dns-result-order.js @@ -1,3 +1,4 @@ const dns = require('node:dns'); + console.log(dns.getDefaultResultOrder()); process.exit(0); diff --git a/spec/fixtures/api/utility-process/env-app/main.js b/spec/fixtures/api/utility-process/env-app/main.js index 5edb3ea8231..c03f28d1750 100644 --- a/spec/fixtures/api/utility-process/env-app/main.js +++ b/spec/fixtures/api/utility-process/env-app/main.js @@ -1,4 +1,5 @@ const { app, utilityProcess } = require('electron'); + const path = require('node:path'); app.whenReady().then(() => { diff --git a/spec/fixtures/api/utility-process/inherit-stderr/main.js b/spec/fixtures/api/utility-process/inherit-stderr/main.js index 80fbaff5cc5..5c9c7331ff0 100644 --- a/spec/fixtures/api/utility-process/inherit-stderr/main.js +++ b/spec/fixtures/api/utility-process/inherit-stderr/main.js @@ -1,4 +1,5 @@ const { app, utilityProcess } = require('electron'); + const path = require('node:path'); app.whenReady().then(() => { diff --git a/spec/fixtures/api/utility-process/inherit-stdout/main.js b/spec/fixtures/api/utility-process/inherit-stdout/main.js index 80fbaff5cc5..5c9c7331ff0 100644 --- a/spec/fixtures/api/utility-process/inherit-stdout/main.js +++ b/spec/fixtures/api/utility-process/inherit-stdout/main.js @@ -1,4 +1,5 @@ const { app, utilityProcess } = require('electron'); + const path = require('node:path'); app.whenReady().then(() => { diff --git a/spec/fixtures/api/utility-process/net.js b/spec/fixtures/api/utility-process/net.js index 7b5544a903e..c5dae192849 100644 --- a/spec/fixtures/api/utility-process/net.js +++ b/spec/fixtures/api/utility-process/net.js @@ -1,4 +1,5 @@ const { net } = require('electron'); + const serverUrl = process.argv[2].split('=')[1]; let configurableArg = null; if (process.argv[3]) { diff --git a/spec/fixtures/api/utility-process/suid.js b/spec/fixtures/api/utility-process/suid.js index 714a288f44e..69d4d018c10 100644 --- a/spec/fixtures/api/utility-process/suid.js +++ b/spec/fixtures/api/utility-process/suid.js @@ -1,2 +1,3 @@ const result = require('node:child_process').execSync('sudo --help'); + process.parentPort.postMessage(result); diff --git a/spec/fixtures/apps/crash/fork.js b/spec/fixtures/apps/crash/fork.js index 2b0cb8be0c8..db984154ffb 100644 --- a/spec/fixtures/apps/crash/fork.js +++ b/spec/fixtures/apps/crash/fork.js @@ -1,5 +1,5 @@ -const path = require('node:path'); const childProcess = require('node:child_process'); +const path = require('node:path'); const crashPath = path.join(__dirname, 'node-crash.js'); const child = childProcess.fork(crashPath, { silent: true }); diff --git a/spec/fixtures/apps/crash/main.js b/spec/fixtures/apps/crash/main.js index cabedbb1aa0..dcae6b79bbb 100644 --- a/spec/fixtures/apps/crash/main.js +++ b/spec/fixtures/apps/crash/main.js @@ -1,6 +1,7 @@ const { app, BrowserWindow, crashReporter } = require('electron'); -const path = require('node:path'); + const childProcess = require('node:child_process'); +const path = require('node:path'); app.setVersion('0.1.0'); diff --git a/spec/fixtures/apps/libuv-hang/main.js b/spec/fixtures/apps/libuv-hang/main.js index 55a65ca93a0..ca7272ff403 100644 --- a/spec/fixtures/apps/libuv-hang/main.js +++ b/spec/fixtures/apps/libuv-hang/main.js @@ -1,4 +1,5 @@ const { app, BrowserWindow, ipcMain } = require('electron'); + const path = require('node:path'); async function createWindow () { diff --git a/spec/fixtures/apps/open-new-window-from-link/main.js b/spec/fixtures/apps/open-new-window-from-link/main.js index 4f4d4999d09..6f0b188a187 100644 --- a/spec/fixtures/apps/open-new-window-from-link/main.js +++ b/spec/fixtures/apps/open-new-window-from-link/main.js @@ -1,4 +1,5 @@ const { app, BrowserWindow } = require('electron'); + const path = require('node:path'); async function createWindow () { diff --git a/spec/fixtures/apps/refresh-page/main.js b/spec/fixtures/apps/refresh-page/main.js index f4ada26db39..d317fa37a70 100644 --- a/spec/fixtures/apps/refresh-page/main.js +++ b/spec/fixtures/apps/refresh-page/main.js @@ -1,8 +1,9 @@ -const path = require('node:path'); -const { once } = require('node:events'); -const { pathToFileURL } = require('node:url'); const { BrowserWindow, app, protocol, net, session } = require('electron'); +const { once } = require('node:events'); +const path = require('node:path'); +const { pathToFileURL } = require('node:url'); + if (process.argv.length < 4) { console.error('Must pass allow_code_cache code_cache_dir'); process.exit(1); diff --git a/spec/fixtures/apps/remote-control/main.js b/spec/fixtures/apps/remote-control/main.js index b2b6f4b4fb8..8ea8d17def6 100644 --- a/spec/fixtures/apps/remote-control/main.js +++ b/spec/fixtures/apps/remote-control/main.js @@ -1,11 +1,12 @@ // eslint-disable-next-line camelcase const electron_1 = require('electron'); + // eslint-disable-next-line camelcase const { app } = electron_1; const http = require('node:http'); -const v8 = require('node:v8'); // eslint-disable-next-line camelcase,@typescript-eslint/no-unused-vars const promises_1 = require('node:timers/promises'); +const v8 = require('node:v8'); if (app.commandLine.hasSwitch('boot-eval')) { // eslint-disable-next-line no-eval diff --git a/spec/fixtures/apps/set-path/main.js b/spec/fixtures/apps/set-path/main.js index abde4409572..7dd0cd30d9a 100644 --- a/spec/fixtures/apps/set-path/main.js +++ b/spec/fixtures/apps/set-path/main.js @@ -1,6 +1,7 @@ -const http = require('node:http'); const { app, ipcMain, BrowserWindow } = require('electron'); +const http = require('node:http'); + if (process.argv.length > 3) { app.setPath(process.argv[2], process.argv[3]); } diff --git a/spec/fixtures/apps/xwindow-icon/main.js b/spec/fixtures/apps/xwindow-icon/main.js index f5e23deda9c..292abe12ce6 100644 --- a/spec/fixtures/apps/xwindow-icon/main.js +++ b/spec/fixtures/apps/xwindow-icon/main.js @@ -1,4 +1,5 @@ const { app, BrowserWindow } = require('electron'); + const path = require('node:path'); app.whenReady().then(() => { diff --git a/spec/fixtures/auto-update/update-json/index.js b/spec/fixtures/auto-update/update-json/index.js index 320dbffe229..3db01f553cf 100644 --- a/spec/fixtures/auto-update/update-json/index.js +++ b/spec/fixtures/auto-update/update-json/index.js @@ -1,3 +1,5 @@ +const { app, autoUpdater } = require('electron'); + const fs = require('node:fs'); const path = require('node:path'); @@ -6,8 +8,6 @@ process.on('uncaughtException', (err) => { process.exit(1); }); -const { app, autoUpdater } = require('electron'); - autoUpdater.on('error', (err) => { console.error(err); process.exit(1); diff --git a/spec/fixtures/auto-update/update-stack/index.js b/spec/fixtures/auto-update/update-stack/index.js index 24527318626..487ef591b47 100644 --- a/spec/fixtures/auto-update/update-stack/index.js +++ b/spec/fixtures/auto-update/update-stack/index.js @@ -1,3 +1,5 @@ +const { app, autoUpdater } = require('electron'); + const fs = require('node:fs'); const path = require('node:path'); @@ -6,8 +8,6 @@ process.on('uncaughtException', (err) => { process.exit(1); }); -const { app, autoUpdater } = require('electron'); - autoUpdater.on('error', (err) => { console.error(err); process.exit(1); diff --git a/spec/fixtures/auto-update/update/index.js b/spec/fixtures/auto-update/update/index.js index f9d1b1670b0..d9ec2b6ac05 100644 --- a/spec/fixtures/auto-update/update/index.js +++ b/spec/fixtures/auto-update/update/index.js @@ -1,3 +1,5 @@ +const { app, autoUpdater } = require('electron'); + const fs = require('node:fs'); const path = require('node:path'); @@ -6,8 +8,6 @@ process.on('uncaughtException', (err) => { process.exit(1); }); -const { app, autoUpdater } = require('electron'); - autoUpdater.on('error', (err) => { console.error(err); process.exit(1); diff --git a/spec/fixtures/crash-cases/api-browser-destroy/index.js b/spec/fixtures/crash-cases/api-browser-destroy/index.js index 1e87b8d177a..97198c6eed5 100644 --- a/spec/fixtures/crash-cases/api-browser-destroy/index.js +++ b/spec/fixtures/crash-cases/api-browser-destroy/index.js @@ -1,4 +1,5 @@ const { app, BrowserWindow, BrowserView } = require('electron'); + const { expect } = require('chai'); function createWindow () { diff --git a/spec/fixtures/crash-cases/fs-promises-renderer-crash/index.js b/spec/fixtures/crash-cases/fs-promises-renderer-crash/index.js index 7e997d030f5..78e630fb54c 100644 --- a/spec/fixtures/crash-cases/fs-promises-renderer-crash/index.js +++ b/spec/fixtures/crash-cases/fs-promises-renderer-crash/index.js @@ -1,4 +1,5 @@ const { app, BrowserWindow } = require('electron'); + const path = require('node:path'); app.whenReady().then(() => { diff --git a/spec/fixtures/crash-cases/js-execute-iframe/index.js b/spec/fixtures/crash-cases/js-execute-iframe/index.js index 65dba1ef016..d71cc4e0d41 100644 --- a/spec/fixtures/crash-cases/js-execute-iframe/index.js +++ b/spec/fixtures/crash-cases/js-execute-iframe/index.js @@ -1,4 +1,5 @@ const { app, BrowserWindow } = require('electron'); + const net = require('node:net'); const path = require('node:path'); diff --git a/spec/fixtures/crash-cases/native-window-open-exit/index.js b/spec/fixtures/crash-cases/native-window-open-exit/index.js index 30ff075ecde..af5f062b4ec 100644 --- a/spec/fixtures/crash-cases/native-window-open-exit/index.js +++ b/spec/fixtures/crash-cases/native-window-open-exit/index.js @@ -1,6 +1,7 @@ const { app, ipcMain, BrowserWindow } = require('electron'); -const path = require('node:path'); + const http = require('node:http'); +const path = require('node:path'); function createWindow () { const mainWindow = new BrowserWindow({ diff --git a/spec/fixtures/crash-cases/safe-storage/index.js b/spec/fixtures/crash-cases/safe-storage/index.js index 151751820a8..08bdede4dae 100644 --- a/spec/fixtures/crash-cases/safe-storage/index.js +++ b/spec/fixtures/crash-cases/safe-storage/index.js @@ -1,4 +1,5 @@ const { app, safeStorage } = require('electron'); + const { expect } = require('chai'); (async () => { diff --git a/spec/fixtures/crash-cases/setimmediate-renderer-crash/index.js b/spec/fixtures/crash-cases/setimmediate-renderer-crash/index.js index be1cb3f3d1c..3ee66640b8a 100644 --- a/spec/fixtures/crash-cases/setimmediate-renderer-crash/index.js +++ b/spec/fixtures/crash-cases/setimmediate-renderer-crash/index.js @@ -1,4 +1,5 @@ const { app, BrowserWindow } = require('electron'); + const path = require('node:path'); app.whenReady().then(() => { diff --git a/spec/fixtures/crash-cases/webcontents-create-leak-exit/index.js b/spec/fixtures/crash-cases/webcontents-create-leak-exit/index.js index 0059a5c3df1..643594da500 100644 --- a/spec/fixtures/crash-cases/webcontents-create-leak-exit/index.js +++ b/spec/fixtures/crash-cases/webcontents-create-leak-exit/index.js @@ -1,4 +1,5 @@ const { app, webContents } = require('electron'); + app.whenReady().then(function () { webContents.create(); diff --git a/spec/fixtures/crash-cases/webcontentsview-create-leak-exit/index.js b/spec/fixtures/crash-cases/webcontentsview-create-leak-exit/index.js index 3d491cabbdd..99297eed49e 100644 --- a/spec/fixtures/crash-cases/webcontentsview-create-leak-exit/index.js +++ b/spec/fixtures/crash-cases/webcontentsview-create-leak-exit/index.js @@ -1,4 +1,5 @@ const { WebContentsView, app } = require('electron'); + app.whenReady().then(function () { // eslint-disable-next-line no-new new WebContentsView(); diff --git a/spec/fixtures/module/asar.js b/spec/fixtures/module/asar.js index ab13554fb87..7b196e53394 100644 --- a/spec/fixtures/module/asar.js +++ b/spec/fixtures/module/asar.js @@ -1,4 +1,5 @@ const fs = require('node:fs'); + process.on('message', function (file) { process.send(fs.readFileSync(file).toString()); }); diff --git a/spec/fixtures/module/check-arguments.js b/spec/fixtures/module/check-arguments.js index 8a5ef8dde19..dccbe2d314b 100644 --- a/spec/fixtures/module/check-arguments.js +++ b/spec/fixtures/module/check-arguments.js @@ -1,4 +1,5 @@ const { ipcRenderer } = require('electron'); + window.onload = function () { ipcRenderer.send('answer', process.argv); }; diff --git a/spec/fixtures/module/create_socket.js b/spec/fixtures/module/create_socket.js index 64c059b2f24..abcc0e66be2 100644 --- a/spec/fixtures/module/create_socket.js +++ b/spec/fixtures/module/create_socket.js @@ -1,4 +1,5 @@ const net = require('node:net'); + const server = net.createServer(function () {}); server.listen(process.argv[2]); process.exit(0); diff --git a/spec/fixtures/module/echo.js b/spec/fixtures/module/echo.js index ae1b31dd9be..56ba812a0d9 100644 --- a/spec/fixtures/module/echo.js +++ b/spec/fixtures/module/echo.js @@ -3,4 +3,5 @@ process.on('uncaughtException', function (err) { }); const echo = require('@electron-ci/echo'); + process.send(echo('ok')); diff --git a/spec/fixtures/module/fork_ping.js b/spec/fixtures/module/fork_ping.js index 33ed47051c6..857211280d2 100644 --- a/spec/fixtures/module/fork_ping.js +++ b/spec/fixtures/module/fork_ping.js @@ -1,10 +1,12 @@ +const childProcess = require('node:child_process'); const path = require('node:path'); process.on('uncaughtException', function (error) { process.send(error.stack); }); -const child = require('node:child_process').fork(path.join(__dirname, '/ping.js')); +const child = childProcess.fork(path.join(__dirname, '/ping.js')); + process.on('message', function (msg) { child.send(msg); }); diff --git a/spec/fixtures/module/isolated-ping.js b/spec/fixtures/module/isolated-ping.js index 90392e46fe4..e7d5980d535 100644 --- a/spec/fixtures/module/isolated-ping.js +++ b/spec/fixtures/module/isolated-ping.js @@ -1,2 +1,3 @@ const { ipcRenderer } = require('electron'); + ipcRenderer.send('pong'); diff --git a/spec/fixtures/module/module-paths.js b/spec/fixtures/module/module-paths.js index 895168dd397..fc5d6cb1ca9 100644 --- a/spec/fixtures/module/module-paths.js +++ b/spec/fixtures/module/module-paths.js @@ -1,2 +1,3 @@ const Module = require('node:module'); + process.send(Module._nodeModulePaths(process.resourcesPath + '/test.js')); diff --git a/spec/fixtures/module/preload-ipc.js b/spec/fixtures/module/preload-ipc.js index 390fa920dfa..465b7152ede 100644 --- a/spec/fixtures/module/preload-ipc.js +++ b/spec/fixtures/module/preload-ipc.js @@ -1,4 +1,5 @@ const { ipcRenderer } = require('electron'); + ipcRenderer.on('ping', function (event, message) { ipcRenderer.sendToHost('pong', message); }); diff --git a/spec/fixtures/module/send-later.js b/spec/fixtures/module/send-later.js index 5b4a2209727..feef5d903ae 100644 --- a/spec/fixtures/module/send-later.js +++ b/spec/fixtures/module/send-later.js @@ -1,4 +1,5 @@ const { ipcRenderer } = require('electron'); + window.onload = function () { ipcRenderer.send('answer', typeof window.process, typeof window.Buffer); }; diff --git a/spec/fixtures/native-addon/external-ab/lib/test-array-buffer.js b/spec/fixtures/native-addon/external-ab/lib/test-array-buffer.js index 97b49e76933..ff2c1a8e721 100644 --- a/spec/fixtures/native-addon/external-ab/lib/test-array-buffer.js +++ b/spec/fixtures/native-addon/external-ab/lib/test-array-buffer.js @@ -1,4 +1,5 @@ 'use strict'; const binding = require('../build/Release/external_ab.node'); + binding.createBuffer(); diff --git a/spec/fixtures/native-addon/uv-dlopen/index.js b/spec/fixtures/native-addon/uv-dlopen/index.js index 6d7e4f8aa7f..c2761afc415 100644 --- a/spec/fixtures/native-addon/uv-dlopen/index.js +++ b/spec/fixtures/native-addon/uv-dlopen/index.js @@ -1,4 +1,5 @@ const path = require('node:path'); + const testLoadLibrary = require('./build/Release/test_module'); const lib = (() => { diff --git a/spec/fixtures/no-proprietary-codecs.js b/spec/fixtures/no-proprietary-codecs.js index 40e073470b2..9c8dbdde74d 100644 --- a/spec/fixtures/no-proprietary-codecs.js +++ b/spec/fixtures/no-proprietary-codecs.js @@ -5,6 +5,7 @@ // that does include proprietary codecs. const { app, BrowserWindow, ipcMain } = require('electron'); + const path = require('node:path'); const MEDIA_ERR_SRC_NOT_SUPPORTED = 4; diff --git a/spec/fixtures/test.asar/repack.js b/spec/fixtures/test.asar/repack.js index 5af420a934e..d85dc01e750 100644 --- a/spec/fixtures/test.asar/repack.js +++ b/spec/fixtures/test.asar/repack.js @@ -2,6 +2,7 @@ // using a new version of the asar package const asar = require('@electron/asar'); + const fs = require('node:fs'); const os = require('node:os'); const path = require('node:path'); diff --git a/spec/fuses-spec.ts b/spec/fuses-spec.ts index 5fb0013c0e5..29409f7cc05 100644 --- a/spec/fuses-spec.ts +++ b/spec/fuses-spec.ts @@ -1,10 +1,13 @@ -import { expect } from 'chai'; -import { startRemoteControlApp } from './lib/spec-helpers'; -import { once } from 'node:events'; -import { spawn, spawnSync } from 'node:child_process'; import { BrowserWindow } from 'electron'; + +import { expect } from 'chai'; + +import { spawn, spawnSync } from 'node:child_process'; +import { once } from 'node:events'; import path = require('node:path'); +import { startRemoteControlApp } from './lib/spec-helpers'; + describe('fuses', () => { it('can be enabled by command-line argument during testing', async () => { const child0 = spawn(process.execPath, ['-v'], { env: { NODE_OPTIONS: '-e 0' } }); diff --git a/spec/guest-window-manager-spec.ts b/spec/guest-window-manager-spec.ts index bd5bab5bd91..88daa4cfae2 100644 --- a/spec/guest-window-manager-spec.ts +++ b/spec/guest-window-manager-spec.ts @@ -1,10 +1,13 @@ import { BrowserWindow, screen } from 'electron'; + import { expect, assert } from 'chai'; + +import { once } from 'node:events'; +import * as http from 'node:http'; + import { HexColors, ScreenCapture, hasCapturableScreen } from './lib/screen-helpers'; import { ifit, listen } from './lib/spec-helpers'; import { closeAllWindows } from './lib/window-helpers'; -import { once } from 'node:events'; -import * as http from 'node:http'; describe('webContents.setWindowOpenHandler', () => { describe('native window', () => { diff --git a/spec/index.js b/spec/index.js index 34967e8f39f..fe5ef6abf18 100644 --- a/spec/index.js +++ b/spec/index.js @@ -1,3 +1,5 @@ +const { app, protocol } = require('electron'); + const fs = require('node:fs'); const path = require('node:path'); const v8 = require('node:v8'); @@ -12,8 +14,6 @@ process.on('uncaughtException', (err) => { process.env.TS_NODE_PROJECT = path.resolve(__dirname, '../tsconfig.spec.json'); process.env.ELECTRON_DISABLE_SECURITY_WARNINGS = 'true'; -const { app, protocol } = require('electron'); - // Some Linux machines have broken hardware acceleration support. if (process.env.ELECTRON_TEST_DISABLE_HARDWARE_ACCELERATION) { app.disableHardwareAcceleration(); diff --git a/spec/lib/artifacts.ts b/spec/lib/artifacts.ts index 5b1b66aba6a..433a119507e 100644 --- a/spec/lib/artifacts.ts +++ b/spec/lib/artifacts.ts @@ -1,6 +1,6 @@ -import path = require('node:path'); -import fs = require('node:fs/promises'); import { randomBytes } from 'node:crypto'; +import fs = require('node:fs/promises'); +import path = require('node:path'); const IS_CI = !!process.env.CI; const ARTIFACT_DIR = path.join(__dirname, '..', 'artifacts'); diff --git a/spec/lib/codesign-helpers.ts b/spec/lib/codesign-helpers.ts index 2de425e5453..9e43f482192 100644 --- a/spec/lib/codesign-helpers.ts +++ b/spec/lib/codesign-helpers.ts @@ -1,7 +1,8 @@ +import { expect } from 'chai'; + import * as cp from 'node:child_process'; import * as fs from 'node:fs'; import * as path from 'node:path'; -import { expect } from 'chai'; const features = process._linkedBinding('electron_common_features'); const fixturesPath = path.resolve(__dirname, '..', 'fixtures'); diff --git a/spec/lib/fs-helpers.ts b/spec/lib/fs-helpers.ts index 26949079d6b..7c1966c9059 100644 --- a/spec/lib/fs-helpers.ts +++ b/spec/lib/fs-helpers.ts @@ -1,5 +1,6 @@ -import * as cp from 'node:child_process'; import * as fs from 'original-fs'; + +import * as cp from 'node:child_process'; import * as os from 'node:os'; import * as path from 'node:path'; diff --git a/spec/lib/net-helpers.ts b/spec/lib/net-helpers.ts index 350885278ce..7500ac755e0 100644 --- a/spec/lib/net-helpers.ts +++ b/spec/lib/net-helpers.ts @@ -1,7 +1,9 @@ import { expect } from 'chai'; + import * as dns from 'node:dns'; import * as http from 'node:http'; import { Socket } from 'node:net'; + import { defer, listen } from './spec-helpers'; // See https://github.com/nodejs/node/issues/40702. diff --git a/spec/lib/screen-helpers.ts b/spec/lib/screen-helpers.ts index 75488497958..0fb3128611d 100644 --- a/spec/lib/screen-helpers.ts +++ b/spec/lib/screen-helpers.ts @@ -1,7 +1,9 @@ import { screen, desktopCapturer, NativeImage } from 'electron'; -import { createArtifactWithRandomId } from './artifacts'; + import { AssertionError } from 'chai'; +import { createArtifactWithRandomId } from './artifacts'; + export enum HexColors { GREEN = '#00b140', PURPLE = '#6a0dad', diff --git a/spec/lib/spec-helpers.ts b/spec/lib/spec-helpers.ts index c2ecb4b16a8..85a31ddd3bf 100644 --- a/spec/lib/spec-helpers.ts +++ b/spec/lib/spec-helpers.ts @@ -1,15 +1,17 @@ -import * as childProcess from 'node:child_process'; -import * as path from 'node:path'; -import * as http from 'node:http'; -import * as https from 'node:https'; -import * as http2 from 'node:http2'; -import * as net from 'node:net'; -import * as v8 from 'node:v8'; -import * as url from 'node:url'; -import { SuiteFunction, TestFunction } from 'mocha'; import { BrowserWindow } from 'electron/main'; + import { AssertionError } from 'chai'; +import { SuiteFunction, TestFunction } from 'mocha'; + +import * as childProcess from 'node:child_process'; +import * as http from 'node:http'; +import * as http2 from 'node:http2'; +import * as https from 'node:https'; +import * as net from 'node:net'; +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import * as url from 'node:url'; +import * as v8 from 'node:v8'; const addOnly = (fn: Function): T => { const wrapped = (...args: any[]) => { diff --git a/spec/lib/window-helpers.ts b/spec/lib/window-helpers.ts index 6571d74189e..77a8913df7d 100644 --- a/spec/lib/window-helpers.ts +++ b/spec/lib/window-helpers.ts @@ -1,5 +1,7 @@ -import { expect } from 'chai'; import { BaseWindow, BrowserWindow } from 'electron/main'; + +import { expect } from 'chai'; + import { once } from 'node:events'; async function ensureWindowIsClosed (window: BaseWindow | null) { diff --git a/spec/logging-spec.ts b/spec/logging-spec.ts index dfa2538bc2a..46fa410a07d 100644 --- a/spec/logging-spec.ts +++ b/spec/logging-spec.ts @@ -1,11 +1,13 @@ import { app } from 'electron'; -import { expect } from 'chai'; -import { startRemoteControlApp, ifdescribe } from './lib/spec-helpers'; +import { expect } from 'chai'; +import * as uuid from 'uuid'; + +import { once } from 'node:events'; import * as fs from 'node:fs/promises'; import * as path from 'node:path'; -import * as uuid from 'uuid'; -import { once } from 'node:events'; + +import { startRemoteControlApp, ifdescribe } from './lib/spec-helpers'; function isTestingBindingAvailable () { try { diff --git a/spec/modules-spec.ts b/spec/modules-spec.ts index 8fd2c7dbe33..ecfdf1a9e8a 100644 --- a/spec/modules-spec.ts +++ b/spec/modules-spec.ts @@ -1,11 +1,14 @@ -import { expect } from 'chai'; -import * as path from 'node:path'; -import * as fs from 'node:fs'; import { BrowserWindow } from 'electron/main'; -import { ifdescribe, ifit } from './lib/spec-helpers'; -import { closeAllWindows } from './lib/window-helpers'; + +import { expect } from 'chai'; + import * as childProcess from 'node:child_process'; import { once } from 'node:events'; +import * as fs from 'node:fs'; +import * as path from 'node:path'; + +import { ifdescribe, ifit } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; const Module = require('node:module') as NodeJS.ModuleInternal; diff --git a/spec/node-spec.ts b/spec/node-spec.ts index 9c5059172c8..d3f68030a2a 100644 --- a/spec/node-spec.ts +++ b/spec/node-spec.ts @@ -1,14 +1,17 @@ +import { webContents } from 'electron/main'; + import { expect } from 'chai'; + import * as childProcess from 'node:child_process'; +import { once } from 'node:events'; import * as fs from 'node:fs'; import * as path from 'node:path'; -import * as util from 'node:util'; -import { getRemoteContext, ifdescribe, ifit, itremote, useRemoteContext } from './lib/spec-helpers'; -import { copyMacOSFixtureApp, getCodesignIdentity, shouldRunCodesignTests, signApp, spawn } from './lib/codesign-helpers'; -import { webContents } from 'electron/main'; import { EventEmitter } from 'node:stream'; -import { once } from 'node:events'; +import * as util from 'node:util'; + +import { copyMacOSFixtureApp, getCodesignIdentity, shouldRunCodesignTests, signApp, spawn } from './lib/codesign-helpers'; import { withTempDirectory } from './lib/fs-helpers'; +import { getRemoteContext, ifdescribe, ifit, itremote, useRemoteContext } from './lib/spec-helpers'; const mainFixturesPath = path.resolve(__dirname, 'fixtures'); diff --git a/spec/parse-features-string-spec.ts b/spec/parse-features-string-spec.ts index be561064b50..1392ae1582b 100644 --- a/spec/parse-features-string-spec.ts +++ b/spec/parse-features-string-spec.ts @@ -1,4 +1,5 @@ import { expect } from 'chai'; + import { parseCommaSeparatedKeyValue } from '../lib/browser/parse-features-string'; describe('feature-string parsing', () => { diff --git a/spec/process-binding-spec.ts b/spec/process-binding-spec.ts index 343e7536cbd..db734208e5f 100644 --- a/spec/process-binding-spec.ts +++ b/spec/process-binding-spec.ts @@ -1,5 +1,7 @@ -import { expect } from 'chai'; import { BrowserWindow } from 'electron/main'; + +import { expect } from 'chai'; + import { closeAllWindows } from './lib/window-helpers'; describe('process._linkedBinding', () => { diff --git a/spec/release-notes-spec.ts b/spec/release-notes-spec.ts index a20a45f817b..be34d0608c3 100644 --- a/spec/release-notes-spec.ts +++ b/spec/release-notes-spec.ts @@ -1,9 +1,11 @@ -import { GitProcess, IGitExecutionOptions, IGitResult } from 'dugite'; import { expect } from 'chai'; -import * as notes from '../script/release/notes/notes'; -import * as path from 'node:path'; +import { GitProcess, IGitExecutionOptions, IGitResult } from 'dugite'; import * as sinon from 'sinon'; +import * as path from 'node:path'; + +import * as notes from '../script/release/notes/notes'; + /* Fake a Dugite GitProcess that only returns the specific commits that we want to test */ diff --git a/spec/security-warnings-spec.ts b/spec/security-warnings-spec.ts index ea356e0d016..19e563b41db 100644 --- a/spec/security-warnings-spec.ts +++ b/spec/security-warnings-spec.ts @@ -1,14 +1,15 @@ -import { expect } from 'chai'; -import * as http from 'node:http'; -import * as fs from 'node:fs/promises'; -import * as path from 'node:path'; - import { BrowserWindow, WebPreferences } from 'electron/main'; -import { closeWindow } from './lib/window-helpers'; +import { expect } from 'chai'; + +import * as fs from 'node:fs/promises'; +import * as http from 'node:http'; +import * as path from 'node:path'; +import { setTimeout } from 'node:timers/promises'; + import { emittedUntil } from './lib/events-helpers'; import { listen } from './lib/spec-helpers'; -import { setTimeout } from 'node:timers/promises'; +import { closeWindow } from './lib/window-helpers'; const messageContainsSecurityWarning = (event: Event, level: number, message: string) => { return message.includes('Electron Security Warning'); diff --git a/spec/spellchecker-spec.ts b/spec/spellchecker-spec.ts index 3d92fedc733..25341e4bddc 100644 --- a/spec/spellchecker-spec.ts +++ b/spec/spellchecker-spec.ts @@ -1,14 +1,16 @@ import { BrowserWindow, Session, session } from 'electron/main'; import { expect } from 'chai'; -import * as path from 'node:path'; + +import { once } from 'node:events'; import * as fs from 'node:fs/promises'; import * as http from 'node:http'; -import { closeWindow } from './lib/window-helpers'; -import { ifit, ifdescribe, listen } from './lib/spec-helpers'; -import { once } from 'node:events'; +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import { ifit, ifdescribe, listen } from './lib/spec-helpers'; +import { closeWindow } from './lib/window-helpers'; + const features = process._linkedBinding('electron_common_features'); const v8Util = process._linkedBinding('electron_common_v8_util'); diff --git a/spec/ts-smoke/runner.js b/spec/ts-smoke/runner.js index 2584c98b9d3..9099e42866d 100644 --- a/spec/ts-smoke/runner.js +++ b/spec/ts-smoke/runner.js @@ -1,5 +1,5 @@ -const path = require('node:path'); const childProcess = require('node:child_process'); +const path = require('node:path'); const typeCheck = () => { const tscExec = path.resolve(require.resolve('typescript'), '../../bin/tsc'); diff --git a/spec/version-bump-spec.ts b/spec/version-bump-spec.ts index c1117707096..e84d4a82ac5 100644 --- a/spec/version-bump-spec.ts +++ b/spec/version-bump-spec.ts @@ -1,8 +1,9 @@ import { expect } from 'chai'; import { GitProcess, IGitExecutionOptions, IGitResult } from 'dugite'; -import { nextVersion } from '../script/release/version-bumper'; import * as sinon from 'sinon'; + import { ifdescribe } from './lib/spec-helpers'; +import { nextVersion } from '../script/release/version-bumper'; class GitFake { branches: { diff --git a/spec/visibility-state-spec.ts b/spec/visibility-state-spec.ts index 6edfcdf1269..2f23420d803 100644 --- a/spec/visibility-state-spec.ts +++ b/spec/visibility-state-spec.ts @@ -1,13 +1,15 @@ -import { expect } from 'chai'; -import * as cp from 'node:child_process'; import { BaseWindow, BrowserWindow, BrowserWindowConstructorOptions, ipcMain, WebContents, WebContentsView } from 'electron/main'; -import * as path from 'node:path'; -import { closeWindow } from './lib/window-helpers'; -import { ifdescribe } from './lib/spec-helpers'; +import { expect } from 'chai'; + +import * as cp from 'node:child_process'; import { once } from 'node:events'; +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import { ifdescribe } from './lib/spec-helpers'; +import { closeWindow } from './lib/window-helpers'; + // visibilityState specs pass on linux with a real window manager but on CI // the environment does not let these specs pass ifdescribe(process.platform !== 'linux')('document.visibilityState', () => { diff --git a/spec/webview-spec.ts b/spec/webview-spec.ts index 5b7a9bd4be8..377e1192780 100644 --- a/spec/webview-spec.ts +++ b/spec/webview-spec.ts @@ -1,15 +1,18 @@ -import * as path from 'node:path'; -import * as url from 'node:url'; import { BrowserWindow, session, ipcMain, app, WebContents } from 'electron/main'; -import { closeAllWindows } from './lib/window-helpers'; -import { emittedUntil } from './lib/events-helpers'; -import { ifit, ifdescribe, defer, itremote, useRemoteContext, listen } from './lib/spec-helpers'; -import { expect } from 'chai'; -import * as http from 'node:http'; + import * as auth from 'basic-auth'; +import { expect } from 'chai'; + import { once } from 'node:events'; +import * as http from 'node:http'; +import * as path from 'node:path'; import { setTimeout } from 'node:timers/promises'; +import * as url from 'node:url'; + +import { emittedUntil } from './lib/events-helpers'; import { HexColors, ScreenCapture, hasCapturableScreen } from './lib/screen-helpers'; +import { ifit, ifdescribe, defer, itremote, useRemoteContext, listen } from './lib/spec-helpers'; +import { closeAllWindows } from './lib/window-helpers'; declare let WebView: any; const features = process._linkedBinding('electron_common_features'); diff --git a/yarn.lock b/yarn.lock index 98cf8ce273f..424f6bac1c9 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1965,6 +1965,11 @@ caniuse-lite@^1.0.30001366: resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001367.tgz#2b97fe472e8fa29c78c5970615d7cd2ee414108a" integrity sha512-XDgbeOHfifWV3GEES2B8rtsrADx4Jf+juKX2SICJcaUhjYBO3bR96kvEIHa15VU6ohtOhBZuPGGYGbXMRn0NCw== +caniuse-lite@^1.0.30001646: + version "1.0.30001666" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001666.tgz#112d77e80f1762f62a1b71ba92164e0cb3f3dd13" + integrity sha512-gD14ICmoV5ZZM1OdzPWmpx+q4GyefaK06zi8hmfHV5xe4/2nOQX3+Dw5o+fSqOws2xVwL9j+anOPFwHzdEdV4g== + chai@^4.2.0: version "4.2.0" resolved "https://registry.yarnpkg.com/chai/-/chai-4.2.0.tgz#760aa72cf20e3795e84b12877ce0e83737aa29e5" @@ -2459,6 +2464,11 @@ electron-to-chromium@^1.4.188: resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.195.tgz#139b2d95a42a3f17df217589723a1deac71d1473" integrity sha512-vefjEh0sk871xNmR5whJf9TEngX+KTKS3hOHpjoMpauKkwlGwtMz1H8IaIjAT/GNnX0TbGwAdmVoXCAzXf+PPg== +electron-to-chromium@^1.5.4: + version "1.5.31" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.31.tgz#b1478418769dec72ea70d9fdf147a81491857f10" + integrity sha512-QcDoBbQeYt0+3CWcK/rEbuHvwpbT/8SV9T3OSgs6cX1FlcUAkgrkqbg9zLnDrMM/rLamzQwal4LYFCiWk861Tg== + emoji-regex@^8.0.0: version "8.0.0" resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" @@ -2729,6 +2739,11 @@ escalade@^3.1.1: resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== +escalade@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.2.0.tgz#011a3f69856ba189dffa7dc8fcce99d2a87903e5" + integrity sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA== + escape-string-regexp@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" @@ -3309,10 +3324,10 @@ file-entry-cache@^6.0.1: dependencies: flat-cache "^3.0.4" -fill-range@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" - integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== +fill-range@^7.1.1: + version "7.1.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.1.1.tgz#44265d3cac07e3ea7dc247516380643754a05292" + integrity sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg== dependencies: to-regex-range "^5.0.1" @@ -5280,6 +5295,11 @@ node-fetch@^2.6.7: dependencies: whatwg-url "^5.0.0" +node-releases@^2.0.18: + version "2.0.18" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.18.tgz#f010e8d35e2fe8d6b2944f03f70213ecedc4ca3f" + integrity sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g== + node-releases@^2.0.6: version "2.0.6" resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.6.tgz#8a7088c63a55e493845683ebf3c828d8c51c5503" @@ -5676,6 +5696,11 @@ picocolors@^1.0.0: resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== +picocolors@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.1.0.tgz#5358b76a78cde483ba5cef6a9dc9671440b27d59" + integrity sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw== + picomatch@^2.0.4: version "2.0.7" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.0.7.tgz#514169d8c7cd0bdbeecc8a2609e34a7163de69f6" @@ -7737,6 +7762,14 @@ update-browserslist-db@^1.0.4: escalade "^3.1.1" picocolors "^1.0.0" +update-browserslist-db@^1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.1.1.tgz#80846fba1d79e82547fb661f8d141e0945755fe5" + integrity sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A== + dependencies: + escalade "^3.2.0" + picocolors "^1.1.0" + uri-js@^4.2.2: version "4.4.1" resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e"