From 31293ce7dcab8cca2e05f42868481bd4f2292c77 Mon Sep 17 00:00:00 2001 From: Tian Feng Date: Tue, 2 Apr 2024 13:57:30 -0700 Subject: [PATCH] fix: Load TestCafe config from project folder (#224) --- src/testcafe-runner.ts | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/src/testcafe-runner.ts b/src/testcafe-runner.ts index 67d645b3..4ff48325 100644 --- a/src/testcafe-runner.ts +++ b/src/testcafe-runner.ts @@ -263,8 +263,8 @@ export function buildCommandLine( // If the 'disableNativeAutomation' setting is enabled in the configuration, // it indicates that the CDP connection is disabled, and TestCafe uses its own // proxy to communicate with the browser. -function isCDPDisabled() { - const cfg = require(path.join(__dirname, 'sauce-testcafe-config.cjs')); +function isCDPDisabled(projectPath: string) { + const cfg = require(path.join(projectPath, 'sauce-testcafe-config.cjs')); return cfg.disableNativeAutomation; } @@ -346,20 +346,6 @@ async function run(nodeBin: string, runCfgPath: string, suiteName: string) { suiteName, ); - // TestCafe used a reverse proxy for browser automation before. - // With TestCafe 3.0.0 and later, native automation mode was enabled by default, - // see https://testcafe.io/documentation/404237/guides/intermediate-guides/native-automation-mode, - // introducing CDP support for Chrome and Edge. - // This means that HTTP requests can't be routed through the reverse proxy anymore. - // Now, we need to set up an OS-level proxy connection. - if ( - isChromiumBased(suite.browserName) && - !isCDPDisabled() && - isProxyAvailable() - ) { - setupProxy(); - } - if (!(await preExec.run({ preExec: suite.preExec }, preExecTimeout))) { return false; } @@ -375,6 +361,20 @@ async function run(nodeBin: string, runCfgPath: string, suiteName: string) { configFile, ); + // TestCafe used a reverse proxy for browser automation before. + // With TestCafe 3.0.0 and later, native automation mode was enabled by default, + // see https://testcafe.io/documentation/404237/guides/intermediate-guides/native-automation-mode, + // introducing CDP support for Chrome and Edge. + // This means that HTTP requests can't be routed through the reverse proxy anymore. + // Now, we need to set up an OS-level proxy connection. + if ( + isChromiumBased(suite.browserName) && + !isCDPDisabled(projectPath) && + isProxyAvailable() + ) { + setupProxy(); + } + // saucectl suite.timeout is in nanoseconds, convert to seconds const timeout = (suite.timeout || 0) / 1_000_000_000 || 30 * 60; // 30min default