227 lines
6.5 KiB
Dart
227 lines
6.5 KiB
Dart
import 'package:clock/clock.dart';
|
|
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';
|
|
import 'package:game_tracker/data/dto/team.dart';
|
|
|
|
void main() {
|
|
late AppDatabase database;
|
|
late Player testPlayer1;
|
|
late Player testPlayer2;
|
|
late Player testPlayer3;
|
|
late Player testPlayer4;
|
|
late Team testTeam1;
|
|
late Team testTeam2;
|
|
late Team testTeam3;
|
|
final fixedDate = DateTime(2025, 19, 11, 00, 11, 23);
|
|
final fakeClock = Clock(() => fixedDate);
|
|
|
|
setUp(() async {
|
|
database = AppDatabase(
|
|
DatabaseConnection(
|
|
NativeDatabase.memory(),
|
|
// Recommended for widget tests to avoid test errors.
|
|
closeStreamsSynchronously: true,
|
|
),
|
|
);
|
|
|
|
withClock(fakeClock, () {
|
|
testPlayer1 = Player(name: 'Alice');
|
|
testPlayer2 = Player(name: 'Bob');
|
|
testPlayer3 = Player(name: 'Charlie');
|
|
testPlayer4 = Player(name: 'Diana');
|
|
testTeam1 = Team(
|
|
name: 'Team Alpha',
|
|
members: [testPlayer1, testPlayer2],
|
|
);
|
|
testTeam2 = Team(
|
|
name: 'Team Beta',
|
|
members: [testPlayer3, testPlayer4],
|
|
);
|
|
testTeam3 = Team(
|
|
name: 'Team Gamma',
|
|
members: [testPlayer1, testPlayer3],
|
|
);
|
|
});
|
|
|
|
await database.playerDao.addPlayersAsList(
|
|
players: [testPlayer1, testPlayer2, testPlayer3, testPlayer4],
|
|
);
|
|
});
|
|
|
|
tearDown(() async {
|
|
await database.close();
|
|
});
|
|
|
|
group('Team Tests', () {
|
|
test('Adding and fetching a single team works correctly', () async {
|
|
final added = await database.teamDao.addTeam(team: testTeam1);
|
|
expect(added, true);
|
|
|
|
final fetchedTeam = await database.teamDao.getTeamById(
|
|
teamId: testTeam1.id,
|
|
);
|
|
|
|
expect(fetchedTeam.id, testTeam1.id);
|
|
expect(fetchedTeam.name, testTeam1.name);
|
|
expect(fetchedTeam.createdAt, testTeam1.createdAt);
|
|
});
|
|
|
|
test('Adding and fetching multiple teams works correctly', () async {
|
|
await database.teamDao.addTeamsAsList(
|
|
teams: [testTeam1, testTeam2, testTeam3],
|
|
);
|
|
|
|
final allTeams = await database.teamDao.getAllTeams();
|
|
expect(allTeams.length, 3);
|
|
|
|
final testTeams = {
|
|
testTeam1.id: testTeam1,
|
|
testTeam2.id: testTeam2,
|
|
testTeam3.id: testTeam3,
|
|
};
|
|
|
|
for (final team in allTeams) {
|
|
final testTeam = testTeams[team.id]!;
|
|
|
|
expect(team.id, testTeam.id);
|
|
expect(team.name, testTeam.name);
|
|
expect(team.createdAt, testTeam.createdAt);
|
|
}
|
|
});
|
|
|
|
test('Adding the same team twice does not create duplicates', () async {
|
|
await database.teamDao.addTeam(team: testTeam1);
|
|
final addedAgain = await database.teamDao.addTeam(team: testTeam1);
|
|
|
|
expect(addedAgain, false);
|
|
|
|
final teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 1);
|
|
});
|
|
|
|
test('Team existence check works correctly', () async {
|
|
var teamExists = await database.teamDao.teamExists(teamId: testTeam1.id);
|
|
expect(teamExists, false);
|
|
|
|
await database.teamDao.addTeam(team: testTeam1);
|
|
|
|
teamExists = await database.teamDao.teamExists(teamId: testTeam1.id);
|
|
expect(teamExists, true);
|
|
});
|
|
|
|
test('Deleting a team works correctly', () async {
|
|
await database.teamDao.addTeam(team: testTeam1);
|
|
|
|
final teamDeleted = await database.teamDao.deleteTeam(
|
|
teamId: testTeam1.id,
|
|
);
|
|
expect(teamDeleted, true);
|
|
|
|
final teamExists = await database.teamDao.teamExists(
|
|
teamId: testTeam1.id,
|
|
);
|
|
expect(teamExists, false);
|
|
});
|
|
|
|
test('Deleting a non-existent team returns false', () async {
|
|
final teamDeleted = await database.teamDao.deleteTeam(
|
|
teamId: 'non-existent-id',
|
|
);
|
|
expect(teamDeleted, false);
|
|
});
|
|
|
|
test('Getting the team count works correctly', () async {
|
|
var teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 0);
|
|
|
|
await database.teamDao.addTeam(team: testTeam1);
|
|
|
|
teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 1);
|
|
|
|
await database.teamDao.addTeam(team: testTeam2);
|
|
|
|
teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 2);
|
|
|
|
await database.teamDao.deleteTeam(teamId: testTeam1.id);
|
|
|
|
teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 1);
|
|
|
|
await database.teamDao.deleteTeam(teamId: testTeam2.id);
|
|
|
|
teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 0);
|
|
});
|
|
|
|
test('Updating team name works correctly', () async {
|
|
await database.teamDao.addTeam(team: testTeam1);
|
|
|
|
var fetchedTeam = await database.teamDao.getTeamById(
|
|
teamId: testTeam1.id,
|
|
);
|
|
expect(fetchedTeam.name, testTeam1.name);
|
|
|
|
const newName = 'Updated Team Name';
|
|
await database.teamDao.updateTeamName(
|
|
teamId: testTeam1.id,
|
|
newName: newName,
|
|
);
|
|
|
|
fetchedTeam = await database.teamDao.getTeamById(teamId: testTeam1.id);
|
|
expect(fetchedTeam.name, newName);
|
|
});
|
|
|
|
test('Deleting all teams works correctly', () async {
|
|
await database.teamDao.addTeamsAsList(
|
|
teams: [testTeam1, testTeam2, testTeam3],
|
|
);
|
|
|
|
var teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 3);
|
|
|
|
final deleted = await database.teamDao.deleteAllTeams();
|
|
expect(deleted, true);
|
|
|
|
teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 0);
|
|
});
|
|
|
|
test('Deleting all teams when empty returns false', () async {
|
|
final deleted = await database.teamDao.deleteAllTeams();
|
|
expect(deleted, false);
|
|
});
|
|
|
|
test('Adding teams as list with empty list returns false', () async {
|
|
final added = await database.teamDao.addTeamsAsList(teams: []);
|
|
expect(added, false);
|
|
});
|
|
|
|
test('Adding teams with duplicate IDs ignores duplicates', () async {
|
|
final duplicateTeam = Team(
|
|
id: testTeam1.id,
|
|
name: 'Duplicate Team',
|
|
members: [testPlayer4],
|
|
);
|
|
|
|
await database.teamDao.addTeamsAsList(
|
|
teams: [testTeam1, duplicateTeam, testTeam2],
|
|
);
|
|
|
|
final teamCount = await database.teamDao.getTeamCount();
|
|
expect(teamCount, 2);
|
|
|
|
// The first one should be kept (insertOrIgnore)
|
|
final fetchedTeam = await database.teamDao.getTeamById(
|
|
teamId: testTeam1.id,
|
|
);
|
|
expect(fetchedTeam.name, testTeam1.name);
|
|
});
|
|
});
|
|
}
|
|
|