status-mobile/doc/tests/how-to-run-local-tests.md
Icaro Motta 4b8a612df4
chore(docs): Document some of our existing testing practices (#20691)
Document some of our current testing practices in hopes of helping reduce
friction in PRs and communication in general. In theory, nothing in the text
should be a surprise because these are things we have been discussing over many
months (some things for almost 1.5 years) and are already present in the code.
2024-07-23 23:45:14 -03:00

2.4 KiB

Local testing

Unit & integration tests

To run all tests:

make test

Also test watcher can be launched. It will re-run the entire test suite when any file is modified

make test WATCH=true

Developers can also manually change the shadow-cljs option :ns-regex to control which namespaces the test runner should pick.

Testing with REPL

The most convenient way to develop and run test locally is using REPL:

  1. Run command make test-watch-for-repl.
  2. Once you see the message [repl] shadow-cljs - #3 ready! you can connect a REPL to the :test target from VS Code, Emacs, etc.
  3. In any test namespace, run cljs.test/run-tests or your preferred method to run tests in the current namespace.

You can run single test in REPL like this

(require 'cljs.test)
(cljs.test/test-var #'status-im.data-store.chats-test/normalize-chat-test)

Tests will use the bindings in modules/react-native-status/nodejs, if you make any changes to these you will need to restart the watcher.

Example in Emacs

In the video below, you can see two buffers side-by-side. On the left the source implementation, on the right the REPL buffer. Whenever a keybinding is pressed, tests in the current namespace instantly run. You can achieve this exact flow in VS Code, IntelliJ, Vim, etc.

2022-12-19 12-46.webm

Example in terminal emulator

Here I'm showing a terminal-only experience using Tmux (left pane Emacs, right pane the output coming from running the make target).

2022-12-19 13-17.webm

Component tests only

To run tests:

make test-component

Also test watcher can be launched. It will re-run the entire test suite when any file is modified

make test-component-watch

Check component tests doc for more.

Unit tests only

To run unit tests:

make test-unit

Also test watcher can be launched. It will re-run the entire test suite when any file is modified

make test-unit WATCH=true

Integration tests only

To run integration tests:

make test-integration

Also test watcher can be launched. It will re-run the entire test suite when any file is modified

make test-integration WATCH=true