-
-
Notifications
You must be signed in to change notification settings - Fork 264
/
Copy pathapp.webview.spec.ts
120 lines (111 loc) · 5.61 KB
/
app.webview.spec.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import TabBar from "../screenobjects/components/TabBar.js";
import WebViewScreen from "../screenobjects/WebviewScreen.js";
import SwipeScreen from "../screenobjects/SwipeScreen.js";
import { CONTEXT_REF } from "../helpers/WebView.js";
describe("WebdriverIO and Appium, when interacting with a WebView,", () => {
beforeEach(async () => {
// Wait for the tab bar to be show
await TabBar.waitForTabBarShown();
// Open the webview page
await TabBar.openWebView();
// This is where a lot of magic is happening
// - it waits for the webview context to be loaded
// - it will then switch to the webview and check if the website is
// fully loaded
// - it will then return back to the native context
await WebViewScreen.waitForWebsiteLoaded();
});
it("should be able search for the url method and open it", async () => {
// To be able to use the site in the webview of the app we first need to
// change the context from native to webview
// This is a custom method, check the source in `./helpers/WebView.js`
await WebViewScreen.switchToContext({
context: CONTEXT_REF.WEBVIEW,
// This is extra data to make sure we have the correct webview
title: "WebdriverIO",
url: "webdriver.io",
});
// Now the site can be accessed like you would automate a normal website
// keep in mind the responsiveness
// Open the search options
await $(".DocSearch").click();
// Search for url
await $(".DocSearch-Input").setValue("url");
await driver.waitUntil(async () =>
(await $(".DocSearch-HitsFooter").getText()).includes("See all")
);
// Let's take the first result
await $("#docsearch-hits0-item-0 a").click();
// Now wait for the header to be displayed and verify that we are on the correct page
await $("h1").waitForDisplayed({ timeout: 3000 });
await expect(await driver.getTitle()).toEqual("url | WebdriverIO");
/**
* IMPORTANT!!
* Because the app is not closed and opened between the 2 tests
* (and thus is NOT starting in the default context which is native)
* the context is here set to native. This is bad practice,
* because you should never rely on the state of a different test,
* but here it is excepted ;-)
*/
await WebViewScreen.switchToContext({
context: CONTEXT_REF.NATIVE_APP,
});
});
it("should be able to switch between webview, native and webview", async () => {
// To be able to use the site in the webview of the app we first need to
// change the context from native to webview
// This is a custom method, check the source in `./helpers/WebView.js`
await WebViewScreen.switchToContext({
context: CONTEXT_REF.WEBVIEW,
// This is extra data to make sure we have the correct webview
title: "WebdriverIO",
url: "webdriver.io",
});
// Open the search options
await $(".DocSearch").click();
// Wait for the search box to be there
// We don't put an expect here because the wait for will fail if the element is not there.
// This means this is already an "indirect" expectation
await $(".DocSearch-Input").waitForDisplayed();
await driver.pause(5000);
// Hide the keyboard if shown
if (await driver.isKeyboardShown()) {
/**
* Normally we would hide the keyboard with this command `driver.hideKeyboard()`, but there is an issue for hiding the keyboard
* on iOS when using the command. You will get an error like below
*
* Request failed with status 400 due to Error Domain=com.facebook.WebDriverAgent Code=1 "The keyboard on iPhone cannot be
* dismissed because of a known XCTest issue. Try to dismiss it in the way supported by your application under test."
* UserInfo={NSLocalizedDescription=The keyboard on iPhone cannot be dismissed because of a known XCTest issue. Try to dismiss
* it in the way supported by your application under test.}
*
* That's why we click on the footer
*/
await $(".DocSearch-Footer").click();
}
// Now open the swipe screen and do some action there
// This can only be done if webdriver.io is told to go to the native context
await WebViewScreen.switchToContext({
context: CONTEXT_REF.NATIVE_APP,
});
await TabBar.openSwipe();
await SwipeScreen.waitForIsShown();
// Now go back to the webview. It will automatically open in the previous state
await TabBar.openWebView();
// To be able to use the site in the webview webdriver.io first needs
// change the context from native to webview
await WebViewScreen.switchToContext({ context: CONTEXT_REF.WEBVIEW });
// Search for the OCR service
await $(".DocSearch-Input").setValue(
"ocr service for appium native apps"
);
await driver.waitUntil(async () =>
(await $(".DocSearch-HitsFooter").getText()).includes("See all")
);
// Let's take the first result
await $("#docsearch-hits0-item-0 a").click();
// Now wait for the header to be displayed and verify that we are on the correct page
await $("header h1").waitForDisplayed({ timeout: 3000 });
await expect(await $("header h1").getText()).toContain("OCR Testing");
});
});