jsPerf.app is an online JavaScript performance benchmark test runner & jsperf.com mirror. It is a complete rewrite in homage to the once excellent jsperf.com now with hopefully a more modern & maintainable codebase.
jsperf.com URLs are mirrored at the same path, e.g:
https://jsperf.com/negative-modulo/2
Can be accessed at:
https://jsperf.app/negative-modulo/2
runs some tests against building a record with imperative foreach vs functional reduce
const dbcols = [
{schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"},
{schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts"},
{schema: "public", table: "foo"},
]
const subsets = [
{schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"},
{schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"}, {schema: "public", table: "users"},
{schema: "public", table: "accounts", whereClause: "foo"},
{schema: "public", table: "foo"},
]
function buildRowKey(schema, table) {
return `${schema}.${table}`;
}
Ready to run.
Test | Ops/sec | |
---|---|---|
foreach |
| ready |
reduce |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.