1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- describe('modal', () => {
- beforeEach(async () => {
- await device.relaunchApp();
- });
-
- it('show modal', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Screen')).toBeVisible();
- });
-
- it('dismiss modal', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Screen')).toBeVisible();
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
-
- it('show multiple modals', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
-
- it('dismiss unknown screen id', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Dismiss Unknown Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
-
- it('dismiss modal by id which is not the top most', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
- await elementByLabel('Dismiss Previous Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
-
- it('dismiss all previous modals by id when they are below top presented modal', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 3')).toBeVisible();
-
- await elementByLabel('Dismiss ALL Previous Modals').tap();
- await expect(elementByLabel('Modal Stack Position: 3')).toBeVisible();
-
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
-
- it('dismiss some modal by id deep in the stack', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 3')).toBeVisible();
-
- await elementByLabel('Dismiss First In Stack').tap();
- await expect(elementByLabel('Modal Stack Position: 3')).toBeVisible();
-
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
-
- await elementByLabel('Dismiss Modal').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
-
- it('dismissAllModals', async () => {
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 1')).toBeVisible();
- await elementByLabel('Show Modal').tap();
- await expect(elementByLabel('Modal Stack Position: 2')).toBeVisible();
- await elementByLabel('Dismiss All Modals').tap();
- await expect(elementByLabel('React Native Navigation!')).toBeVisible();
- });
- });
-
- function elementByLabel(label) {
- return element(by.label(label));
- }
|