Idempotent upsert importer for arena-two-pick-rewards.json; 2 NUnit tests (16-row load + idempotency). Wired into Program.cs globals pipeline after ArenaSeasonImporter. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
52 lines
1.6 KiB
C#
52 lines
1.6 KiB
C#
using Microsoft.EntityFrameworkCore;
|
|
using SVSim.Bootstrap.Models.Seed;
|
|
using SVSim.Database;
|
|
using SVSim.Database.Models;
|
|
|
|
namespace SVSim.Bootstrap.Importers;
|
|
|
|
/// <summary>
|
|
/// Idempotent upsert of <see cref="ArenaTwoPickReward"/> rows from
|
|
/// <c>arena-two-pick-rewards.json</c>. Key = (WinCount, RewardType, RewardId).
|
|
/// </summary>
|
|
public class ArenaTwoPickRewardImporter
|
|
{
|
|
public async Task<int> ImportAsync(SVSimDbContext context, string seedDir)
|
|
{
|
|
var path = Path.Combine(seedDir, "arena-two-pick-rewards.json");
|
|
if (!File.Exists(path))
|
|
{
|
|
Console.WriteLine($"[ArenaTwoPickRewardImporter] missing {path}; skipping.");
|
|
return 0;
|
|
}
|
|
|
|
var seeds = SeedLoader.LoadList<ArenaTwoPickRewardSeed>(path);
|
|
var existing = await context.ArenaTwoPickRewards
|
|
.ToDictionaryAsync(r => (r.WinCount, r.RewardType, r.RewardId));
|
|
|
|
int upserted = 0;
|
|
foreach (var s in seeds)
|
|
{
|
|
if (existing.TryGetValue((s.WinCount, s.RewardType, s.RewardId), out var row))
|
|
{
|
|
row.RewardNum = s.RewardNum;
|
|
}
|
|
else
|
|
{
|
|
context.ArenaTwoPickRewards.Add(new ArenaTwoPickReward
|
|
{
|
|
WinCount = s.WinCount,
|
|
RewardType = s.RewardType,
|
|
RewardId = s.RewardId,
|
|
RewardNum = s.RewardNum,
|
|
});
|
|
}
|
|
upserted++;
|
|
}
|
|
|
|
await context.SaveChangesAsync();
|
|
Console.WriteLine($"[ArenaTwoPickRewardImporter] upserted={upserted}");
|
|
return upserted;
|
|
}
|
|
}
|