forked from webdriverio/appium-boilerplate
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.forms.spec.ts
108 lines (95 loc) · 5.2 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
import Gestures from '../helpers/Gestures';
import TabBar from '../screenobjects/components/TabBar';
import FormScreen from '../screenobjects/FormsScreen';
import Picker from '../screenobjects/components/Picker';
import NativeAlert from '../screenobjects/components/NativeAlert';
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).toHaveTextContaining(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 () => {
await Gestures.checkIfDisplayedWithSwipeUp(await FormScreen.activeButton, 2);
await FormScreen.tapOnActiveButton();
await NativeAlert.waitForIsShown(true);
await expect(await NativeAlert.text()).toEqual('This button is\nThis button is active');
/**
* 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.
await Gestures.checkIfDisplayedWithSwipeUp(await FormScreen.inActiveButton, 2);
// 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);
});
});