using Business; using Entities; using Microsoft.Data.Sqlite; using Microsoft.EntityFrameworkCore; using Model; using Shared; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace TestEF { public class TestRunePage { [Fact] public async void Test_Add() { //connection must be opened to use In-memory database var connection = new SqliteConnection("DataSource=:memory:"); connection.Open(); var options = new DbContextOptionsBuilder() .UseSqlite(connection) .Options; using (var context = new LolDbContext(options)) { var manager = new DbData(context).RunePagesMgr; var runeManager = new DbData(context).RunesMgr; context.Database.EnsureCreated(); Model.Rune rune1 = new("Sanglante", RuneFamily.Domination); Model.Rune rune2 = new("Oeil de l'esprit", RuneFamily.Precision); Model.Rune rune3 = new("Concrétisation", RuneFamily.Unknown); Model.Rune rune4 = new("The moon", RuneFamily.Unknown); Model.Rune rune5 = new("Radiance", RuneFamily.Domination); Model.Rune rune6 = new("Bullseye", RuneFamily.Precision); RunePage runepage1 = new("Damages"); runepage1[Category.Major] = rune1; runepage1[Category.Minor1] = rune2; runepage1[Category.Minor2] = rune5; RunePage runepage2 = new("Hawk"); runepage2[Category.Major] = rune6; runepage2[Category.Minor1] = rune2; RunePage runepage3 = new("Juggler"); runepage3[Category.Major] = rune5; runepage3[Category.Minor1] = rune3; runepage3[Category.Minor2] = rune2; await runeManager.AddItem(rune1); await runeManager.AddItem(rune2); await runeManager.AddItem(rune3); await runeManager.AddItem(rune4); await runeManager.AddItem(rune5); await runeManager.AddItem(rune6); await manager.AddItem(runepage1); await manager.AddItem(runepage2); await manager.AddItem(runepage3); } //uses another instance of the context to do the tests using (var context = new LolDbContext(options)) { var manager = new DbData(context).RunePagesMgr; context.Database.EnsureCreated(); Model.Rune rune5 = new("Radiance", RuneFamily.Domination); Model.Rune rune1 = new("Sanglante", RuneFamily.Domination); var nbItems = await manager.GetNbItems(); Assert.Equal(3, nbItems); var items = await manager.GetItemsByName("Ha", 0, nbItems); Assert.Equal("Hawk", items.First().Name); Assert.Equal(2, await manager.GetNbItemsByName("a")); Assert.Equal(1, await manager.GetNbItemsByRune(rune5)); items = await manager.GetItemsByRune(rune1, 0, nbItems); Assert.Equal("Damages", items.First().Name); } } } }