mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-15 03:05:17 +00:00
4b8a612df4
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.
95 lines
2.4 KiB
Markdown
95 lines
2.4 KiB
Markdown
# 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`.
|
|
3. Once you see the message `[repl] shadow-cljs - #3 ready!` you can connect a REPL to the `:test` target from VS Code, Emacs, etc.
|
|
4. In any test namespace, run [cljs.test/run-tests](https://cljs.github.io/api/cljs.test/#run-tests) or your preferred method to run tests in the current namespace.
|
|
|
|
You can run single test in REPL like this
|
|
|
|
```clojure
|
|
(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](https://user-images.githubusercontent.com/46027/208465927-4ad9a935-5494-45e7-85b0-8134dc32d1a1.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](https://user-images.githubusercontent.com/46027/208471199-1909c446-c82d-42a0-9350-0c15ca562713.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](./component-tests-overview.md) 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
|
|
```
|