mirror of https://github.com/flutter/pinball.git
parent
b13ad6a06d
commit
79a7440dc3
@ -0,0 +1,77 @@
|
||||
// ignore_for_file: cascade_invocations
|
||||
|
||||
import 'package:flame/game.dart';
|
||||
import 'package:flame_bloc/flame_bloc.dart';
|
||||
import 'package:flame_forge2d/flame_forge2d.dart';
|
||||
import 'package:flame_test/flame_test.dart';
|
||||
import 'package:flutter_test/flutter_test.dart';
|
||||
import 'package:mocktail/mocktail.dart';
|
||||
import 'package:pinball/game/bloc/game_bloc.dart';
|
||||
import 'package:pinball/game/components/backbox/displays/info_display.dart';
|
||||
import 'package:pinball/l10n/l10n.dart';
|
||||
import 'package:pinball_components/pinball_components.dart';
|
||||
import 'package:pinball_flame/pinball_flame.dart';
|
||||
|
||||
class _TestGame extends Forge2DGame with HasTappables {
|
||||
@override
|
||||
Future<void> onLoad() async {
|
||||
await super.onLoad();
|
||||
images.prefix = '';
|
||||
await images.loadAll(
|
||||
[
|
||||
Assets.images.backbox.button.share.keyName,
|
||||
],
|
||||
);
|
||||
}
|
||||
|
||||
Future<void> pump(InfoDisplay component) {
|
||||
return ensureAdd(
|
||||
FlameBlocProvider<GameBloc, GameState>.value(
|
||||
value: GameBloc(),
|
||||
children: [
|
||||
FlameProvider.value(
|
||||
_MockAppLocalizations(),
|
||||
children: [component],
|
||||
),
|
||||
],
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
class _MockAppLocalizations extends Mock implements AppLocalizations {
|
||||
@override
|
||||
String get shareYourScore => '';
|
||||
|
||||
@override
|
||||
String get andChallengeYourFriends => '';
|
||||
|
||||
@override
|
||||
String get share => '';
|
||||
|
||||
@override
|
||||
String get gotoIO => '';
|
||||
|
||||
@override
|
||||
String get learnMore => '';
|
||||
|
||||
@override
|
||||
String get firebaseOrOpenSource => '';
|
||||
}
|
||||
|
||||
void main() {
|
||||
TestWidgetsFlutterBinding.ensureInitialized();
|
||||
|
||||
final flameTester = FlameTester(_TestGame.new);
|
||||
|
||||
group('InfoDisplay', () {
|
||||
flameTester.test(
|
||||
'loads correctly',
|
||||
(game) async {
|
||||
final component = InfoDisplay();
|
||||
await game.pump(component);
|
||||
expect(game.descendants(), contains(component));
|
||||
},
|
||||
);
|
||||
});
|
||||
}
|
@ -0,0 +1,45 @@
|
||||
import 'package:bloc_test/bloc_test.dart';
|
||||
import 'package:flutter_test/flutter_test.dart';
|
||||
import 'package:mocktail/mocktail.dart';
|
||||
import 'package:pinball/game/game.dart';
|
||||
import 'package:pinball/start_game/bloc/start_game_bloc.dart';
|
||||
|
||||
import '../../../helpers/helpers.dart';
|
||||
|
||||
class _MockStartGameBloc extends Mock implements StartGameBloc {}
|
||||
|
||||
void main() {
|
||||
group('ReplayButtonOverlay', () {
|
||||
late StartGameBloc startGameBloc;
|
||||
|
||||
setUp(() async {
|
||||
await mockFlameImages();
|
||||
startGameBloc = _MockStartGameBloc();
|
||||
|
||||
whenListen(
|
||||
startGameBloc,
|
||||
Stream.value(const StartGameState.initial()),
|
||||
initialState: const StartGameState.initial(),
|
||||
);
|
||||
});
|
||||
|
||||
testWidgets('renders correctly', (tester) async {
|
||||
await tester.pumpApp(const ReplayButtonOverlay());
|
||||
|
||||
expect(find.text('Replay'), findsOneWidget);
|
||||
});
|
||||
|
||||
testWidgets('adds ReplayTapped event to StartGameBloc when taped',
|
||||
(tester) async {
|
||||
await tester.pumpApp(
|
||||
const ReplayButtonOverlay(),
|
||||
startGameBloc: startGameBloc,
|
||||
);
|
||||
|
||||
await tester.tap(find.text('Replay'));
|
||||
await tester.pump();
|
||||
|
||||
verify(() => startGameBloc.add(const ReplayTapped())).called(1);
|
||||
});
|
||||
});
|
||||
}
|
Loading…
Reference in new issue