Rocket.Chat.ReactNative/e2e
Djorkaeff Alexandre c583e0c8f5
[IMPROVEMENT] Remove useMarkdown (#1774)
Co-authored-by: Diego Mello <diegolmello@gmail.com>
2020-02-27 15:34:20 -03:00
..
helpers Switch to react-navigation (#687) 2019-03-12 13:23:06 -03:00
00-onboarding.spec.js [WIP] New Authentication layout (#536) 2018-11-14 19:42:03 -02:00
01-welcome.spec.js [WIP] New Authentication layout (#536) 2018-11-14 19:42:03 -02:00
02-legal.spec.js Active users improvements (#855) 2019-04-29 13:03:52 -03:00
03-forgotpassword.spec.js [CHORE] Make e2e pass on CircleCI (#933) 2019-06-03 16:20:36 -03:00
04-createuser.spec.js [CHORE] Make e2e pass on CircleCI (#933) 2019-06-03 16:20:36 -03:00
05-login.spec.js [WIP] New Authentication layout (#536) 2018-11-14 19:42:03 -02:00
06-roomslist.spec.js Create class to manage navigation (#594) 2019-01-31 14:08:38 -02:00
07-createroom.spec.js Use FlatList in RoomView (#762) 2019-03-27 17:06:57 -03:00
08-room.spec.js [NEW] Settings view (#900) 2019-06-11 11:01:40 -03:00
09-roomactions.spec.js [NEW] Jitsi integration (#1196) 2019-09-18 14:32:12 -03:00
10-roominfo.spec.js Switch toast lib (#898) 2019-05-15 16:33:30 -03:00
11-changeserver.spec.js [CHORE] Migrate to Watermelon (#1171) 2019-09-16 17:26:32 -03:00
12-broadcast.spec.js Use FlatList in RoomView (#762) 2019-03-27 17:06:57 -03:00
13-profile.spec.js Switch toast lib (#898) 2019-05-15 16:33:30 -03:00
14-setting.spec.js [IMPROVEMENT] Remove useMarkdown (#1774) 2020-02-27 15:34:20 -03:00
15-joinpublicroom.spec.js [NEW] Settings view (#900) 2019-06-11 11:01:40 -03:00
README.md [CHORE] Make e2e pass on CircleCI (#933) 2019-06-03 16:20:36 -03:00
data.js [CHORE] Make e2e pass on CircleCI (#933) 2019-06-03 16:20:36 -03:00
init.js Update dependencies (#587) 2019-01-29 17:52:56 -02:00
mocha.opts Unnecessary re-renders removed (#570) 2018-12-21 08:55:35 -02:00

README.md

Contents:

  1. Prepare test environment
  2. Prepare test data
  3. Running tests
  4. FAQ

1. Prepare test environment

1.1. Set up local Rocket Chat server
  • Install Rocket Chat meteor app by following this guide.
1.2. Set up detox
  • Install dependencies by following this guide (only Step 1).

2. Prepare test data

  • Run Rocket Chat meteor app: meteor npm start (make sure you to run this command from project that you created on Step 1.1.).
  • Open localhost:3000 in browser.
  • Sign up as admin.
  • Create public room detox-public.
  • Create user with role: user, username: detoxrn, email: YOUR@EMAIL.COM, password: 123.
  • Create user with role: user, username: YOUR.NAME, email: YOUR.SECOND@EMAIL.COM, password: 123.
  • In file e2e/data.js change values existingEmail with YOUR.SECOND@EMAIL.COM, existingName with YOUR.NAME.
  • Login as user detoxrn -> open My Account -> Settings tab -> click Enable 2FA -> copy TTOLP code -> paste TTOLP code into ./e2e/data.js file into field: alternateUserTOTPSecret.

3. Running tests

3.1. iOS

  • Build app with detox: detox build -c ios.sim.release
  • Open Simulator which is used in tests (check in package.json under detox section) from Xcode and make sure that software keyboard is being displayed. To toggle keyboard press cmd+K.
  • Run tests: detox test -c ios.sim.release

3.1. Android

  • Build app with detox: detox build -c android.emu.debug
  • Run: react-native start
  • Run Android emulator with name ANDROID_API_28 via Android studio or cd /Users/USERNAME/Library/Android/sdk/emulator/ && ./emulator -avd ANDROID_API_28 Note: if you need to run tests on different Android emulator then simply change emulator name in ./package.json detox configurations
  • Run tests: detox test -c android.emu.debug

4. FAQ

4.1. Detox build fails

  • Delete node_modules, ios/build, android/build: rm -rf node_modules && rm -rf ios/build && rm -rf android/build
  • Install packages: yarn install
  • Kill metro bundler server by closing terminal or with following command: lsof -ti:8081 | xargs kill
  • Clear metro bundler cache: watchman watch-del-all && rm -rf $TMPDIR/react-native-packager-cache-* && rm -rf $TMPDIR/metro-bundler-cache-*
  • Make sure you have all required environment.
  • Now try building again with detox build (with specific configuration).

4.2. Detox iOS test run fails

  • Check if your meteor app is running by opening localhost:3000 in browser.
  • Make sure software keyboard is displayed in simulator when focusing some input. To enable keyboard press cmd+K.
  • Make sure you have prepared all test data.
  • Sometimes detox e2e tests fail for no reason so all you can do is simply re-run again.