Skip to content

Commit

Permalink
Merge pull request #818 from gemini-testing/HERMIONE-1273.fix_disable…
Browse files Browse the repository at this point in the history
…_animation_ios_hermione7

fix: correctly disable animations in iframes for ios
  • Loading branch information
DudaGod authored Dec 19, 2023
2 parents 8e3e247 + d53c157 commit f7719c8
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 24 deletions.
5 changes: 4 additions & 1 deletion src/browser/existing-browser.js
Original file line number Diff line number Diff line change
Expand Up @@ -302,7 +302,10 @@ module.exports = class ExistingBrowser extends Browser {
await cb();
}
} finally {
await this._session.switchToParentFrame();
if (!_.isEmpty(iframes)) {
// switchToParentFrame does not work in ios - https://github.com/appium/appium/issues/14882
await this._session.switchToFrame(null);
}
}
}

Expand Down
63 changes: 45 additions & 18 deletions test/src/browser/existing-browser.js
Original file line number Diff line number Diff line change
Expand Up @@ -725,15 +725,16 @@ describe("ExistingBrowser", () => {
it("should disable animations if 'disableAnimation: true' and 'automationProtocol: webdriver'", async () => {
const clientBridge = stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "webdriver" }));
const [wdElement] = await browser.publicAPI.findElements("css selector", ".some-selector");
const iframeElement = { "element-12345": "67890_element_1" };
browser.publicAPI.findElements.withArgs("css selector", "iframe").resolves([iframeElement]);

await browser.prepareScreenshot(".selector", { disableAnimation: true });

assert.calledWith(clientBridge.call, "prepareScreenshot", [
".selector",
sinon.match({ disableAnimation: true }),
]);
assert.calledOnceWith(browser.publicAPI.switchToFrame, wdElement);
assert.calledWith(browser.publicAPI.switchToFrame, iframeElement);
assert.calledWith(clientBridge.call, "disableFrameAnimations");
});

Expand All @@ -754,15 +755,16 @@ describe("ExistingBrowser", () => {
it("should not disable animations if 'disableAnimation: false'", async () => {
const clientBridge = stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "webdriver" }));
const [wdElement] = await browser.publicAPI.findElements("css selector", ".some-selector");
const iframeElement = { "element-12345": "67890_element_1" };
browser.publicAPI.findElements.withArgs("css selector", "iframe").resolves([iframeElement]);

await browser.prepareScreenshot(".selector", { disableAnimation: false });

assert.neverCalledWith(clientBridge.call, "prepareScreenshot", [
".selector",
sinon.match({ disableAnimation: true }),
]);
assert.neverCalledWith(browser.publicAPI.switchToFrame, wdElement);
assert.neverCalledWith(browser.publicAPI.switchToFrame, iframeElement);
assert.neverCalledWith(clientBridge.call, "disableFrameAnimations");
});
});
Expand All @@ -786,27 +788,52 @@ describe("ExistingBrowser", () => {
assert.neverCalledWith(clientBridge.call, "cleanupFrameAnimations");
});

it("should cleanup animations in iframe if 'automationProtocol: webdriver'", async () => {
const clientBridge = stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "webdriver" }));
const [wdElement] = await browser.publicAPI.findElements("css selector", ".some-selector");
it("should not cleanup animations in iframe if 'automationProtocol: devtools'", async () => {
stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "devtools" }));

await browser.cleanupScreenshot({ disableAnimation: true });

assert.calledOnceWith(browser.publicAPI.switchToFrame, wdElement);
assert.calledWith(clientBridge.call, "cleanupFrameAnimations");
assert.callOrder(browser.publicAPI.switchToFrame, clientBridge.call);
assert.notCalled(browser.publicAPI.switchToFrame);
});

it("should not cleanup animations in iframe if 'automationProtocol: devtools'", async () => {
const clientBridge = stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "devtools" }));
const [wdElement] = await browser.publicAPI.findElements("css selector", ".some-selector");
describe("'automationProtocol: webdriver'", () => {
it("should cleanup animations in iframe", async () => {
const clientBridge = stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "webdriver" }));
const iframeElement = { "element-12345": "67890_element_1" };
browser.publicAPI.findElements.withArgs("css selector", "iframe").resolves([iframeElement]);

await browser.cleanupScreenshot({ disableAnimation: true });
await browser.cleanupScreenshot({ disableAnimation: true });

assert.notCalled(browser.publicAPI.switchToFrame);
assert.neverCalledWith(clientBridge.call, "cleanupFrameAnimations", wdElement);
assert.calledWith(browser.publicAPI.switchToFrame, iframeElement);
assert.calledWith(clientBridge.call, "cleanupFrameAnimations");
assert.callOrder(browser.publicAPI.switchToFrame, clientBridge.call);
});

it("should switch to parent frame after clean animations in iframe", async () => {
stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "webdriver" }));
const iframeElement = { "element-12345": "67890_element_1" };
browser.publicAPI.findElements.withArgs("css selector", "iframe").resolves([iframeElement]);

await browser.cleanupScreenshot({ disableAnimation: true });

assert.callOrder(
browser.publicAPI.switchToFrame.withArgs(iframeElement),
browser.publicAPI.switchToFrame.withArgs(null),
);
});

it("should not switch to any frame if there are no iframes on the page ", async () => {
stubClientBridge_();
const browser = await initBrowser_(mkBrowser_({ automationProtocol: "webdriver" }));
browser.publicAPI.findElements.withArgs("css selector", "iframe").resolves([]);

await browser.cleanupScreenshot({ disableAnimation: true });

assert.notCalled(browser.publicAPI.switchToFrame);
});
});
});

Expand Down
6 changes: 1 addition & 5 deletions test/src/browser/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -63,9 +63,6 @@ exports.mkSessionStub_ = () => {
click: sinon.stub().named("click").resolves(),
waitForExist: sinon.stub().named("waitForExist").resolves(),
};
const wdElement = {
"element-6066-11e4-a52e-4f735466cecf": "95777D6590AF653A2FD8EB0ADD20B333_element_1",
};

session.sessionId = "1234567890";
session.isW3C = false;
Expand All @@ -89,9 +86,8 @@ exports.mkSessionStub_ = () => {
session.$ = sinon.stub().named("$").resolves(wdioElement);
session.getWindowHandles = sinon.stub().named("getWindowHandles").resolves([]);
session.switchToWindow = sinon.stub().named("switchToWindow").resolves();
session.findElements = sinon.stub().named("findElements").resolves([wdElement]);
session.findElements = sinon.stub().named("findElements").resolves([]);
session.switchToFrame = sinon.stub().named("switchToFrame").resolves();
session.switchToParentFrame = sinon.stub().named("switchToParentFrame").resolves();

session.addCommand = sinon.stub().callsFake((name, command, isElement) => {
const target = isElement ? wdioElement : session;
Expand Down

0 comments on commit f7719c8

Please sign in to comment.