parent
dd18fc3bc7
commit
5e8f83cf8a
2 changed files with 30 additions and 9 deletions
|
@ -5,10 +5,10 @@ import 'package:rules_of_living/src/Engine.dart';
|
|||
class EngineService {
|
||||
Engine _engine;
|
||||
|
||||
Engine get engine => _engine ?? createEngine(null);
|
||||
Engine get engine => _engine ?? getEngine(Engine());
|
||||
|
||||
Engine createEngine(html.CanvasElement canvas) {
|
||||
_engine = Engine(canvas);
|
||||
Engine getEngine(Engine engine) {
|
||||
_engine = engine;
|
||||
return _engine;
|
||||
}
|
||||
|
||||
|
@ -45,5 +45,4 @@ class EngineService {
|
|||
}
|
||||
|
||||
bool get isRunning => engine.running;
|
||||
|
||||
}
|
||||
|
|
|
@ -1,19 +1,41 @@
|
|||
@TestOn('browser')
|
||||
|
||||
import 'package:test/test.dart';
|
||||
import 'package:mockito/mockito.dart';
|
||||
import 'package:rules_of_living/src/Engine.dart';
|
||||
import 'package:rules_of_living/service/engine_service.dart';
|
||||
|
||||
class MockEngine extends Mock implements Engine {}
|
||||
|
||||
void main() {
|
||||
EngineService sut;
|
||||
MockEngine me;
|
||||
setUp(() {
|
||||
me = MockEngine();
|
||||
sut = EngineService();
|
||||
});
|
||||
group("Dependency Injection", () {
|
||||
test("EngineService accesses the Engine defined in getEngine", () {
|
||||
sut.getEngine(me);
|
||||
|
||||
test("EngineService creates an engine on demand", () {
|
||||
expect(sut.engine, isNotNull);
|
||||
Engine result = sut.engine;
|
||||
expect(result, equals(me));
|
||||
});
|
||||
});
|
||||
group("caching", () {
|
||||
test("EngineService creates an engine on demand", () {
|
||||
Engine result = sut.engine;
|
||||
expect(result, TypeMatcher<Engine>());
|
||||
});
|
||||
|
||||
test("EngineService returns the cached engine on subsequent requests", () {
|
||||
expect(sut.engine, allOf(isNotNull, equals(sut.engine)));
|
||||
test("EngineService returns the cached engine on subsequent requests", () {
|
||||
Engine result = sut.engine;
|
||||
expect(sut.engine, equals(result));
|
||||
});
|
||||
test("caching can be overriden by providing a custom engine", () {
|
||||
Engine first = sut.engine;
|
||||
sut.getEngine(me);
|
||||
Engine second = sut.engine;
|
||||
expect(second, isNot(equals(first)));
|
||||
});
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue