-
-
Notifications
You must be signed in to change notification settings - Fork 264
/
Copy pathapp.forms.spec.ts
117 lines (104 loc) · 5.48 KB
/
app.forms.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
import TabBar from "../screenobjects/components/TabBar.js";
import FormScreen from "../screenobjects/FormsScreen.js";
import Picker from "../screenobjects/components/Picker.js";
import NativeAlert from "../screenobjects/components/NativeAlert.js";
describe("WebdriverIO and Appium, when interacting with form elements,", () => {
beforeEach(async () => {
await TabBar.waitForTabBarShown();
await TabBar.openForms();
await FormScreen.waitForIsShown(true);
});
it("should be able type in the input and validate the text", async () => {
const text = "Hello, this is a demo app";
await FormScreen.input.setValue(text);
await expect(FormScreen.inputTextResult).toHaveText(
expect.stringContaining(text)
);
/**
* IMPORTANT!!
* Because the app is not closed and opened between the tests
* (and thus is NOT starting with the keyboard hidden)
* the keyboard is closed here if it is still visible.
*/
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 outside of the keyboard.
*/
await FormScreen.tapOnInputTextResult();
}
});
it("should be able turn on and off the switch", async () => {
await expect(await FormScreen.isSwitchActive()).toEqual(false);
await FormScreen.tapOnSwitch();
await expect(await FormScreen.isSwitchActive()).toEqual(true);
await FormScreen.tapOnSwitch();
await expect(await FormScreen.isSwitchActive()).toEqual(false);
});
it("should be able select a value from the select element", async () => {
const valueOne = "This app is awesome";
const valueTwo = "webdriver.io is awesome";
const valueThree = "Appium is awesome";
await FormScreen.tapOnDropDown();
await Picker.selectValue(valueOne);
await expect(await FormScreen.getDropDownText()).toContain(valueOne);
await FormScreen.tapOnDropDown();
await Picker.selectValue(valueTwo);
await expect(await FormScreen.getDropDownText()).toContain(valueTwo);
await FormScreen.tapOnDropDown();
await Picker.selectValue(valueThree);
await expect(await FormScreen.getDropDownText()).toContain(valueThree);
});
it("should be able to open the alert and close it with all 3 buttons", async () => {
// This uses the "new" `scrollIntoView` method that now also supports native apps
await FormScreen.activeButton.scrollIntoView({
maxScrolls: 2,
scrollableElement: await FormScreen.screen,
});
await FormScreen.tapOnActiveButton();
await NativeAlert.waitForIsShown(true);
await expect(await NativeAlert.text()).toContain("This button is");
/**
* The following steps don't contain any assertions. This might look strange, but
* the `waitForIsShown`-method is the verification. If the element is there, it will
* click on it, and we can also verify if the element is not there. Both can be seen
* as assertions so we don't need to do double assertions per action (wait for the element
* to be there, and when it's there, expect that it's there)
*/
await NativeAlert.topOnButtonWithText("Ask me later");
await NativeAlert.waitForIsShown(false);
await FormScreen.tapOnActiveButton();
await NativeAlert.waitForIsShown(true);
await NativeAlert.topOnButtonWithText("Cancel");
await NativeAlert.waitForIsShown(false);
await FormScreen.tapOnActiveButton();
await NativeAlert.waitForIsShown(true);
await NativeAlert.topOnButtonWithText("OK");
await NativeAlert.waitForIsShown(false);
});
it("should be able to determine that the inactive button is inactive", async () => {
// Depending on the size of the screen we might need to scroll. This methods determines if it's visible,
// if not, it will automatically scroll to find it. This will be done two times.
// This uses the "new" `scrollIntoView` method that now also supports native apps
await FormScreen.inActiveButton.scrollIntoView({
maxScrolls: 2,
scrollableElement: await FormScreen.screen,
});
// In this case the button can't be asked if it is active or not with
// `expect(FormScreen.inActiveButton.isEnabled()).toEqual(false);`
// So use a click and check if shown, make sure the alert is not there
await NativeAlert.waitForIsShown(false);
await FormScreen.tapOnInActiveButton();
// Just wait 1 second to be sure it didn't appear
await driver.pause(1000);
// Now validate it isn't there
await NativeAlert.waitForIsShown(false);
});
});