Skip to content

Commit

Permalink
fix: add missing command types (moveCursorTo and openAndWait)
Browse files Browse the repository at this point in the history
  • Loading branch information
shadowusr committed Mar 20, 2024
1 parent 4dc6c2f commit 970edd0
Show file tree
Hide file tree
Showing 13 changed files with 58 additions and 46 deletions.
2 changes: 1 addition & 1 deletion src/browser/browser.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ const _ = require("lodash");
const { SAVE_HISTORY_MODE } = require("../constants/config");
const { X_REQUEST_ID_DELIMITER } = require("../constants/browser");
const history = require("./history");
const addRunStepCommand = require("./commands/runStep");
const addRunStepCommand = require("./commands/runStep").default;

const CUSTOM_SESSION_OPTS = [
"outputDir",
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/assert-view/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ const getIgnoreDiffPixelCountRatio = value => {
return percent / 100;
};

module.exports = browser => {
module.exports.default = browser => {
const screenShooter = ScreenShooter.create(browser);
const { publicAPI: session, config } = browser;
const {
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/clearSession.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import type { Browser } from "../types";
import logger from "../../utils/logger";

export = async (browser: Browser): Promise<void> => {
export default async (browser: Browser): Promise<void> => {
const { publicAPI: session } = browser;

const clearStorage = async (storageName: "localStorage" | "sessionStorage"): Promise<void> => {
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/getConfig.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
"use strict";

module.exports = browser => {
module.exports.default = browser => {
const { publicAPI: session, config } = browser;
session.addCommand("getConfig", () => config);
};
2 changes: 1 addition & 1 deletion src/browser/commands/getPuppeteer.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

const urljoin = require("url-join");

module.exports = browser => {
module.exports.default = browser => {
const { publicAPI: session, config } = browser;

if (!config.browserWSEndpoint || !session.getPuppeteer) {
Expand Down
48 changes: 25 additions & 23 deletions src/browser/commands/moveCursorTo.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,30 +5,32 @@ type MoveToOptions = {
yOffset?: number;
};

// As of now, we can't export type of the command function directly. See: https://github.com/webdriverio/webdriverio/issues/12527
export type MoveCursorToCommand = (options: MoveToOptions) => Promise<void>;

const makeMoveCursorToCommand = (session: WebdriverIO.Browser) =>
async function (this: WebdriverIO.Element, { xOffset = 0, yOffset = 0 }: MoveToOptions = {}): Promise<void> {
if (!this.isW3C) {
return this.moveToElement(this.elementId, xOffset, yOffset);
}

const { x, y, width, height } = await this.getElementRect(this.elementId);
const { scrollX, scrollY } = await session.execute(function (this: Window) {
return { scrollX: this.scrollX, scrollY: this.scrollY };
});

const newXOffset = Math.floor(x - scrollX + (typeof xOffset === "number" ? xOffset : width / 2));
const newYOffset = Math.floor(y - scrollY + (typeof yOffset === "number" ? yOffset : height / 2));

return session
.action("pointer", { parameters: { pointerType: "mouse" } })
.move({ x: newXOffset, y: newYOffset })
.perform();
};

// TODO: remove after next major version
export = async (browser: Browser): Promise<void> => {
export default async (browser: Browser): Promise<void> => {
const { publicAPI: session } = browser;

session.addCommand(
"moveCursorTo",
async function (this: WebdriverIO.Element, { xOffset = 0, yOffset = 0 }: MoveToOptions = {}): Promise<void> {
if (!this.isW3C) {
return this.moveToElement(this.elementId, xOffset, yOffset);
}

const { x, y, width, height } = await this.getElementRect(this.elementId);
const { scrollX, scrollY } = await session.execute(function (this: Window) {
return { scrollX: this.scrollX, scrollY: this.scrollY };
});

const newXOffset = Math.floor(x - scrollX + (typeof xOffset === "number" ? xOffset : width / 2));
const newYOffset = Math.floor(y - scrollY + (typeof yOffset === "number" ? yOffset : height / 2));

return session
.action("pointer", { parameters: { pointerType: "mouse" } })
.move({ x: newXOffset, y: newYOffset })
.perform();
},
true,
);
session.addCommand("moveCursorTo", makeMoveCursorToCommand(session), true);
};
30 changes: 17 additions & 13 deletions src/browser/commands/openAndWait.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import _ from "lodash";
import { Matches } from "webdriverio";
import PageLoader from "../../utils/page-loader";
import type { Browser } from "../types";
import { BrowserConfig } from "../../config/browser-config";

interface WaitOpts {
selector?: string | string[];
Expand All @@ -23,25 +24,23 @@ const is: Record<string, (match: Matches) => boolean> = {
favicon: match => _.isString(match.url) && match.url.endsWith("/favicon.ico"),
};

export = (browser: Browser): void => {
const { publicAPI: session, config } = browser;
const { openAndWaitOpts } = config;
const isChrome = config.desiredCapabilities?.browserName === "chrome";
const isCDP = config.automationProtocol === "devtools";

const makeOpenAndWaitCommand = (config: BrowserConfig, session: WebdriverIO.Browser) =>
function openAndWait(
uri: string,
{
selector = [],
predicate,
waitNetworkIdle = openAndWaitOpts?.waitNetworkIdle,
waitNetworkIdleTimeout = openAndWaitOpts?.waitNetworkIdleTimeout,
failOnNetworkError = openAndWaitOpts?.failOnNetworkError,
waitNetworkIdle = config.openAndWaitOpts?.waitNetworkIdle,
waitNetworkIdleTimeout = config.openAndWaitOpts?.waitNetworkIdleTimeout,
failOnNetworkError = config.openAndWaitOpts?.failOnNetworkError,
shouldThrowError = shouldThrowErrorDefault,
ignoreNetworkErrorsPatterns = openAndWaitOpts?.ignoreNetworkErrorsPatterns,
timeout = openAndWaitOpts?.timeout || config?.pageLoadTimeout || 0,
ignoreNetworkErrorsPatterns = config.openAndWaitOpts?.ignoreNetworkErrorsPatterns,
timeout = config.openAndWaitOpts?.timeout || config?.pageLoadTimeout || 0,
}: WaitOpts = {},
): Promise<string | void> {
const isChrome = config.desiredCapabilities?.browserName === "chrome";
const isCDP = config.automationProtocol === "devtools";

waitNetworkIdle &&= isChrome || isCDP;

if (!uri || uri === emptyPageUrl) {
Expand Down Expand Up @@ -110,9 +109,14 @@ export = (browser: Browser): void => {

pageLoader.load(goToPage).then(checkLoaded);
}).finally(() => pageLoader.unsubscribe());
}
};

export type OpenAndWaitCommand = ReturnType<typeof makeOpenAndWaitCommand>;

export default (browser: Browser): void => {
const { publicAPI: session, config } = browser;

session.addCommand("openAndWait", openAndWait);
session.addCommand("openAndWait", makeOpenAndWaitCommand(config, session));
};

function isMatchPatterns(patterns: Array<RegExp | string> = [], str: string): boolean {
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/runStep.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

const _ = require("lodash");

module.exports = browser => {
module.exports.default = browser => {
const { publicAPI: session } = browser;
session.addCommand("runStep", (stepName, stepCb) => {
if (!_.isString(stepName)) {
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/scrollIntoView.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import type { Browser } from "../types";

// TODO: remove after fix https://github.com/webdriverio/webdriverio/issues/9620
export = async (browser: Browser): Promise<void> => {
export default async (browser: Browser): Promise<void> => {
const { publicAPI: session } = browser;

session.overwriteCommand(
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/setOrientation.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/* global document */
"use strict";

module.exports = browser => {
module.exports.default = browser => {
const { publicAPI: session, config } = browser;

if (!session.setOrientation) {
Expand Down
2 changes: 1 addition & 1 deletion src/browser/commands/switchToRepl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import type { Browser } from "../types";

const REPL_LINE_EVENT = "line";

export = async (browser: Browser): Promise<void> => {
export default async (browser: Browser): Promise<void> => {
const { publicAPI: session } = browser;

const applyContext = (replServer: repl.REPLServer, ctx: Record<string, unknown> = {}): void => {
Expand Down
2 changes: 1 addition & 1 deletion src/browser/existing-browser.js
Original file line number Diff line number Diff line change
Expand Up @@ -181,7 +181,7 @@ module.exports = class ExistingBrowser extends Browser {
this._addMetaAccessCommands(this._session);
this._decorateUrlMethod(this._session);

commandsList.forEach(command => require(`./commands/${command}`)(this));
commandsList.forEach(command => require(`./commands/${command}`).default(this));

super._addCommands();
}
Expand Down
6 changes: 6 additions & 0 deletions src/browser/types.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import type { AssertViewCommand, AssertViewElementCommand } from "./commands/types";
import type { BrowserConfig } from "./../config/browser-config";
import type { AssertViewResult, RunnerTest, RunnerHook } from "../types";
import { MoveCursorToCommand } from "./commands/moveCursorTo";
import { OpenAndWaitCommand } from "./commands/openAndWait";

export interface BrowserMeta {
pid: number;
Expand Down Expand Up @@ -107,6 +109,8 @@ declare global {
};
};

openAndWait: OpenAndWaitCommand;

switchToRepl: (ctx?: Record<string, unknown>) => Promise<void>;

clearSession: () => Promise<void>;
Expand Down Expand Up @@ -144,6 +148,8 @@ declare global {
* "compositeImage", "screenshotDelay", "selectorToScroll"
*/
assertView: AssertViewElementCommand;

moveCursorTo: MoveCursorToCommand;
}
}
}

0 comments on commit 970edd0

Please sign in to comment.