mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-24 23:38:59 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			116 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Data.Common;
 | |
| using System.Linq;
 | |
| using System.Threading.Tasks;
 | |
| using API.Data;
 | |
| using API.Entities;
 | |
| using API.Entities.Enums;
 | |
| using API.Helpers;
 | |
| using API.Helpers.Builders;
 | |
| using API.Services;
 | |
| using AutoMapper;
 | |
| using Hangfire;
 | |
| using Microsoft.Data.Sqlite;
 | |
| using Microsoft.EntityFrameworkCore;
 | |
| using Microsoft.EntityFrameworkCore.Infrastructure;
 | |
| using Microsoft.Extensions.Logging;
 | |
| using NSubstitute;
 | |
| using Polly;
 | |
| using Xunit.Abstractions;
 | |
| 
 | |
| namespace API.Tests;
 | |
| 
 | |
| public abstract class AbstractDbTest(ITestOutputHelper testOutputHelper): AbstractFsTest
 | |
| {
 | |
| 
 | |
|     protected async Task<(IUnitOfWork, DataContext, IMapper)> CreateDatabase()
 | |
|     {
 | |
|         var contextOptions = new DbContextOptionsBuilder<DataContext>()
 | |
|             .UseSqlite(CreateInMemoryDatabase())
 | |
|             .EnableSensitiveDataLogging()
 | |
|             .Options;
 | |
| 
 | |
|         var connection = RelationalOptionsExtension.Extract(contextOptions).Connection;
 | |
|         var context = new DataContext(contextOptions);
 | |
| 
 | |
|         await context.Database.EnsureCreatedAsync();
 | |
| 
 | |
|         await SeedDb(context);
 | |
| 
 | |
| 
 | |
|         var config = new MapperConfiguration(cfg => cfg.AddProfile<AutoMapperProfiles>());
 | |
|         var mapper = config.CreateMapper();
 | |
| 
 | |
|         GlobalConfiguration.Configuration.UseInMemoryStorage();
 | |
|         var unitOfWork = new UnitOfWork(context, mapper, null);
 | |
| 
 | |
|         return (unitOfWork, context, mapper);
 | |
|     }
 | |
| 
 | |
|     private static DbConnection CreateInMemoryDatabase()
 | |
|     {
 | |
|         var connection = new SqliteConnection("Filename=:memory:");
 | |
|         connection.Open();
 | |
| 
 | |
|         return connection;
 | |
|     }
 | |
| 
 | |
|     private async Task<bool> SeedDb(DataContext context)
 | |
|     {
 | |
|         try
 | |
|         {
 | |
|             await context.Database.EnsureCreatedAsync();
 | |
|             var filesystem = CreateFileSystem();
 | |
| 
 | |
|             await Seed.SeedSettings(context, new DirectoryService(Substitute.For<ILogger<DirectoryService>>(), filesystem));
 | |
| 
 | |
|             var setting = await context.ServerSetting.Where(s => s.Key == ServerSettingKey.CacheDirectory).SingleAsync();
 | |
|             setting.Value = CacheDirectory;
 | |
| 
 | |
|             setting = await context.ServerSetting.Where(s => s.Key == ServerSettingKey.BackupDirectory).SingleAsync();
 | |
|             setting.Value = BackupDirectory;
 | |
| 
 | |
|             setting = await context.ServerSetting.Where(s => s.Key == ServerSettingKey.BookmarkDirectory).SingleAsync();
 | |
|             setting.Value = BookmarkDirectory;
 | |
| 
 | |
|             setting = await context.ServerSetting.Where(s => s.Key == ServerSettingKey.TotalLogs).SingleAsync();
 | |
|             setting.Value = "10";
 | |
| 
 | |
|             context.ServerSetting.Update(setting);
 | |
| 
 | |
| 
 | |
|             context.Library.Add(new LibraryBuilder("Manga")
 | |
|                 .WithAllowMetadataMatching(true)
 | |
|                 .WithFolderPath(new FolderPathBuilder(DataDirectory).Build())
 | |
|                 .Build());
 | |
| 
 | |
|             await context.SaveChangesAsync();
 | |
| 
 | |
|             await Seed.SeedMetadataSettings(context);
 | |
| 
 | |
|             return true;
 | |
|         }
 | |
|         catch (Exception ex)
 | |
|         {
 | |
|             testOutputHelper.WriteLine($"[SeedDb] Error: {ex.Message}");
 | |
|             return false;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Add a role to an existing User. Commits.
 | |
|     /// </summary>
 | |
|     /// <param name="userId"></param>
 | |
|     /// <param name="roleName"></param>
 | |
|     protected async Task AddUserWithRole(DataContext context, int userId, string roleName)
 | |
|     {
 | |
|         var role = new AppRole { Id = userId, Name = roleName, NormalizedName = roleName.ToUpper() };
 | |
| 
 | |
|         await context.Roles.AddAsync(role);
 | |
|         await context.UserRoles.AddAsync(new AppUserRole { UserId = userId, RoleId = userId });
 | |
| 
 | |
|         await context.SaveChangesAsync();
 | |
|     }
 | |
| 
 | |
| }
 |