mirror of
https://github.com/Llewellynvdm/nativefier.git
synced 2025-01-05 07:02:10 +00:00
Fix playwright tests on Linux (#1440)
This commit is contained in:
parent
0de2463f2b
commit
82ff609a91
@ -117,18 +117,23 @@ const fileDownloadOptions = { ...appArgs.fileDownloadOptions };
|
|||||||
electronDownload(fileDownloadOptions);
|
electronDownload(fileDownloadOptions);
|
||||||
|
|
||||||
if (appArgs.processEnvs) {
|
if (appArgs.processEnvs) {
|
||||||
|
let processEnvs: Record<string, string> =
|
||||||
|
appArgs.processEnvs as unknown as Record<string, string>;
|
||||||
// This is compatibility if just a string was passed.
|
// This is compatibility if just a string was passed.
|
||||||
if (typeof appArgs.processEnvs === 'string') {
|
if (typeof appArgs.processEnvs === 'string') {
|
||||||
process.env.processEnvs = appArgs.processEnvs;
|
try {
|
||||||
} else {
|
processEnvs = JSON.parse(appArgs.processEnvs) as Record<string, string>;
|
||||||
Object.keys(appArgs.processEnvs)
|
} catch {
|
||||||
.filter((key) => key !== undefined)
|
// This wasn't JSON. Fall back to the old code
|
||||||
.forEach((key) => {
|
processEnvs = {};
|
||||||
// @ts-expect-error TS will complain this could be undefined, but we filtered those out
|
process.env.processEnvs = appArgs.processEnvs;
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
}
|
||||||
process.env[key] = appArgs.processEnvs[key];
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
Object.keys(processEnvs)
|
||||||
|
.filter((key) => key !== undefined)
|
||||||
|
.forEach((key) => {
|
||||||
|
process.env[key] = processEnvs[key];
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof appArgs.flashPluginDir === 'string') {
|
if (typeof appArgs.flashPluginDir === 'string') {
|
||||||
|
@ -27,6 +27,17 @@ export function hasWine(): boolean {
|
|||||||
return hasbin.sync('wine');
|
return hasbin.sync('wine');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// I tried to place this (and the other is* functions) in
|
||||||
|
// a new shared helpers, but alas eslint gets real confused
|
||||||
|
// about the type signatures and thinks they're all any.
|
||||||
|
// TODO: Figure out a way to refactor duplicate code from
|
||||||
|
// src/helpers/helpers.ts and app/src/helpers/helpers.ts
|
||||||
|
// into the shared module
|
||||||
|
|
||||||
|
export function isLinux(): boolean {
|
||||||
|
return os.platform() === 'linux';
|
||||||
|
}
|
||||||
|
|
||||||
export function isOSX(): boolean {
|
export function isOSX(): boolean {
|
||||||
return os.platform() === 'darwin';
|
return os.platform() === 'darwin';
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@ import {
|
|||||||
Page,
|
Page,
|
||||||
} from 'playwright';
|
} from 'playwright';
|
||||||
|
|
||||||
import { getTempDir } from './helpers/helpers';
|
import { getTempDir, isLinux } from './helpers/helpers';
|
||||||
import { NativefierOptions } from '../shared/src/options/model';
|
import { NativefierOptions } from '../shared/src/options/model';
|
||||||
|
|
||||||
const INJECT_DIR = path.join(__dirname, '..', 'app', 'inject');
|
const INJECT_DIR = path.join(__dirname, '..', 'app', 'inject');
|
||||||
@ -70,11 +70,26 @@ describe('Application launch', () => {
|
|||||||
.catch(() => log.log('window.console', consoleMessage));
|
.catch(() => log.log('window.console', consoleMessage));
|
||||||
};
|
};
|
||||||
app = await _electron.launch({
|
app = await _electron.launch({
|
||||||
args: [appMainJSPath],
|
// Workaround for the following errors in some linux distros:
|
||||||
|
// pw:browser [pid=24716][err] [24718:0100/000000.660708:ERROR:zygote_linux.cc(650)] write: Broken pipe (32) +16ms
|
||||||
|
// pw:browser [pid=24719][err] [24719:0725/114519.722060:FATAL:setuid_sandbox_host.cc(157)] The SUID sandbox helper binary was found, but is not configured correctly. Rather than run without sandboxing I'm aborting now. You need to make sure that /home/parallels/Dev/nativefier/node_modules/electron/dist/chrome-sandbox is owned by root and has mode 4755. +61ms
|
||||||
|
args: isLinux()
|
||||||
|
? ['--no-sandbox', '--disable-setuid-sandbox', appMainJSPath]
|
||||||
|
: [appMainJSPath],
|
||||||
env: {
|
env: {
|
||||||
LOG_FILE_DIR: logFileDir,
|
LOG_FILE_DIR: logFileDir,
|
||||||
PLAYWRIGHT_TEST: '1',
|
PLAYWRIGHT_TEST: '1',
|
||||||
PLAYWRIGHT_CONFIG: JSON.stringify(playwrightConfig),
|
PLAYWRIGHT_CONFIG: JSON.stringify({
|
||||||
|
...playwrightConfig,
|
||||||
|
// disableGpu and process.env.DISPLAY forwarding solve the following errors on Linux:
|
||||||
|
// pw:browser [pid=286188][err] [286188:0724/102939.938248:ERROR:ozone_platform_x11.cc(248)] Missing X server or $DISPLAY +77ms
|
||||||
|
// pw:browser [pid=286188][err] [286188:0724/102939.938299:ERROR:env.cc(225)] The platform failed to initialize. Exiting. +2ms
|
||||||
|
disableGpu: isLinux() ? true : undefined,
|
||||||
|
processEnvs:
|
||||||
|
isLinux() && process.env.DISPLAY
|
||||||
|
? JSON.stringify({ DISPLAY: process.env.DISPLAY })
|
||||||
|
: undefined,
|
||||||
|
} as NativefierOptions),
|
||||||
USE_LOG_FILE: '1',
|
USE_LOG_FILE: '1',
|
||||||
VERBOSE: '1',
|
VERBOSE: '1',
|
||||||
},
|
},
|
||||||
@ -344,24 +359,29 @@ describe('Application launch', () => {
|
|||||||
const loginWindow = appWindows.filter((x) => x !== mainWindow)[0];
|
const loginWindow = appWindows.filter((x) => x !== mainWindow)[0];
|
||||||
|
|
||||||
await loginWindow.waitForLoadState('domcontentloaded');
|
await loginWindow.waitForLoadState('domcontentloaded');
|
||||||
|
await loginWindow.waitForLoadState('load');
|
||||||
|
|
||||||
const usernameField = await loginWindow.$('#username-input');
|
const usernameField = await loginWindow.$('#username-input');
|
||||||
|
|
||||||
expect(usernameField).not.toBeNull();
|
expect(usernameField).not.toBeNull();
|
||||||
|
await usernameField?.fill('foo');
|
||||||
|
|
||||||
const passwordField = await loginWindow.$('#password-input');
|
const passwordField = await loginWindow.$('#password-input');
|
||||||
|
|
||||||
expect(passwordField).not.toBeNull();
|
expect(passwordField).not.toBeNull();
|
||||||
|
await passwordField?.fill('bar');
|
||||||
|
|
||||||
const submitButton = await loginWindow.$('#submit-form-button');
|
const submitButton = await loginWindow.$('#submit-form-button');
|
||||||
|
|
||||||
expect(submitButton).not.toBeNull();
|
expect(submitButton).not.toBeNull();
|
||||||
|
|
||||||
await usernameField?.fill('foo');
|
// "Why is this here?" you may be asking yourself.
|
||||||
await passwordField?.fill('bar');
|
// Because for some reason, on some linux boxes,
|
||||||
|
// the click function will not work until this is done.
|
||||||
|
// Why? I do not have access to the dark incantation
|
||||||
|
// that would allow me to know such information.
|
||||||
|
log.log({ submitButton });
|
||||||
|
|
||||||
await submitButton?.click();
|
await submitButton?.click();
|
||||||
|
|
||||||
await mainWindow.waitForLoadState('networkidle');
|
await mainWindow.waitForEvent('load');
|
||||||
|
|
||||||
const documentText = await mainWindow.evaluate<string>(
|
const documentText = await mainWindow.evaluate<string>(
|
||||||
'document.documentElement.innerText',
|
'document.documentElement.innerText',
|
||||||
|
Loading…
Reference in New Issue
Block a user