56dfcc5468
* chore: bump chromium in DEPS to 124.0.6315.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * chore: update patches Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 5279678: Stream AIDA responses https://chromium-review.googlesource.com/c/chromium/src/+/5279678 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 5276439: Remove non_network_url_loader_factory_remotes_ https://chromium-review.googlesource.com/c/chromium/src/+/5276439 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 5310165: Add DevTools API to show search results https://chromium-review.googlesource.com/c/chromium/src/+/5310165 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: bump chromium in DEPS to 124.0.6317.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * chore: update patches Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * Remove Setup.Install.CumulativeDiskUsage2 and supporting code https://chromium-review.googlesource.com/c/chromium/src/+/5314269 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * browser: Make cmd line non-const in process singleton callback https://chromium-review.googlesource.com/c/chromium/src/+/5311256 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: bump chromium in DEPS to 124.0.6319.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * chore: bump chromium in DEPS to 124.0.6321.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * chore: bump chromium in DEPS to 124.0.6323.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * 5318335: Roll src/third_party/boringssl/src 23824fa0f..4fe29ebc7 https://chromium-review.googlesource.com/c/chromium/src/+/5318335 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * 5318051: [CBE Watermarking] Hoist `watermark_view` to a member variable. https://chromium-review.googlesource.com/c/chromium/src/+/5318051 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * chore: fixup patch indices Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * 4946553: Delegate HID permission to Chrome App in webview https://chromium-review.googlesource.com/c/chromium/src/+/4946553 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * 5310001: DevTools UI binding for reporting client events to AIDA https://chromium-review.googlesource.com/c/chromium/src/+/5310001 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * Refactor the predicate taking variant of `__cxx_atomic_wait` Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * chore: fix browser_view patch harder Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * 5293937: Reland "[gUM] Use preferred device if more than one is eligible" https://chromium-review.googlesource.com/c/chromium/src/+/5293937 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * fix: filter {video|audio} devices by eligible device id Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * 5267921: enable speak content under the pointer on PWA and WV2 https://chromium-review.googlesource.com/c/chromium/src/+/5267921 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * 5310195: heap: Remove Blink's GCTaskRunner https://chromium-review.googlesource.com/c/chromium/src/+/5310195 Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> --------- Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com>
207 lines
7.9 KiB
TypeScript
207 lines
7.9 KiB
TypeScript
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', () => {
|
|
describe('renderer process', () => {
|
|
let w: BrowserWindow;
|
|
before(async () => {
|
|
w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: true, contextIsolation: false } });
|
|
await w.loadURL('about:blank');
|
|
});
|
|
after(closeAllWindows);
|
|
|
|
describe('process.getCreationTime()', () => {
|
|
it('returns a creation time', async () => {
|
|
const creationTime = await w.webContents.executeJavaScript('process.getCreationTime()');
|
|
expect(creationTime).to.be.a('number').and.be.at.least(0);
|
|
});
|
|
});
|
|
|
|
describe('process.getCPUUsage()', () => {
|
|
it('returns a cpu usage object', async () => {
|
|
const cpuUsage = await w.webContents.executeJavaScript('process.getCPUUsage()');
|
|
expect(cpuUsage.percentCPUUsage).to.be.a('number');
|
|
expect(cpuUsage.idleWakeupsPerSecond).to.be.a('number');
|
|
});
|
|
});
|
|
|
|
describe('process.getBlinkMemoryInfo()', () => {
|
|
it('returns blink memory information object', async () => {
|
|
const heapStats = await w.webContents.executeJavaScript('process.getBlinkMemoryInfo()');
|
|
expect(heapStats.allocated).to.be.a('number');
|
|
expect(heapStats.total).to.be.a('number');
|
|
});
|
|
});
|
|
|
|
describe('process.getProcessMemoryInfo()', () => {
|
|
it('resolves promise successfully with valid data', async () => {
|
|
const memoryInfo = await w.webContents.executeJavaScript('process.getProcessMemoryInfo()');
|
|
expect(memoryInfo).to.be.an('object');
|
|
if (process.platform === 'linux' || process.platform === 'win32') {
|
|
expect(memoryInfo.residentSet).to.be.a('number').greaterThan(0);
|
|
}
|
|
expect(memoryInfo.private).to.be.a('number').greaterThan(0);
|
|
// Shared bytes can be zero
|
|
expect(memoryInfo.shared).to.be.a('number').greaterThan(-1);
|
|
});
|
|
});
|
|
|
|
describe('process.getSystemMemoryInfo()', () => {
|
|
it('returns system memory info object', async () => {
|
|
const systemMemoryInfo = await w.webContents.executeJavaScript('process.getSystemMemoryInfo()');
|
|
expect(systemMemoryInfo.free).to.be.a('number');
|
|
expect(systemMemoryInfo.total).to.be.a('number');
|
|
});
|
|
});
|
|
|
|
describe('process.getSystemVersion()', () => {
|
|
it('returns a string', async () => {
|
|
const systemVersion = await w.webContents.executeJavaScript('process.getSystemVersion()');
|
|
expect(systemVersion).to.be.a('string');
|
|
});
|
|
});
|
|
|
|
describe('process.getHeapStatistics()', () => {
|
|
it('returns heap statistics object', async () => {
|
|
const heapStats = await w.webContents.executeJavaScript('process.getHeapStatistics()');
|
|
expect(heapStats.totalHeapSize).to.be.a('number');
|
|
expect(heapStats.totalHeapSizeExecutable).to.be.a('number');
|
|
expect(heapStats.totalPhysicalSize).to.be.a('number');
|
|
expect(heapStats.totalAvailableSize).to.be.a('number');
|
|
expect(heapStats.usedHeapSize).to.be.a('number');
|
|
expect(heapStats.heapSizeLimit).to.be.a('number');
|
|
expect(heapStats.mallocedMemory).to.be.a('number');
|
|
expect(heapStats.peakMallocedMemory).to.be.a('number');
|
|
expect(heapStats.doesZapGarbage).to.be.a('boolean');
|
|
});
|
|
});
|
|
|
|
describe('process.takeHeapSnapshot()', () => {
|
|
it('returns true on success', async () => {
|
|
const filePath = path.join(app.getPath('temp'), 'test.heapsnapshot');
|
|
defer(() => {
|
|
try {
|
|
fs.unlinkSync(filePath);
|
|
} catch {
|
|
// ignore error
|
|
}
|
|
});
|
|
|
|
const success = await w.webContents.executeJavaScript(`process.takeHeapSnapshot(${JSON.stringify(filePath)})`);
|
|
expect(success).to.be.true();
|
|
const stats = fs.statSync(filePath);
|
|
expect(stats.size).not.to.be.equal(0);
|
|
});
|
|
|
|
it('returns false on failure', async () => {
|
|
const success = await w.webContents.executeJavaScript('process.takeHeapSnapshot("")');
|
|
expect(success).to.be.false();
|
|
});
|
|
});
|
|
|
|
describe('process.contextId', () => {
|
|
it('is a string', async () => {
|
|
const contextId = await w.webContents.executeJavaScript('process.contextId');
|
|
expect(contextId).to.be.a('string');
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('main process', () => {
|
|
describe('process.getCreationTime()', () => {
|
|
it('returns a creation time', () => {
|
|
const creationTime = process.getCreationTime();
|
|
expect(creationTime).to.be.a('number').and.be.at.least(0);
|
|
});
|
|
});
|
|
|
|
describe('process.getCPUUsage()', () => {
|
|
it('returns a cpu usage object', () => {
|
|
const cpuUsage = process.getCPUUsage();
|
|
expect(cpuUsage.percentCPUUsage).to.be.a('number');
|
|
expect(cpuUsage.idleWakeupsPerSecond).to.be.a('number');
|
|
});
|
|
});
|
|
|
|
describe('process.getBlinkMemoryInfo()', () => {
|
|
it('returns blink memory information object', () => {
|
|
const heapStats = process.getBlinkMemoryInfo();
|
|
expect(heapStats.allocated).to.be.a('number');
|
|
expect(heapStats.total).to.be.a('number');
|
|
});
|
|
});
|
|
|
|
describe('process.getProcessMemoryInfo()', () => {
|
|
it('resolves promise successfully with valid data', async () => {
|
|
const memoryInfo = await process.getProcessMemoryInfo();
|
|
expect(memoryInfo).to.be.an('object');
|
|
if (process.platform === 'linux' || process.platform === 'win32') {
|
|
expect(memoryInfo.residentSet).to.be.a('number').greaterThan(0);
|
|
}
|
|
expect(memoryInfo.private).to.be.a('number').greaterThan(0);
|
|
// Shared bytes can be zero
|
|
expect(memoryInfo.shared).to.be.a('number').greaterThan(-1);
|
|
});
|
|
});
|
|
|
|
describe('process.getSystemMemoryInfo()', () => {
|
|
it('returns system memory info object', () => {
|
|
const systemMemoryInfo = process.getSystemMemoryInfo();
|
|
expect(systemMemoryInfo.free).to.be.a('number');
|
|
expect(systemMemoryInfo.total).to.be.a('number');
|
|
});
|
|
});
|
|
|
|
describe('process.getSystemVersion()', () => {
|
|
it('returns a string', () => {
|
|
const systemVersion = process.getSystemVersion();
|
|
expect(systemVersion).to.be.a('string');
|
|
});
|
|
});
|
|
|
|
describe('process.getHeapStatistics()', () => {
|
|
it('returns heap statistics object', async () => {
|
|
const heapStats = process.getHeapStatistics();
|
|
expect(heapStats.totalHeapSize).to.be.a('number');
|
|
expect(heapStats.totalHeapSizeExecutable).to.be.a('number');
|
|
expect(heapStats.totalPhysicalSize).to.be.a('number');
|
|
expect(heapStats.totalAvailableSize).to.be.a('number');
|
|
expect(heapStats.usedHeapSize).to.be.a('number');
|
|
expect(heapStats.heapSizeLimit).to.be.a('number');
|
|
expect(heapStats.mallocedMemory).to.be.a('number');
|
|
expect(heapStats.peakMallocedMemory).to.be.a('number');
|
|
expect(heapStats.doesZapGarbage).to.be.a('boolean');
|
|
});
|
|
});
|
|
|
|
describe('process.takeHeapSnapshot()', () => {
|
|
// DISABLED-FIXME(nornagon): this seems to take a really long time when run in the
|
|
// main process, for unknown reasons.
|
|
it('returns true on success', () => {
|
|
const filePath = path.join(app.getPath('temp'), 'test.heapsnapshot');
|
|
defer(() => {
|
|
try {
|
|
fs.unlinkSync(filePath);
|
|
} catch {
|
|
// ignore error
|
|
}
|
|
});
|
|
|
|
const success = process.takeHeapSnapshot(filePath);
|
|
expect(success).to.be.true();
|
|
const stats = fs.statSync(filePath);
|
|
expect(stats.size).not.to.be.equal(0);
|
|
});
|
|
|
|
it('returns false on failure', async () => {
|
|
const success = process.takeHeapSnapshot('');
|
|
expect(success).to.be.false();
|
|
});
|
|
});
|
|
});
|
|
});
|