Skip to content

Commit

Permalink
fix: fixes issues with older browsers / caps
Browse files Browse the repository at this point in the history
  • Loading branch information
wswebcreation committed Oct 29, 2020
1 parent 53b1218 commit 97315f3
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 11 deletions.
28 changes: 17 additions & 11 deletions src/process-config.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
import {bootstrap} from 'global-agent'
import {isW3C} from "./utils";

export function processConfig (config: any = {}, args: any = {}) {
export function processConfig(config: any = {}, args: any = {}) {
const username = config.username || process.env.SAUCE_USERNAME;
const accessKey = config.accessKey || process.env.SAUCE_ACCESS_KEY;
const startConnect = config.startConnect !== false;

let tunnelIdentifier = args.tunnelIdentifier || config.tunnelIdentifier;

// TODO: This option is very ambiguous because it technically only affects the reporter. Consider
// TODO: This option is very ambiguous because it technically only affects the reporter. Consider
// renaming in the future.
const sauceApiProxy = args.proxy || config.proxy;
if (sauceApiProxy) {
Expand All @@ -20,9 +21,7 @@ export function processConfig (config: any = {}, args: any = {}) {
}

// Browser name that will be printed out by Karma.
const browserName = args.browserName +
(args.version ? ' ' + args.version : '') +
(args.platform ? ' (' + args.platform + ')' : '');
const browserName = `${args.browserName} ${args.browserVersion || args.version || ''} ${args.platformName || args.platform || ''}`;

// In case "startConnect" is enabled, and no tunnel identifier has been specified, we just
// generate one randomly. This makes it possible for developers to use "startConnect" with
Expand Down Expand Up @@ -53,20 +52,27 @@ export function processConfig (config: any = {}, args: any = {}) {
};

// transform JWP capabilities into W3C capabilities for backward compatibility
args.browserVersion = args.browserVersion || args.version || 'latest'
args.platformName = args.platformName || args.platform || 'Windows 10'
// delete JWP capabilities
if (isW3C(args)) {
args.browserVersion = args.browserVersion || args.version || 'latest'
args.platformName = args.platformName || args.platform || 'Windows 10'
args['sauce:options'] = args['sauce:options'] ? {...args['sauce:options'], ...capabilitiesFromConfig} : capabilitiesFromConfig

// delete JWP capabilities
delete args.version
delete args.platform
} else {
args = {...args, ...capabilitiesFromConfig}
}
// Not needed
delete args.base
delete args.version
delete args.platform

const seleniumCapabilities = {
user: username,
key: accessKey,
region: config.region,
headless: config.headless,
logLevel: 'error',
capabilities: {
'sauce:options': capabilitiesFromConfig,
...args
},
...config.options
Expand Down
5 changes: 5 additions & 0 deletions src/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,8 @@ export async function waitUntil({condition, retries = 0, maxRetries = 50, interv

return waitUntil({condition, retries: retries++, maxRetries, interval})
}

export function isW3C(capabilities){
// Only browserVersion is mandatory, platformName is optional
return Boolean(capabilities.browserVersion)
}

0 comments on commit 97315f3

Please sign in to comment.