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:flutter_test/flutter_test.dart';
|
||||||
|
import 'package:pinball/game/game.dart';
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
group('PinballGame', () {
|
group('PinballGame', () {
|
||||||
|
TestWidgetsFlutterBinding.ensureInitialized();
|
||||||
|
final flameTester = FlameTester(PinballGame.new);
|
||||||
|
|
||||||
// TODO(alestiago): test if [PinballGame] registers
|
// TODO(alestiago): test if [PinballGame] registers
|
||||||
// [BallScorePointsCallback] once the following issue is resolved:
|
// [BallScorePointsCallback] once the following issue is resolved:
|
||||||
// https://github.com/flame-engine/flame/issues/1416
|
// 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