sveltejs/js-framework-benchmark

Name: js-framework-benchmark

Owner: Svelte

Description: A comparison of the perfomance of a few popular javascript frameworks

Forked from: krausest/js-framework-benchmark

Created: 2017-05-17 14:09:59.0

Updated: 2017-05-17 14:10:01.0

Pushed: 2017-05-17 18:36:30.0

Homepage:

Size: 1902

Language: HTML

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

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.

Thanks to Baptiste Augrain for making the benchmarks more sophisticated and adding frameworks.

Important News

Chrome 54 on OSX has a bug that causes webdriver to hang or crash on non english systems. Please run the following command prior to executing the webdriver-ts testdriver:` export LANG="en_US.UTF-8"`

Prerequsites

Have node.js (>=6.0) installed. If you want to do yourself a favour use nvm for that and install yarn. The benchmark has been tested with node 6.0. You will also need java (>=8, e.g. openjdk-8-jre on ubuntu) for the google closure compiler, currently used in kivi. Further maven is needed and the bin directory of maven must be added to the path. Please make sure that the following command work before trying to build:

m
-version
5
de --version
.0
ho %JAVA_HOME% / echo $JAVA_HOME
va -version
 version "1.8.0_111" ...
vac -version
c 1.8.0_111
n -version
he Maven 3.3.9 (...
t --version
version 2.11.0.windows.3
Building

npm install or yarn

npm run build

The latter calls npm build-prod in each subproject.

cd aurelia

npm install or yarn

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

For all benchmarks the duration is measured including rendering time. You can read some details on this article. The results of this benchmark is outlined on my blog (round 1, round 2, round 3, round 4, and round 5).

Execute the benchmarks with webdriver

The former java test runner has been replaced with a typescript based test runner. The new test runner contains no timer based waits and is thus much faster.

npm start

which starts a web server

npm run selenium

which runs the seleniums tests

Open http://localhost:8080/webdriver-ts/table.html for the results

A test showing the durations on my machine (MacBook Pro 15, 2,5 GHz i7, 16 GB RAM) can be seen here

Single tests can be repeated easily. Just cd webdriver-ts and run the benchmarks and frameworks you want, e.g: npm run selenium -- --framework angular bob --benchmark 01_ 02_ runs the test for all frameworks that contain either angular or bob, which means all angular versions and bobril and all benchmarks whose id contain 01 or 02 which means the create rows and replace all rows benchmarks. After that you'll want to update the result table with npm run results

How to contribute

Contributions are very welcome. Please use the following rules:

How to start submitting a new implementation:


This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.