Skip to content
This repository has been archived by the owner on Nov 1, 2024. It is now read-only.

Version 2.3.0 #102

Merged
merged 3 commits into from
Apr 23, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 4 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
## 2.2.3
## 2.3.0

- Require Dart 3.2.
- Add ScoreEmitterV2 interface, documented with the intention to change
ScoreEmitter interface to match it in the next major release,
a breaking change.
- Add `PerfBenchmarkBase` class which runs the 'perf stat' command from
linux-tools on a benchmark and reports metrics from the hardware
performance counters and the iteration count, as well as the run time
Expand Down
2 changes: 1 addition & 1 deletion lib/src/async_benchmark_base.dart
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,6 @@ class AsyncBenchmarkBase {

/// Run the benchmark and report results on the [emitter].
Future<void> report() async {
emitter.emit(name, await measure(), unit: 'us.');
emitter.emit(name, await measure());
}
}
2 changes: 1 addition & 1 deletion lib/src/benchmark_base.dart
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ class BenchmarkBase {
}

void report() {
emitter.emit(name, measure(), unit: 'us.');
emitter.emit(name, measure());
}
}

Expand Down
11 changes: 7 additions & 4 deletions lib/src/perf_benchmark_base.dart
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,10 @@ class PerfBenchmarkBase extends BenchmarkBase {
late final Process perfProcess;
late final List<String> perfProcessArgs;

PerfBenchmarkBase(super.name, {super.emitter = const PrintEmitter()});
PerfBenchmarkBase(super.name,
{ScoreEmitterV2 super.emitter = const PrintEmitterV2()});

ScoreEmitterV2 get _emitterV2 => emitter as ScoreEmitterV2;

Future<void> _createFifos() async {
perfControlFifo = '${fifoDir.path}/perf_control_fifo';
Expand Down Expand Up @@ -81,11 +84,11 @@ class PerfBenchmarkBase extends BenchmarkBase {
String event && ('cycles' || 'page-faults'),
...
]) {
emitter.emit(name, double.parse(counter) / totalIterations,
_emitterV2.emit(name, double.parse(counter) / totalIterations,
metric: metrics[event]!);
}
}
emitter.emit('$name.totalIterations', totalIterations.toDouble(),
_emitterV2.emit('$name.totalIterations', totalIterations.toDouble(),
metric: 'Count');
}

Expand Down Expand Up @@ -118,7 +121,7 @@ class PerfBenchmarkBase extends BenchmarkBase {
}

Future<void> reportPerf() async {
emitter.emit(name, await measurePerf(), unit: 'us.');
_emitterV2.emit(name, await measurePerf(), unit: 'us.');
}

void _waitForAck() {
Expand Down
24 changes: 22 additions & 2 deletions lib/src/score_emitter.dart
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,33 @@
// BSD-style license that can be found in the LICENSE file.

abstract class ScoreEmitter {
void emit(String testName, double value,
{String metric = 'RunTime', String unit});
void emit(String testName, double value);
}

class PrintEmitter implements ScoreEmitter {
const PrintEmitter();

@override
void emit(String testName, double value) {
print('$testName(RunTime): $value us.');
}
}

/// New interface for [ScoreEmitter]. [ScoreEmitter] will be migrated to
whesse marked this conversation as resolved.
Show resolved Hide resolved
/// this interface in the next major version release, and this class will
/// be deprecated and removed. That release will be a breaking change.
abstract class ScoreEmitterV2 implements ScoreEmitter {
@override
void emit(String testName, double value,
{String metric = 'RunTime', String unit});
}

/// New implementation of [PrintEmitter] implementing the [ScoreEmitterV2]
/// interface. [PrintEmitter] will be updated to this implementation in the
/// next major version release.
class PrintEmitterV2 implements ScoreEmitterV2 {
const PrintEmitterV2();

@override
void emit(String testName, double value,
{String metric = 'RunTime', String unit = ''}) {
Expand Down
2 changes: 1 addition & 1 deletion pubspec.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
name: benchmark_harness
version: 2.2.3
version: 2.3.0
description: The official Dart project benchmark harness.
repository: https://github.com/dart-lang/benchmark_harness

Expand Down
3 changes: 1 addition & 2 deletions test/result_emitter_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,7 @@ class MockResultEmitter extends ScoreEmitter {
int emitCount = 0;

@override
void emit(String name, double value,
{String metric = 'RunTime', String unit = ''}) {
void emit(String name, double value) {
emitCount++;
}
}
Expand Down