Skip to content

Commit

Permalink
Adding some benchmarks
Browse files Browse the repository at this point in the history
  • Loading branch information
divdavem committed Nov 8, 2024
1 parent 03e7307 commit 0aed36a
Show file tree
Hide file tree
Showing 6 changed files with 139 additions and 2 deletions.
12 changes: 11 additions & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ on:
jobs:
build:
permissions:
contents: read
contents: write
id-token: write
runs-on: ubuntu-latest
steps:
Expand All @@ -27,3 +27,13 @@ jobs:
use_oidc: true
- run: npm run build
- run: npm run docs
- run: npm run benchmark
- uses: benchmark-action/github-action-benchmark@d48d326b4ca9ba73ca0cd0d59f108f9e02a381c7 #v1.20.4
with:
name: Tansu benchmarks
tool: 'customBiggerIsBetter'
output-file-path: benchmarks.json
auto-push: ${{ github.event_name == 'push' }}
github-token: ${{ secrets.GITHUB_TOKEN }}
comment-on-alert: true
summary-always: true
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ dist
temp
coverage
.angular
benchmarks.json
82 changes: 82 additions & 0 deletions benchmarks/basic.bench.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
import { bench, describe } from 'vitest';
import type { ReadableSignal, Unsubscriber } from '../src';
import { computed, derived, DerivedStore, readable, Store, writable } from '../src';

class StoreClass extends Store<number> {}
class DoubleStoreClass extends DerivedStore<number, ReadableSignal<number>> {
protected override derive(value: number): Unsubscriber | void {
this.set(2 * value);
}
}

describe('creating base stores', () => {
bench('writable', () => {
writable(0);
});
bench('readable', () => {
readable(0);
});

bench('new StoreClass', () => {
new StoreClass(0);
});
});

describe('creating derived stores', () => {
const baseStore = writable(0);
bench('computed', () => {
computed(() => 2 * baseStore());
});

bench('derived', () => {
derived(baseStore, (a) => 2 * a);
});

bench('new DoubleStoreClass', () => {
new DoubleStoreClass(baseStore, 0);
});
});

describe('updating derived stores', () => {
const baseStore1 = writable(0);
computed(() => 2 * baseStore1()).subscribe(() => {});
let count1 = 0;
bench('computed', () => {
count1++;
baseStore1.set(count1);
});

const baseStore2 = writable(0);
derived(baseStore2, (a) => 2 * a).subscribe(() => {});
let count2 = 0;
bench('derived', () => {
count2++;
baseStore2.set(count2);
});

const baseStore3 = writable(0);
new DoubleStoreClass(baseStore3, 0).subscribe(() => {});
let count3 = 0;
bench('DoubleStoreClass', () => {
count3++;
baseStore3.set(count3);
});
});

describe('updating writable stores', () => {
const storeWithoutSubscriber = writable(0);
let count1 = 0;

bench('without subscriber', () => {
count1++;
storeWithoutSubscriber.set(count1);
});

const storeWithSubscriber = writable(0);
storeWithSubscriber.subscribe(() => {});
let count2 = 0;
bench('with subscriber', () => {
count2++;
storeWithSubscriber.set(count2);
});
});
38 changes: 38 additions & 0 deletions benchmarks/jsonArrayReporter.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
import { RunnerTestFile } from 'vitest';
import { Reporter } from 'vitest/reporters';
import { writeFile } from 'fs/promises';

class JsonArrayReporter implements Reporter {
async onFinished(files: RunnerTestFile[]): Promise<void> {
const results: {
name: string;
unit: string;
value: number;
}[] = [];

function processTasks(tasks: RunnerTestFile['tasks'], name: string) {
for (const task of tasks) {
if (task.type === 'suite') {
processTasks(task.tasks, `${name} > ${task.name}`);
} else {
const value = task.result?.benchmark?.hz;
if (value) {
results.push({
name: `${name} > ${task.name}`,
unit: 'Hz',
value,
});
}
}
}
}

for (const file of files) {
processTasks(file.tasks, file.name);
}

await writeFile('benchmarks.json', JSON.stringify(results, null, ' '));
}
}

export default JsonArrayReporter;
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,7 @@
"test": "vitest run",
"tdd": "vitest",
"tdd:ui": "vitest --ui",
"benchmark": "vitest bench --run",
"clean": "rm -rf dist temp",
"lint": "eslint src/{,**/}*.ts",
"build:rollup": "rollup --failAfterWarnings -c",
Expand Down
7 changes: 6 additions & 1 deletion vitest.config.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,18 @@
import { defineConfig } from 'vitest/config';
import JsonArrayReporter from './benchmarks/jsonArrayReporter';

export default defineConfig({
test: {
setupFiles: ['test.ts'],
include: ['./**/*.spec.ts'],
include: ['src/**/*.spec.ts'],
environment: 'happy-dom',
coverage: {
provider: 'v8',
reporter: ['lcov'],
include: ['src/**'],
},
benchmark: {
reporters: [new JsonArrayReporter(), 'default'],
},
},
});

0 comments on commit 0aed36a

Please sign in to comment.