Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/krisselden/ember-macro-benchmark
Benchmark recording of an ember app with running with 2 versions of Ember.
https://github.com/krisselden/ember-macro-benchmark
Last synced: 9 days ago
JSON representation
Benchmark recording of an ember app with running with 2 versions of Ember.
- Host: GitHub
- URL: https://github.com/krisselden/ember-macro-benchmark
- Owner: krisselden
- Created: 2017-04-05T09:33:53.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2021-05-29T04:32:33.000Z (over 3 years ago)
- Last Synced: 2024-04-13T17:14:51.080Z (9 months ago)
- Language: TypeScript
- Homepage:
- Size: 2.34 MB
- Stars: 25
- Watchers: 7
- Forks: 9
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-ember - ember-macro-benchmark - Benchmark recording of an ember app with running with 2 versions of Ember.js. (Packages / Benchmarking)
README
# ember-macro-bench
A tool for measuring changes in Ember to applications.
This uses [chrome-tracing](https://github.com/krisselden/chrome-tracing) and [har-remix](https://github.com/krisselden/har-remix) to measure the effects of small changes to Ember on applications.
This is also a demonstration of using these tools to measure applications.
## Setup
### PrerequisitesThese instructions assume Mac and using homebrew.
Install R
```sh
brew tap homebrew/science
brew install r
```Run R
```sh
R
```Then install R packages:
```R
install.packages("jsonlite")
install.packages("R6")
install.packages("ggplot2")
q()
```Install yarn
```sh
brew install yarn
```### Install
```sh
git clone [email protected]:krisselden/ember-macro-benchmark.git
cd ember-macro-benchmark
yarn
```### Run the Server
Edit the `config.json`
* `har`: The emberaddons.com HAR file, the example is a recording of
emberaddons.com built with Ember 2.13.0-beta.1
* `runCount`: Number of benchmarks to run
* `cpuThrottleRate`: Throttling rate as a slowdown factor (1 is no throttle, 2 is 2x slowdown, etc).
* `networkCondition`: Configurations for combinations of latency/downloadThroughput/uploadThroughput. Presets are taken from [addyosmani/network-emulation-conditions](https://github.com/addyosmani/network-emulation-conditions)
* Available options: `GPRS`, `REGULAR_2G`, `GOOD_2G`, `REGULAR_3G`, `GOOD_3G`, `REGULAR_4G`, `DSL`, `WIFI`.
* `servers`
* `name`: Name of the server
* `port`: Port for the server to run on
* `dist`: path to full emberaddons.com build. Use this when testing ember
versions that require wire format changes. Note that you *must* use an
unfingerprinted production build.
* `ember`: path to an ember dist to splice into the vendor.js, the example
results were tested against Ember commit 2c45a3b.Caveat: the templates are in the recorded app, you can only test with an Ember with compatible template wire-format as the recording unless you add a `dist` to the server
```sh
yarn run serve
```### Run the Benchmark
While the app is being served, run:
```sh
yarn run bench
```### Generate the Report
To generate the report run:
`yarn run plot`
Which will generate a PDF in the `results` folder with the reports from Chrome Tracing. It contains several graphs and plots for. Here are a few resources to help you read them:
* [Wilcoxon rank-sum test](https://en.wikipedia.org/wiki/Mann%E2%80%93Whitney_U_test)
* [Null Hypothesis](https://en.wikipedia.org/wiki/Null_hypothesis)If you'd like to see a smaller summary in your CLI you can run:
`yarn run report`
Which will give you an abbreviated report.