Thanks to visit codestin.com
Credit goes to github.com

Skip to content

makepanic/js-framework-benchmark

 
 

Repository files navigation

js-framework-benchmark

This is a simple benchmark for several javascript frameworks. The benchmarks creates a large table with randomized entries and measures the time for various operations.

This work is derived from a benchmark that Richard Ayotte published on https://gist.github.com/RichAyotte/a7b8780341d5e75beca7 and adds more framework and more operations.

Thanks for the great work.

Prerequsites

Have node.js installed. If you want to do yourself a favour use nvm for that. The benchmark has been tested with node 5.1+.

Building

  • To build the benchmarks for all frameworks:

npm install

npm run build

The latter calls npm build-prod in each subproject.

  • To build a single benchmark for a framework, e.g. aurelia

cd aurelia

npm install

npm run build-prod

Running in the browser

Execute npm start in the main directory to start a http-server for the web pages. Open http://localhost:8080 and choose the directory for the framework you want to test. Most actions will try to measure the duration and print it to the console. Depending on the framework this might be more or less precise. To measure the exact numbers one needs to use e.g. the timeline from the chrome dev tools.

About the benchmarks

  • create 1000 rows: Time for creating a table with 1000 rows after the page loaded.
  • update 1000 rows (hot): Time for updating all 1000 rows of the table. A few iterations to warmup the javascript engine are performed before measuring.
  • partial update: Time to update the text of every 10th row. A few iterations to warmup the javascript engine are performed before measuring.
  • select row: Duration to highlight a row in response to a click on the row. A few iterations to warmup the javascript engine are performed before measuring.
  • remove row: Duration to remove a row. A few iterations to warmup the javascript engine are performed before measuring.

Execute the benchmarks with selenium

You need to have a current java and maven installation to run the automated benchmark.

npm start which starts a web browser npm run selenium which runs the seleniums tests

Open http://localhost:8080/webdriver-java/chart.html for the results

A test showing the durations on my machine can be seen here

Execute the benchmarks with protractor and benchpress [deprecated]

This uses the work of ShMcK Framework-Performance-Tests-with-Meteor who put Protractor and BenchPress wonderfully to work.

npm start

cd tests npm run webdriver-manager open a new shell in the tests directory npm run protractor

Open http://localhost:8080/tests/chart.html for the results

About

A comparison of the perfomance of a few popular javascript frameworks

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 73.1%
  • Java 12.3%
  • HTML 11.8%
  • TypeScript 2.3%
  • CSS 0.5%