mirror of https://github.com/flutter/pinball.git
parent
294ff1b7ee
commit
421ad272cb
@ -1,9 +1,54 @@
|
||||
// ignore_for_file: cascade_invocations
|
||||
|
||||
import 'package:flame_test/flame_test.dart';
|
||||
import 'package:flutter_test/flutter_test.dart';
|
||||
import 'package:pinball/game/game.dart';
|
||||
|
||||
void main() {
|
||||
group('PinballGame', () {
|
||||
TestWidgetsFlutterBinding.ensureInitialized();
|
||||
final flameTester = FlameTester(PinballGame.new);
|
||||
|
||||
// TODO(alestiago): test if [PinballGame] registers
|
||||
// [BallScorePointsCallback] once the following issue is resolved:
|
||||
// https://github.com/flame-engine/flame/issues/1416
|
||||
group(
|
||||
'components',
|
||||
() {
|
||||
group('Flippers', () {
|
||||
flameTester.test(
|
||||
'has only one left flipper',
|
||||
(game) {
|
||||
final flipper = game.children.firstWhere(
|
||||
(e) => e is Flipper && e.side == BoardSide.left,
|
||||
) as Flipper;
|
||||
|
||||
final anotherFlipper = game.children.lastWhere(
|
||||
(e) => e is Flipper && e.side == BoardSide.left,
|
||||
) as Flipper;
|
||||
|
||||
expect(flipper, equals(anotherFlipper));
|
||||
expect(flipper.side, equals(BoardSide.left));
|
||||
},
|
||||
);
|
||||
|
||||
flameTester.test(
|
||||
'has only one right flipper',
|
||||
(game) {
|
||||
final flipper = game.children.firstWhere(
|
||||
(e) => e is Flipper && e.side == BoardSide.right,
|
||||
) as Flipper;
|
||||
|
||||
final anotherFlipper = game.children.lastWhere(
|
||||
(e) => e is Flipper && e.side == BoardSide.right,
|
||||
) as Flipper;
|
||||
|
||||
expect(flipper, equals(anotherFlipper));
|
||||
expect(flipper.side, equals(BoardSide.right));
|
||||
},
|
||||
);
|
||||
});
|
||||
},
|
||||
);
|
||||
});
|
||||
}
|
||||
|
@ -0,0 +1,50 @@
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:meta/meta.dart';
|
||||
import 'package:mocktail/mocktail.dart';
|
||||
|
||||
import 'helpers.dart';
|
||||
|
||||
@isTest
|
||||
void testRawKeyUpEvents(
|
||||
List<LogicalKeyboardKey> keys,
|
||||
Function(RawKeyUpEvent) test,
|
||||
) {
|
||||
for (final key in keys) {
|
||||
test(_mockKeyUpEvent(key));
|
||||
}
|
||||
}
|
||||
|
||||
RawKeyUpEvent _mockKeyUpEvent(LogicalKeyboardKey key) {
|
||||
final event = MockRawKeyUpEvent();
|
||||
when(() => event.logicalKey).thenReturn(
|
||||
LogicalKeyboardKey.keyA,
|
||||
);
|
||||
return event;
|
||||
}
|
||||
|
||||
@isTest
|
||||
void testRawKeyDownEvents(
|
||||
List<LogicalKeyboardKey> keys,
|
||||
Function(RawKeyDownEvent) test,
|
||||
) {
|
||||
for (final key in keys) {
|
||||
test(_mockKeyDownEvent(key));
|
||||
}
|
||||
}
|
||||
|
||||
RawKeyDownEvent _mockKeyDownEvent(LogicalKeyboardKey key) {
|
||||
final event = MockRawKeyDownEvent();
|
||||
when(() => event.logicalKey).thenReturn(
|
||||
LogicalKeyboardKey.keyA,
|
||||
);
|
||||
return event;
|
||||
}
|
||||
|
||||
@isTest
|
||||
void testRawKeyEvents(
|
||||
List<LogicalKeyboardKey> keys,
|
||||
Function(RawKeyEvent) test,
|
||||
) {
|
||||
testRawKeyDownEvents(keys, test);
|
||||
testRawKeyUpEvents(keys, test);
|
||||
}
|
Loading…
Reference in new issue