Added missing methods and implemented tests

This commit is contained in:
2025-11-12 20:02:01 +01:00
parent 3f5a840675
commit 93a4ccaee0
11 changed files with 402 additions and 41 deletions

View File

@@ -0,0 +1,111 @@
import 'package:drift/drift.dart';
import 'package:drift/native.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/game.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/player.dart';
void main() {
late AppDatabase database;
late Player testPlayer;
late Player player1;
late Player player2;
late Player player3;
late Player player4;
late Group testgroup;
late Game testgame;
setUp(() {
database = AppDatabase(
DatabaseConnection(
NativeDatabase.memory(),
// Recommended for widget tests to avoid test errors.
closeStreamsSynchronously: true,
),
);
testPlayer = Player(id: 'test_id', name: 'Test Player');
player1 = Player(id: 'p1', name: 'Alice');
player2 = Player(id: 'p2', name: 'Bob');
player3 = Player(id: 'p3', name: 'Charlie');
player4 = Player(id: 'p4', name: 'Diana');
testgroup = Group(
id: 'gr1',
name: 'Test Group',
members: [player1, player2, player3],
);
testgame = Game(
id: 'ga1',
name: 'Test Game',
group: testgroup,
players: [player4],
);
});
tearDown(() async {
await database.close();
});
group('game tests', () {
test('game is added correctly', () async {
await database.gameDao.addGame(game: testgame);
final result = await database.gameDao.getGameById(gameId: testgame.id);
expect(result.id, testgame.id);
expect(result.name, testgame.name);
expect(result.winner, testgame.winner);
if (result.group != null) {
expect(result.group!.members.length, testgroup.members.length);
for (int i = 0; i < testgroup.members.length; i++) {
expect(result.group!.members[i].id, testgroup.members[i].id);
expect(result.group!.members[i].name, testgroup.members[i].name);
}
} else {
fail('Group is null');
}
if (result.players != null) {
expect(result.players!.length, testgame.players!.length);
for (int i = 0; i < testgame.players!.length; i++) {
expect(result.players![i].id, testgame.players![i].id);
expect(result.players![i].name, testgame.players![i].name);
}
} else {
fail('Players is null');
}
});
test('game is deleted correctly', () async {
await database.gameDao.addGame(game: testgame);
final gameDeleted = await database.gameDao.deleteGame(
gameId: testgame.id,
);
expect(gameDeleted, true);
final gameExists = await database.gameDao.gameExists(gameId: testgame.id);
expect(gameExists, false);
});
test('get game count works correctly', () async {
final initialCount = await database.gameDao.getGameCount();
expect(initialCount, 0);
await database.gameDao.addGame(game: testgame);
final gameAdded = await database.gameDao.getGameCount();
expect(gameAdded, 1);
final gameRemoved = await database.gameDao.deleteGame(
gameId: testgame.id,
);
expect(gameRemoved, true);
final finalCount = await database.gameDao.getGameCount();
expect(finalCount, 0);
});
});
}

View File

@@ -0,0 +1,130 @@
import 'package:drift/drift.dart';
import 'package:drift/native.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/group.dart';
import 'package:game_tracker/data/dto/player.dart';
void main() {
late AppDatabase database;
late Player player1;
late Player player2;
late Player player3;
late Player player4;
late Group testgroup;
setUp(() {
database = AppDatabase(
DatabaseConnection(
NativeDatabase.memory(),
// Recommended for widget tests to avoid test errors.
closeStreamsSynchronously: true,
),
);
player1 = Player(id: 'p1', name: 'Alice');
player2 = Player(id: 'p2', name: 'Bob');
player3 = Player(id: 'p3', name: 'Charlie');
player4 = Player(id: 'p4', name: 'Diana');
testgroup = Group(
id: 'gr1',
name: 'Test Group',
members: [player1, player2, player3],
);
});
tearDown(() async {
await database.close();
});
test('group and group members gets added correctly', () async {
await database.groupDao.addGroup(group: testgroup);
final result = await database.groupDao.getGroupById(groupId: testgroup.id);
expect(result.id, testgroup.id);
expect(result.name, testgroup.name);
expect(result.members.length, testgroup.members.length);
for (int i = 0; i < testgroup.members.length; i++) {
expect(result.members[i].id, testgroup.members[i].id);
expect(result.members[i].name, testgroup.members[i].name);
}
});
test('group gets deleted correctly', () async {
await database.groupDao.addGroup(group: testgroup);
final groupDeleted = await database.groupDao.deleteGroup(
groupId: testgroup.id,
);
expect(groupDeleted, true);
final groupExists = await database.groupDao.groupExists(
groupId: testgroup.id,
);
expect(groupExists, false);
});
test('group name gets updated correcly ', () async {
await database.groupDao.addGroup(group: testgroup);
const newGroupName = 'new group name';
await database.groupDao.updateGroupname(
groupId: testgroup.id,
newName: newGroupName,
);
final result = await database.groupDao.getGroupById(groupId: testgroup.id);
expect(result.name, newGroupName);
});
test('Adding player to group works correctly', () async {
await database.groupDao.addGroup(group: testgroup);
await database.playerGroupDao.addPlayerToGroup(
player: player4,
groupId: testgroup.id,
);
final playerAdded = await database.playerGroupDao.isPlayerInGroup(
playerId: player4.id,
groupId: testgroup.id,
);
expect(playerAdded, true);
final playerAdded2 = await database.playerGroupDao.isPlayerInGroup(
playerId: 'a',
groupId: testgroup.id,
);
expect(playerAdded2, false);
expect(playerAdded, true);
final result = await database.groupDao.getGroupById(groupId: testgroup.id);
expect(result.members.length, testgroup.members.length + 1);
final addedPlayer = result.members.firstWhere((p) => p.id == player4.id);
expect(addedPlayer.name, player4.name);
});
test('Removing player from group works correctly', () async {
await database.groupDao.addGroup(group: testgroup);
final playerToRemove = testgroup.members[0];
final removed = await database.playerGroupDao.removePlayerFromGroup(
playerId: playerToRemove.id,
groupId: testgroup.id,
);
expect(removed, true);
final result = await database.groupDao.getGroupById(groupId: testgroup.id);
expect(result.members.length, testgroup.members.length - 1);
final playerExists = result.members.any((p) => p.id == playerToRemove.id);
expect(playerExists, false);
});
}

View File

@@ -0,0 +1,66 @@
import 'package:drift/drift.dart';
import 'package:drift/native.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:game_tracker/data/db/database.dart';
import 'package:game_tracker/data/dto/player.dart';
void main() {
late AppDatabase database;
late Player testPlayer;
setUp(() {
database = AppDatabase(
DatabaseConnection(
NativeDatabase.memory(),
// Recommended for widget tests to avoid test errors.
closeStreamsSynchronously: true,
),
);
testPlayer = Player(id: 'test_id', name: 'Test Player');
});
tearDown(() async {
await database.close();
});
group('player tests', () {
test('players get inserted correcly ', () async {
await database.playerDao.addPlayer(player: testPlayer);
final result = await database.playerDao.getPlayerById(
playerId: testPlayer.id,
);
expect(result.id, testPlayer.id);
expect(result.name, testPlayer.name);
});
test('players get deleted correcly ', () async {
await database.playerDao.addPlayer(player: testPlayer);
final playerDeleted = await database.playerDao.deletePlayer(
playerId: testPlayer.id,
);
expect(playerDeleted, true);
final playerExists = await database.playerDao.playerExists(
playerId: testPlayer.id,
);
expect(playerExists, false);
});
test('player name gets updated correcly ', () async {
await database.playerDao.addPlayer(player: testPlayer);
const newPlayerName = 'new player name';
await database.playerDao.updatePlayername(
playerId: testPlayer.id,
newName: newPlayerName,
);
final result = await database.playerDao.getPlayerById(
playerId: testPlayer.id,
);
expect(result.name, newPlayerName);
});
});
}