feat(inventory): add ViewerAcquireHistoryEntry entity + DbSet

Adds the ViewerAcquireHistoryEntry model (8 fields: Id, ViewerId,
RewardType, RewardDetailId, RewardCount, AcquireType, Message,
AcquireTime), registers DbSet<ViewerAcquireHistoryEntry> on
SVSimDbContext, configures model (PK, FK cascade to Viewer, MaxLength
64 on Message, composite index on ViewerId/AcquireTime/Id), and adds a
DbSet round-trip integration test.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
gamer147
2026-06-09 14:19:00 -04:00
parent 82dc877639
commit 0d036e1bff
3 changed files with 73 additions and 0 deletions

View File

@@ -1,3 +1,5 @@
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using SVSim.Database.Services.Inventory;
namespace SVSim.UnitTests.Services.Inventory;
@@ -37,4 +39,31 @@ public class InventoryHistoryTests
var cfg = new InventoryLoadConfig { Source = GrantSource.PackOpen };
Assert.That(cfg.Source, Is.EqualTo(GrantSource.PackOpen));
}
[Test]
public async Task ViewerAcquireHistory_DbSet_round_trips_a_row()
{
using var factory = new SVSim.UnitTests.Infrastructure.SVSimTestFactory();
long viewerId = await factory.SeedViewerAsync();
using var scope = factory.Services.CreateScope();
var ctx = scope.ServiceProvider.GetRequiredService<SVSim.Database.SVSimDbContext>();
ctx.ViewerAcquireHistory.Add(new SVSim.Database.Models.ViewerAcquireHistoryEntry
{
ViewerId = viewerId,
RewardType = (int)SVSim.Database.Enums.UserGoodsType.Rupy,
RewardDetailId = 0,
RewardCount = 50,
AcquireType = (int)GrantSource.DailyBonus,
Message = "Daily Bonus",
AcquireTime = new DateTime(2026, 6, 9, 12, 0, 0, DateTimeKind.Utc),
});
await ctx.SaveChangesAsync();
var roundtrip = await ctx.ViewerAcquireHistory.AsNoTracking()
.Where(h => h.ViewerId == viewerId).ToListAsync();
Assert.That(roundtrip, Has.Count.EqualTo(1));
Assert.That(roundtrip[0].RewardCount, Is.EqualTo(50));
Assert.That(roundtrip[0].AcquireType, Is.EqualTo((int)GrantSource.DailyBonus));
}
}