* Updated createGameView ListBuilder * Added ReorderableListView * Increment build no * Fixed bug with wrong medal icon * change not equal to greater than * Updated bool var * Fixed deletion error * Small translation improvements * Implemented first version of point overview * Visual improvements on table * Added details and sum row * Updated strings * Implemented new strings * Refactoring * Updated graph displayment * Moved new views to statistics section * Added seperator in main menu * Renaming * Updated sign * Updated colors & class name * Removed empty line * Updated round index * Updated types * Added new kamikaze button and bundles navigation functionality * Updated lock icon * Updated button position and design * Removed title row and changed segmendetControl Padding * Refactored logic and added comments * Updated comment * Chaned icon * Added comment * Removed print * Updated colors * Changed var name * Removed unused strings * Added gameMode * Changed creation variable * Updated mode selection * Updated strings * Changed mode order * Implemented default mode selection * Updated initState * Removed print * Removed print * Removed comments * Updated config service * Changed create game view * Changed icon * Updated strings * Updated config * Updated mode selection logic * Deleted getter * Removed not used code * Implemented reset logic for default game mode * Updated to 0.5.0 * Hotfix: Pixel Overflow * Changed the overall return type for gamemodes * Updated documentation * Fixed merge issues * Added Custom button * Updated strings * Updated buttons, implemented animatedOpacity * Keyboard still doesnt works * Fixed keyboard behaviour * Changed keyboard height * Added method getGameSessionById() * Updated gameSession class * id gets added to gameSession class at creation * Cleaned up file * Added docs and dependency * Removed toString * Implemented null safety * Added named parameter * Replaced button with custom button * Updated key * Updated addGameSessionMethod * Update README.md * Added Strings for popup * Implemented popup & confetti * Extracted code to method _playFinishAnimation() * Replaced tenary operator with Visibility Widget * Replaced tenary operator with Visibility Widget * Used variable again * Added delays in constants.dart * Removed confetti button * Updated strings * Removed print * Added dispose for confettiController * Implemented missing constant in code * Updated gameSession logic so more than one player can be winner * Updated strings * Updated winner popup * game names now can have up to 20 chars * Updated strings * Added sized box for visual enhancement * Centered the add player button and made it wider * New created player textfields get automatically focused * Added focus nodes for autofocus and navigation between textfields * Updated version number * Updated game title textfield with focus node and textaction * Added focusnodes to dispose * Update README.md * Fixed bug with no popup shown * Fixed bug with out of range error * Updated listener notification
		
			
				
	
	
		
			165 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			165 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:cabo_counter/data/game_session.dart';
 | |
| import 'package:test/test.dart';
 | |
| 
 | |
| void main() {
 | |
|   late GameSession session;
 | |
|   final testPlayers = ['Alice', 'Bob', 'Charlie'];
 | |
|   final testDate = DateTime(2023, 1, 1);
 | |
|   const testTitle = 'Test Game';
 | |
| 
 | |
|   setUp(() {
 | |
|     session = GameSession(
 | |
|       id: '1',
 | |
|       createdAt: testDate,
 | |
|       gameTitle: testTitle,
 | |
|       players: testPlayers,
 | |
|       pointLimit: 100,
 | |
|       caboPenalty: 5,
 | |
|       isPointsLimitEnabled: true,
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   group('Initialization & JSON', () {
 | |
|     test('Initialization', () {
 | |
|       expect(session.gameTitle, testTitle);
 | |
|       expect(session.players, testPlayers);
 | |
|       expect(session.playerScores, [0, 0, 0]);
 | |
|       expect(session.roundNumber, 1);
 | |
|       expect(session.isGameFinished, isFalse);
 | |
|       expect(session.winner, isEmpty);
 | |
|     });
 | |
| 
 | |
|     test('toJson and fromJson', () {
 | |
|       // Add some rounds to test serialization
 | |
|       session.addRoundScoresToList(1, [10, 20, 30], [10, 20, 30], 0);
 | |
|       session.addRoundScoresToList(2, [15, 25, 35], [5, 5, 5], 1);
 | |
| 
 | |
|       final json = session.toJson();
 | |
|       final fromJsonSession = GameSession.fromJson(json);
 | |
| 
 | |
|       expect(fromJsonSession.gameTitle, testTitle);
 | |
|       expect(fromJsonSession.players, testPlayers);
 | |
|       expect(fromJsonSession.roundList.length, 2);
 | |
|     });
 | |
| 
 | |
|     test('null values in JSON', () {
 | |
|       expect(
 | |
|           () => GameSession.fromJson({
 | |
|                 'createdAt': testDate.toIso8601String(),
 | |
|                 'gameTitle': null, // Invalid
 | |
|                 'players': testPlayers,
 | |
|                 'pointLimit': 100,
 | |
|                 'caboPenalty': 50,
 | |
|                 'isPointsLimitEnabled': true,
 | |
|                 'isGameFinished': false,
 | |
|                 'winner': '',
 | |
|                 'roundNumber': 1,
 | |
|                 'playerScores': [0, 0, 0],
 | |
|                 'roundList': [],
 | |
|               }),
 | |
|           throwsA(isA<TypeError>()));
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   group('Helper Functions', () {
 | |
|     test('getMaxLengthOfPlayerNames', () {
 | |
|       expect(session.getMaxLengthOfPlayerNames(), equals(7)); // Charlie (7)
 | |
|     });
 | |
| 
 | |
|     test('increaseRound', () {
 | |
|       expect(session.roundNumber, 1);
 | |
|       session.increaseRound();
 | |
|       expect(session.roundNumber, 2);
 | |
|     });
 | |
| 
 | |
|     test('getLowestScoreIndex', () {
 | |
|       List<int> lowestScoreIndex;
 | |
| 
 | |
|       lowestScoreIndex = session.testingGetLowestScoreIndex([5, 10, 15]);
 | |
|       expect(lowestScoreIndex, [0]);
 | |
| 
 | |
|       lowestScoreIndex = session.testingGetLowestScoreIndex([5, 5, 15]);
 | |
|       expect(lowestScoreIndex, [0, 1]);
 | |
| 
 | |
|       lowestScoreIndex = session.testingGetLowestScoreIndex([5, 5, 5]);
 | |
|       expect(lowestScoreIndex, [0, 1, 2]);
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   group('Game Functions', () {
 | |
|     test('applyKamikaze', () {
 | |
|       session.applyKamikaze(1, 0); // Alice has kamikaze
 | |
|       expect(session.roundList[0].scoreUpdates, [0, 50, 50]);
 | |
|       expect(session.roundList[0].scores, [0, 0, 0]);
 | |
|       expect(session.roundList[0].kamikazePlayerIndex, 0);
 | |
|       expect(session.roundList[0].caboPlayerIndex, 0);
 | |
|     });
 | |
| 
 | |
|     test('calculateScoredPoints - CABO player has lowest', () {
 | |
|       session.calculateScoredPoints(1, [3, 5, 8], 0); // Alice has lowest
 | |
|       expect(session.roundList[0].scoreUpdates, equals([0, 5, 8]));
 | |
|     });
 | |
| 
 | |
|     test('calculateScoredPoints - CABO player not lowest', () {
 | |
|       session.calculateScoredPoints(1, [5, 3, 8], 0); // Bob has lowest
 | |
|       expect(session.roundList[0].scoreUpdates, [10, 0, 8]);
 | |
|     });
 | |
| 
 | |
|     test('addRoundScoresToList', () {
 | |
|       session.addRoundScoresToList(1, [3, 5, 8], [0, 5, 8], 0);
 | |
|       expect(session.roundList.length, 1);
 | |
|       expect(session.roundList[0].roundNum, 1);
 | |
|       expect(session.roundList[0].scoreUpdates, [0, 5, 8]);
 | |
|       expect(session.roundList[0].scores, [3, 5, 8]);
 | |
|       expect(session.roundList[0].kamikazePlayerIndex, isNull);
 | |
|       expect(session.roundList[0].caboPlayerIndex, 0);
 | |
|     });
 | |
| 
 | |
|     test('updatePoints - game not finished', () {
 | |
|       session.addRoundScoresToList(1, [10, 20, 30], [10, 20, 30], 0);
 | |
|       session.updatePoints();
 | |
|       expect(session.isGameFinished, isFalse);
 | |
|     });
 | |
| 
 | |
|     test('updatePoints - game finished', () {
 | |
|       session.addRoundScoresToList(1, [101, 20, 30], [101, 20, 30], 0);
 | |
|       session.updatePoints();
 | |
|       expect(session.isGameFinished, isTrue);
 | |
|     });
 | |
| 
 | |
|     test('_assignPoints', () {
 | |
|       // Alice said Cabo and has the lowest score
 | |
|       session.testingAssignPoints(1, [5, 10, 15], 0, [0]);
 | |
|       expect(session.roundList[0].scoreUpdates, [0, 10, 15]);
 | |
| 
 | |
|       // Alice said Cabo and has not the lowest score
 | |
|       session.testingAssignPoints(1, [5, 10, 15], 0, [1], 0);
 | |
|       expect(session.roundList[0].scoreUpdates, [10, 0, 15]);
 | |
| 
 | |
|       // Bob and Charlie have the lowest score, Alice said Cabo
 | |
|       session.testingAssignPoints(1, [15, 5, 5], 0, [1, 2], 0);
 | |
|       expect(session.roundList[0].scoreUpdates, [20, 0, 0]);
 | |
|     });
 | |
| 
 | |
|     test('_sumPoints', () async {
 | |
|       session.addRoundScoresToList(1, [10, 20, 30], [10, 20, 30], 0);
 | |
|       session.addRoundScoresToList(2, [5, 5, 5], [5, 5, 5], 1);
 | |
|       session.testingSumPoints();
 | |
|       expect(session.playerScores, [15, 25, 35]);
 | |
|     });
 | |
| 
 | |
|     test('_checkHundredPointsReached via updatePoints', () {
 | |
|       session.addRoundScoresToList(1, [50, 5, 15], [50, 0, 15], 1);
 | |
|       session.addRoundScoresToList(2, [50, 5, 15], [50, 0, 15], 1);
 | |
|       session.updatePoints();
 | |
|       expect(session.playerScores, equals([50, 0, 30]));
 | |
|     });
 | |
| 
 | |
|     test('_setWinner via updatePoints', () {
 | |
|       session.addRoundScoresToList(1, [101, 20, 30], [101, 0, 30], 1);
 | |
|       session.updatePoints();
 | |
|       expect(session.winner, 'Bob'); // Bob has lowest score (20)
 | |
|     });
 | |
|   });
 | |
| }
 |