Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/EmergeTools/ETTrace
Easily and accurately profile iOS apps
https://github.com/EmergeTools/ETTrace
Last synced: about 1 month ago
JSON representation
Easily and accurately profile iOS apps
- Host: GitHub
- URL: https://github.com/EmergeTools/ETTrace
- Owner: EmergeTools
- License: mit
- Created: 2022-12-09T13:42:52.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-11-27T22:23:05.000Z (about 2 months ago)
- Last Synced: 2024-12-04T17:54:28.853Z (about 1 month ago)
- Language: C
- Homepage: https://www.emergetools.com/ettrace
- Size: 3.4 MB
- Stars: 570
- Watchers: 9
- Forks: 23
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - ETTrace - Locally measure performance of your app, without Xcode or Instruments. (Testing / Other Testing)
- awesome-ios-star - ETTrace - Locally measure performance of your app, without Xcode or Instruments. (Testing / Other Testing)
README
# ETTrace π½
[![](https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2FEmergeTools%2FETTrace%2Fbadge%3Ftype%3Dswift-versions)](https://swiftpackageindex.com/EmergeTools/ETTrace)
[![](https://img.shields.io/endpoint?url=https%3A%2F%2Fswiftpackageindex.com%2Fapi%2Fpackages%2FEmergeTools%2FETTrace%2Fbadge%3Ftype%3Dplatforms)](https://swiftpackageindex.com/EmergeTools/ETTrace)
[![](https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fwww.emergetools.com%2Fapi%2Fv2%2Fpublic_new_build%3FexampleId%3Dettrace.ETTrace%26platform%3Dios%26badgeOption%3Dversion_and_max_install_size%26buildType%3Drelease&query=$.badgeMetadata&label=ETTrace&logo=apple)](https://www.emergetools.com/app/example/ios/ettrace.ETTrace/release?utm_campaign=badge-data)Locally measure performance of your app, without Xcode or Instruments. Read all about it in the [launch blog post](https://www.emergetools.com/blog/posts/ettrace-reliable-ios-profiling-with-flamecharts)
![Example Flamechart](https://raw.githubusercontent.com/EmergeTools/ETTrace/master/images/example_flamechart.png)
## Building and Installing
ETTrace has two components, the "runner" which is a command line tool, and a framework that your app links to.
First, install the runner with `brew install emergetools/homebrew-tap/ettrace`. Then install the framework using one of the following methods:
### Swift Package Manager
Add this repo as a swift package (either in Xcode or your Package.swift file) using the URL `https://github.com/EmergeTools/ETTrace`. Select "ETTrace" as the package product to add to your app.
> [!WARNING]
> Make sure to add the ETTrace package product to your app as shown in the screenshot below.![SPM Installation](https://raw.githubusercontent.com/EmergeTools/ETTrace/master/images/spm_installation.png)
### Manual
Alternatively, run `./build.sh` to build the xcframework `ETTrace.xcframework`. Link the xcframework to your app.
> [!NOTE]
> Linking the framework to your app is the only installation step, there are no code changes you need to make.If everything is set up correctly "Starting ETTrace" will be printed to the console when you launch the app.
## Testimonials
Our users love ETTrace and find it essential in their iOS development process. Hereβs what some of them have to say:
- **Keith Smiley, Principal Engineer @ Lyft**: "With ETTrace I can pinpoint exactly what is taking time in my app, and quickly find opportunities to improve it. Itβs my go-to tool for in-depth performance analysis."
- **Bruno Rocha, Software Engineer @ Spotify**: "ETTrace is my favorite tool for diagnosing iOS performance, the flamechart view makes it easy to find bottlenecks and speed up app launch."
## Using
Launch your app and run `ettrace` or `ettrace --simulator`. After profiling, the result will be displayed on https://emergetools.com/flamegraph
Note: Always launch the app by manually tapping the icon on the iOS homescreen, running the app through Xcode can result in inaccurate results.
## dSYMs
You can point `ettrace` to a folder containing your dsyms with the `--dsyms` flag. If the dsyms are indexed by spotlight they will be automatically found and used.
## Run at Launch
Use the flag `--launch` to start recording on app launch. When you first connect to the app using this flag, the app will force quit. On the next launch it will start profiling automatically and capture all of your `main` function. In some cases you need to record the first launch after an install. You can't use the `--launch` flag for this because that requires re-launching the app. Instead, add a boolean set to `YES` in your Info.plist with the key `ETTraceRunAtStartup`. You can then run `ettrace` regularly, without the `--launch` flag, and still start profiling at the start of app launch.
## Under the hood
ETTrace spawns a new thread which captures a stacktrace of the main thread periodically. This is sampling based profiling. The sampling thread starts either when ettrace.framework is loaded (+load method), or when the CLI sends a message to the application. These control messages and the sampled data are communicated using PeerTalk.
## Adding events to the flamechart
ETTrace supports displaying events in the flamechart from version v1.0. You can use them to track user flows in your code, you can easily add them by posting a notification in your code:
```swift
NotificationCenter.default.post(name: Notification.Name(rawValue: "EmergeMetricStarted" | "EmergeMetricEnded"),
object: nil,
userInfo: [
"metric": "EVENT_NAME"
])
```
Use `EmergeMetricStarted` to register the start of your flow and `EmergeMetricEnded` to track it's end.For example we would post this notification to track the start of an user login flow.
```swift
NotificationCenter.default.post(name: Notification.Name(rawValue: "EmergeMetricStarted"),
object: nil,
userInfo: [
"metric": "USER_LOGIN"
])
```And then this one when the user successfuly logins:
```swift
NotificationCenter.default.post(name: Notification.Name(rawValue: "EmergeMetricEnded"),
object: nil,
userInfo: [
"metric": "USER_LOGIN"
])
```In the flamechart we would be able to see this flow as follows:
![Events Flamechart](images/events_flamechart.png)## Profiling background threads
Use the flag `--multi-thread` (`-m`) to record all threads. This will provide a output.json file for every thread recorded, which you can drag into ETTrace.