Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oblador/react-native-performance
📐 Monitor and measure React Native performance
https://github.com/oblador/react-native-performance
flipper metrics performance react-native
Last synced: 5 days ago
JSON representation
📐 Monitor and measure React Native performance
- Host: GitHub
- URL: https://github.com/oblador/react-native-performance
- Owner: oblador
- License: mit
- Created: 2019-11-30T17:19:06.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-08T21:36:31.000Z (11 months ago)
- Last Synced: 2024-05-21T01:58:42.232Z (8 months ago)
- Topics: flipper, metrics, performance, react-native
- Language: TypeScript
- Homepage:
- Size: 1.51 MB
- Stars: 897
- Watchers: 9
- Forks: 38
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome - oblador/react-native-performance - 📐 Monitor and measure React Native performance (TypeScript)
README
# React Native Performance tooling
Toolchain to measure and monitor the performance of your React Native app in development, pipeline and in production.
## Packages
### [`react-native-performance`](https://github.com/oblador/react-native-performance/blob/master/packages/react-native-performance/README.md)
An implementation of the [`Performance` API](https://developer.mozilla.org/en-US/docs/Web/API/Performance) for React Native.
- Integrates well with `React.Profiler` API
- Trace arbitrary events in your app such as component render time
- Capture network traffic
- Collect native traces such as script execution and time to interactive of root view
- Collect native metrics in development such as JS bundle size### [`flipper-plugin-performance`](https://github.com/oblador/react-native-performance/blob/master/packages/flipper-plugin-performance/README.md)
Visualize performance tracing on a timeline and generic metrics in the debug tool Flipper.
### [`react-native-performance-flipper-reporter`](https://github.com/oblador/react-native-performance/blob/master/packages/react-native-performance-flipper-reporter/README.md)
Connect the `react-native-performance` library with the `flipper-plugin-performance` visualization tool in development.
### [`isomorphic-performance`](https://github.com/oblador/react-native-performance/blob/master/packages/isomorphic-performance/README.md)
Isomorphic Performance API for Node, Browser & React Native. Useful if your app targets both web and native.
## Demo
See the projects in the [`examples`](https://github.com/oblador/flipper-plugin-react-native-performance/tree/master/examples) folder.
## Development
Make sure to have [`yarn`](https://classic.yarnpkg.com/lang/en/) v1 installed and run `yarn` in the root folder to install dependencies for all packages.
Uninstall the Flipper Performance plugin if previously installed. Then edit your `~/.flipper/config.json` to look something like this:
```
{
"pluginPaths": ["/path/to/react-native-performance/packages"]
}
```Continously compile the plugin as you edit with:
```bash
yarn workspace flipper-plugin-performance run watch
```Run the example app with:
```bash
cd examples/vanilla
yarn start # important to run this before the next step!
yarn ios # or yarn android
```Run the unit tests with:
```bash
yarn test
```## License
MIT © Joel Arvidsson 2019 – present