mirror of
https://github.com/status-im/status-mobile.git
synced 2025-03-02 17:20:48 +00:00
41 lines
2.7 KiB
Markdown
41 lines
2.7 KiB
Markdown
|
# How to catch crash on ios use xcode
|
||
|
|
||
|
## Overview
|
||
|
Sometimes, we can't reproduce crash with local dev build, probably because your built version differs from the one QA team used.
|
||
|
The QA team mostly used the PR build version. In this guide we will try to make a build as close as possible to the PR build for iOS.
|
||
|
|
||
|
You may notice various configuration files starting with .env (such as .env, .env.e2e, .env.jenkins) in the project.
|
||
|
The usage of these files and environment variables injected at build time on CI will not be covered in this guide.
|
||
|
|
||
|
This guide covers how to configure Xcode to capture a crash stack trace with a physical iOS device. This allows debugging crashes by inspecting the stack trace.
|
||
|
I will use [issue #17255](https://github.com/status-im/status-mobile/issues/17255) as an example to reproduce and analyze a crash.
|
||
|
|
||
|
## Prerequisites
|
||
|
- A physical ios device (simulator is not considered in this doc)
|
||
|
- Xcode installed
|
||
|
|
||
|
## Steps
|
||
|
1. Prepare Status Mobile
|
||
|
1. Open Terminal, cd to project root
|
||
|
2. Run `make run-clojure` in one tab
|
||
|
3. Run `make run-metro` in a second tab
|
||
|
4. Run `make pod-install` in a third tab
|
||
|
2. Configure Xcode Project
|
||
|
1. Open Xcode
|
||
|
2. Open a project or file, navigate to folder `path_to_root_directory_of_status_mobile/ios`
|
||
|
3. Set Scheme `StatusImPR` as current scheme data:image/s3,"s3://crabby-images/e1057/e105735bdf31b60b42e5498cbc7dc9efe1d14881" alt=""
|
||
|
4. Edit scheme data:image/s3,"s3://crabby-images/c5c86/c5c863b2c56ab5a1d191710cb5c6d60d287f64e8" alt=""
|
||
|
5. Change `Info` data:image/s3,"s3://crabby-images/c6c03/c6c0399cb55143ff435e5defd9164f687e70ccdf" alt=""
|
||
|
6. Change `Diagnostics` data:image/s3,"s3://crabby-images/b2d3f/b2d3f8046d8cfe1f7b356b59a05b7a3e429ff0b9" alt=""
|
||
|
7. Set automatically manage signing data:image/s3,"s3://crabby-images/a8807/a8807c2c19975ce04193c50916582d3792f2c14c" alt=""
|
||
|
3. Update Code
|
||
|
1. Edit `src/status_im2/setup/dev.cljs`, comment out lines 47-52 data:image/s3,"s3://crabby-images/9fc63/9fc63e4570b98234ac1aa398ba8d6154b9c1eca3" alt=""
|
||
|
2. Edit `shadow-cljs.edn`, comment out `re-frisk-remote.preload`, otherwise it will try to connect `localhost:4567` on physical device which could slow down performance data:image/s3,"s3://crabby-images/3bb46/3bb4663867160b44b9a31ccd0134b4d54776b8fd" alt=""
|
||
|
4. Reproduce Crash And Analyze
|
||
|
1. Choose your physical ios device as target device and Run
|
||
|
2. Follow reproduce steps from [issue #17255](https://github.com/status-im/status-mobile/issues/17255) mentioned and xcode will halt at crash point data:image/s3,"s3://crabby-images/b27af/b27afd6f6612a7439ec6eaad48b7d38a10905299" alt=""
|
||
|
3. Inspect stack trace to identify root cause. From the stack trace, we can locate the crash happened in `api/geth_backend.go:1048`(createTempDBFile) clearly! data:image/s3,"s3://crabby-images/a6df2/a6df22feee4b22fce78f45b6fa902e4341ae999e" alt=""
|
||
|
|
||
|
## Links
|
||
|
- [changes](https://github.com/status-im/status-mobile/commit/4306d419de15e737e8ded3a749cc5e8d6a06e627) to source code
|