mirror of
https://github.com/pese-git/cherrypick.git
synced 2026-01-24 05:25:19 +00:00
44 lines
1.1 KiB
Dart
44 lines
1.1 KiB
Dart
import 'package:benchmark_harness/benchmark_harness.dart';
|
||
import 'package:cherrypick/cherrypick.dart';
|
||
|
||
class Shared {}
|
||
class ParentImpl extends Shared {}
|
||
class ChildImpl extends Shared {}
|
||
|
||
class ParentModule extends Module {
|
||
@override
|
||
void builder(Scope currentScope) {
|
||
bind<Shared>().toProvide(() => ParentImpl()).singleton();
|
||
}
|
||
}
|
||
|
||
class ChildOverrideModule extends Module {
|
||
@override
|
||
void builder(Scope currentScope) {
|
||
bind<Shared>().toProvide(() => ChildImpl()).singleton();
|
||
}
|
||
}
|
||
|
||
class ScopeOverrideBenchmark extends BenchmarkBase {
|
||
ScopeOverrideBenchmark() : super('ScopeOverride (child overrides parent)');
|
||
late Scope parent;
|
||
late Scope child;
|
||
@override
|
||
void setup() {
|
||
parent = CherryPick.openRootScope();
|
||
parent.installModules([ParentModule()]);
|
||
child = parent.openSubScope('child');
|
||
child.installModules([ChildOverrideModule()]);
|
||
}
|
||
@override
|
||
void teardown() {
|
||
CherryPick.closeRootScope();
|
||
}
|
||
@override
|
||
void run() {
|
||
// Должен возвращать ChildImpl, а не ParentImpl
|
||
final resolved = child.resolve<Shared>();
|
||
assert(resolved is ChildImpl);
|
||
}
|
||
}
|