feat(data): add completed game portfolio schema
This commit is contained in:
@@ -0,0 +1,52 @@
|
||||
namespace GmRelay.Bot.Tests.Web;
|
||||
|
||||
public sealed class PortfolioMigrationTests
|
||||
{
|
||||
[Fact]
|
||||
public async Task MigrationV029_ShouldCreatePortfolioTablesAndPublicationGuards()
|
||||
{
|
||||
var migration = await ReadRepositoryFileAsync("src/GmRelay.Bot/Migrations/V029__add_completed_game_portfolios_and_reviews.sql");
|
||||
|
||||
Assert.Contains("CREATE TABLE portfolio_games", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("CREATE TABLE portfolio_game_sessions", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("CREATE TABLE portfolio_game_masters", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("CREATE TABLE portfolio_game_reviews", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("cover_storage_key", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("UNIQUE (session_id)", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("UNIQUE (portfolio_game_id, author_player_id)", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("'Pending'", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("'Approved'", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("'Rejected'", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("'Hidden'", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("publication_consent_at", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("ix_portfolio_games_public", migration, StringComparison.Ordinal);
|
||||
Assert.Contains("ix_portfolio_game_reviews_public", migration, StringComparison.Ordinal);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task MigrationV029_ShouldStoreProviderNeutralCoverKeys()
|
||||
{
|
||||
var migration = await ReadRepositoryFileAsync("src/GmRelay.Bot/Migrations/V029__add_completed_game_portfolios_and_reviews.sql");
|
||||
|
||||
Assert.Contains("cover_storage_key", migration, StringComparison.Ordinal);
|
||||
Assert.DoesNotContain("s3_bucket", migration, StringComparison.OrdinalIgnoreCase);
|
||||
Assert.DoesNotContain("physical_path", migration, StringComparison.OrdinalIgnoreCase);
|
||||
}
|
||||
|
||||
private static async Task<string> ReadRepositoryFileAsync(string relativePath)
|
||||
{
|
||||
var directory = new DirectoryInfo(AppContext.BaseDirectory);
|
||||
while (directory is not null)
|
||||
{
|
||||
var candidate = Path.Combine(directory.FullName, relativePath);
|
||||
if (File.Exists(candidate))
|
||||
{
|
||||
return await File.ReadAllTextAsync(candidate);
|
||||
}
|
||||
|
||||
directory = directory.Parent;
|
||||
}
|
||||
|
||||
throw new FileNotFoundException($"Could not locate repository file '{relativePath}'.");
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user