react-native-navigation的迁移库

TopLevelApi.test.js 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. const Utils = require('./Utils');
  2. const elementByLabel = Utils.elementByLabel;
  3. describe('top level api', () => {
  4. beforeEach(async () => {
  5. await device.relaunchApp();
  6. });
  7. it('shows welcome screen', async () => {
  8. await expect(elementByLabel('React Native Navigation!')).toBeVisible();
  9. });
  10. it('switch to tab based app, passProps and functions', async () => {
  11. await elementByLabel('Switch to tab based app').tap();
  12. await expect(elementByLabel('This is tab 1')).toBeVisible();
  13. await expect(elementByLabel('Hello from a function!')).toBeVisible();
  14. });
  15. it('switch to tabs with side menus', async () => {
  16. await elementByLabel('Switch to app with side menus').tap();
  17. await elementByLabel('This is a side menu center screen tab 1').swipe('right');
  18. await expect(elementByLabel('This is a left side menu screen')).toBeVisible();
  19. });
  20. it('screen lifecycle', async () => {
  21. await elementByLabel('Push Lifecycle Screen').tap();
  22. await expect(elementByLabel('didAppear')).toBeVisible();
  23. await elementByLabel('Push to test didDisappear').tap();
  24. await expect(elementByLabel('Alert')).toBeVisible();
  25. await expect(elementByLabel('didDisappear')).toBeVisible();
  26. });
  27. it('unmount is called on pop', async () => {
  28. await elementByLabel('Push Lifecycle Screen').tap();
  29. await expect(elementByLabel('didAppear')).toBeVisible();
  30. await Utils.tapBackIos();
  31. await expect(elementByLabel('componentWillUnmount')).toBeVisible();
  32. await element(by.traits(['button']).and(by.label('OK'))).atIndex(0).tap();
  33. await expect(elementByLabel('didDisappear')).toBeVisible();
  34. });
  35. });
  36. describe('reload app', async () => {
  37. beforeEach(async () => {
  38. await device.relaunchApp();
  39. });
  40. it('push a screen to ensure its not there after reload', async () => {
  41. await elementByLabel('Push').tap();
  42. await expect(elementByLabel('Pushed Screen')).toBeVisible();
  43. await device.reloadReactNative();
  44. await expect(elementByLabel('React Native Navigation!')).toBeVisible();
  45. });
  46. });