mirror of
https://github.com/farcasclaudiu/LanBackup.git
synced 2026-06-22 07:01:08 +03:00
improved ef context, ef inmemory
This commit is contained in:
@@ -227,7 +227,7 @@ export class BackupsComponent implements OnInit {
|
||||
this.currentPage = page
|
||||
this.totalPages = data.tp * this.pageSize;
|
||||
this.isloading = false;
|
||||
}, 300);//TODO - remove - induced delay
|
||||
}, 200);//TODO - remove - induced delay
|
||||
|
||||
},
|
||||
err => {
|
||||
|
||||
@@ -57,7 +57,7 @@ export class LogsComponent implements OnInit {
|
||||
this.currentPage = page
|
||||
this.totalPages = data.tp * this.pageSize;
|
||||
this.isloading = false;
|
||||
}, 400);//induced delay
|
||||
}, 200);//TODO - remove induced delay
|
||||
},
|
||||
err => this.log.error(err)
|
||||
);
|
||||
|
||||
@@ -10,6 +10,7 @@ using AutoMapper;
|
||||
using LanBackup.WebApp.Models.DTO;
|
||||
using AutoMapper.QueryableExtensions;
|
||||
using LanBackup.WebApp.Models.Telemetry;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace LanBackup.WebApp.Controllers
|
||||
{
|
||||
@@ -44,9 +45,8 @@ namespace LanBackup.WebApp.Controllers
|
||||
[ProducesResponseType(typeof(IEnumerable<BackupConfigurationDTO>), 200)]
|
||||
[ProducesResponseType(typeof(PaginatedList<BackupConfiguration, String, BackupConfigurationDTO>), 200)]
|
||||
public async Task<IActionResult> Get([FromHeader] string idx, [FromHeader] string siz)
|
||||
//public IEnumerable<BackupConfiguration> Get()
|
||||
{
|
||||
//return new DatabaseManager(_context).GetBackupConfigs();
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
if (!string.IsNullOrEmpty(idx) && !string.IsNullOrEmpty(siz))
|
||||
{
|
||||
return new OkObjectResult(
|
||||
@@ -67,6 +67,7 @@ namespace LanBackup.WebApp.Controllers
|
||||
[ProducesResponseType(typeof(BackupConfigurationDTO), 404)]
|
||||
public IActionResult Get(string id)
|
||||
{
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
var res = new DatabaseManager(_context).GetBackupConfig(id);
|
||||
if (res == null)
|
||||
{
|
||||
@@ -87,6 +88,7 @@ namespace LanBackup.WebApp.Controllers
|
||||
[ProducesResponseType(typeof(IEnumerable<BackupConfigurationDTO>), 404)]
|
||||
public IActionResult GetByCient(string clientid)
|
||||
{
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
var results = new DatabaseManager(_context).GetBackupConfigByClient(clientid);
|
||||
if (results == null || results.Count() == 0)
|
||||
return NotFound();
|
||||
|
||||
@@ -10,6 +10,7 @@ using LanBackup.WebApp.Models.DTO;
|
||||
using AutoMapper;
|
||||
using AutoMapper.QueryableExtensions;
|
||||
using LanBackup.WebApp.Models.Telemetry;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
|
||||
namespace LanBackup.WebApp.Controllers
|
||||
{
|
||||
@@ -35,19 +36,6 @@ namespace LanBackup.WebApp.Controllers
|
||||
}
|
||||
|
||||
|
||||
///// <summary>
|
||||
///// retrieves all logs from DB
|
||||
///// </summary>
|
||||
///// <returns></returns>
|
||||
//[AllowAnonymous]
|
||||
//[HttpGet]
|
||||
//[ProducesResponseType(typeof(IEnumerable<BackupLog>), 200)]
|
||||
//public IActionResult Get()
|
||||
//{
|
||||
// return new OkObjectResult(_context.Logs.ToList());
|
||||
// //return new ObjectResult(_context.Logs.ToList());
|
||||
//}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// retrieves paginated logs from DB
|
||||
@@ -57,14 +45,11 @@ namespace LanBackup.WebApp.Controllers
|
||||
/// <returns></returns>
|
||||
[AllowAnonymous]
|
||||
[HttpGet]
|
||||
//[HttpGet("{pageIndex}/{pageSize}")]
|
||||
[ProducesResponseType(typeof(IEnumerable<BackupLogDTO>), 200)]
|
||||
[ProducesResponseType(typeof(PaginatedList<BackupLog, DateTime, BackupLogDTO>), 200)]
|
||||
public async Task<IActionResult> Get([FromHeader] string idx, [FromHeader] string siz)
|
||||
{
|
||||
//StringValues val1, val2;
|
||||
//HttpContext.Request.Headers.TryGetValue("idx", out val1) &&
|
||||
//HttpContext.Request.Headers.TryGetValue("siz", out val2)
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
if (!string.IsNullOrEmpty(idx) && !string.IsNullOrEmpty(siz))
|
||||
{
|
||||
return new OkObjectResult(
|
||||
@@ -86,6 +71,7 @@ namespace LanBackup.WebApp.Controllers
|
||||
[ProducesResponseType(typeof(BackupLogDTO), 404)]
|
||||
public IActionResult Get(int id)
|
||||
{
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
var result = _context.Logs.SingleOrDefault(p => p.ID == id);
|
||||
if (result == null)
|
||||
{
|
||||
@@ -107,6 +93,7 @@ namespace LanBackup.WebApp.Controllers
|
||||
[ProducesResponseType(typeof(IEnumerable<BackupLogDTO>), 404)]
|
||||
public IActionResult GetByCientID(string clientid)
|
||||
{
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
var results = _context.Logs.Where(p => p.ClientIP == clientid).OrderByDescending(o => o.DateTime);
|
||||
if (results == null || results.Count() == 0)
|
||||
return NotFound();
|
||||
@@ -126,6 +113,7 @@ namespace LanBackup.WebApp.Controllers
|
||||
[ProducesResponseType(typeof(IEnumerable<BackupLogDTO>), 404)]
|
||||
public IActionResult GetByConfigurationID(string configurationid)
|
||||
{
|
||||
_context.ChangeTracker.QueryTrackingBehavior = QueryTrackingBehavior.NoTracking;
|
||||
var results = _context.Logs.Where(p => p.ConfigurationID == configurationid).OrderByDescending(o => o.DateTime);
|
||||
if (results == null || results.Count() == 0)
|
||||
return NotFound();
|
||||
@@ -141,7 +129,7 @@ namespace LanBackup.WebApp.Controllers
|
||||
/// </summary>
|
||||
/// <param name="log"></param>
|
||||
/// <returns></returns>
|
||||
[AllowAnonymous]//[Authorize(Roles = "Admin")]
|
||||
[AllowAnonymous]//TODO [Authorize(Roles = "Admin")]
|
||||
[HttpPost]
|
||||
[ProducesResponseType(typeof(int), 200)]
|
||||
[ProducesResponseType(typeof(int), 400)]
|
||||
|
||||
@@ -47,8 +47,8 @@ namespace LanBackup.WebApp.Controllers
|
||||
var count = await source.CountAsync();
|
||||
if (order != null)
|
||||
{
|
||||
var items = source.OrderByDescending(order).Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList();// .ToListAsync();
|
||||
var mappedItems = mapper.Map<List<T>, List<M>>(items);
|
||||
var items = source.OrderByDescending(order).Skip((pageIndex - 1) * pageSize).Take(pageSize).ToAsyncEnumerable();
|
||||
var mappedItems = mapper.Map<List<T>, List<M>>(await items.ToList());
|
||||
return new PaginatedList<T, U, M>(mappedItems, count, pageIndex, pageSize);
|
||||
}
|
||||
else
|
||||
|
||||
@@ -37,7 +37,8 @@
|
||||
"AutoMapper": "5.2.0",
|
||||
"AutoMapper.Extensions.Microsoft.DependencyInjection": "1.2.0",
|
||||
"Microsoft.ApplicationInsights.AspNetCore": "2.0.0",
|
||||
"Microsoft.ApplicationInsights.JavaScript": "1.0.7-build00691"
|
||||
"Microsoft.ApplicationInsights.JavaScript": "1.0.7-build00691",
|
||||
"Microsoft.EntityFrameworkCore": "1.1.0"
|
||||
},
|
||||
|
||||
"tools": {
|
||||
|
||||
@@ -63,12 +63,76 @@ namespace LanBackup.WebApp.Tests.IntegrationTests
|
||||
|
||||
|
||||
|
||||
#region EF InMemory DB
|
||||
|
||||
[Fact]
|
||||
public async void WithEfInMemoryTestMethod()
|
||||
{
|
||||
using (var mctx = new EfInMemoryContext().GetContext())
|
||||
{
|
||||
var service = new LogsController(Mapper.Instance, mctx, _tele);
|
||||
var res = Assert.IsType<OkObjectResult>(await service.Get(null, null));
|
||||
var val1 = Assert.IsType<List<BackupLogDTO>>(res.Value);
|
||||
|
||||
Assert.Equal(5, val1.Count());
|
||||
}
|
||||
}
|
||||
|
||||
private class EfInMemoryContext : IDisposable
|
||||
{
|
||||
private BackupsContext _context;
|
||||
private DbContextOptions<BackupsContext> options;
|
||||
|
||||
public EfInMemoryContext()
|
||||
{
|
||||
options = new DbContextOptionsBuilder<BackupsContext>()
|
||||
.UseInMemoryDatabase()
|
||||
.Options;
|
||||
|
||||
// Create the schema in the database
|
||||
using (var context = new BackupsContext(options))
|
||||
{
|
||||
context.Database.EnsureCreated();
|
||||
}
|
||||
|
||||
// Insert seed data into the database using one instance of the context
|
||||
using (var context = new BackupsContext(options))
|
||||
{
|
||||
int id = 1;
|
||||
context.Add(new BackupLog { ClientIP = "192.168.1.100", Description = $"Playing with some test data {Guid.NewGuid()}", Status = "OK", ID = id++ });
|
||||
context.Add(new BackupLog { ClientIP = "192.168.1.100", Description = $"Playing with some test data {Guid.NewGuid()}", Status = "OK", ID = id++ });
|
||||
context.Add(new BackupLog { ClientIP = "192.168.1.101", Description = $"Playing with some test data {Guid.NewGuid()}", Status = "OK", ID = id++ });
|
||||
context.Add(new BackupLog { ClientIP = "192.168.1.102", Description = $"Playing with some test data {Guid.NewGuid()}", Status = "OK", ID = id++ });
|
||||
context.Add(new BackupLog { ClientIP = "192.168.1.103", Description = $"Playing with some test data {Guid.NewGuid()}", Status = "OK", ID = id++ });
|
||||
context.SaveChanges();
|
||||
}
|
||||
_context = new BackupsContext(options);
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
_context.Dispose();
|
||||
}
|
||||
|
||||
internal BackupsContext GetContext()
|
||||
{
|
||||
return _context;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#endregion EF InMemory DB
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#region SqliteInMemory DB tests
|
||||
|
||||
[Fact]
|
||||
public async void WithSqliteInmemoryTestMethod()
|
||||
{
|
||||
using (var mctx = new GetSqliteMemoryContext().GetContext())
|
||||
using (var mctx = new SqliteMemoryContext().GetContext())
|
||||
{
|
||||
var service = new LogsController(Mapper.Instance, mctx, _tele);
|
||||
var res = Assert.IsType<OkObjectResult>(await service.Get(null, null));
|
||||
@@ -83,7 +147,7 @@ namespace LanBackup.WebApp.Tests.IntegrationTests
|
||||
public async void GetByIdWithSqliteInmemoryTestMethod()
|
||||
{
|
||||
|
||||
using (var mctx = new GetSqliteMemoryContext().GetContext())
|
||||
using (var mctx = new SqliteMemoryContext().GetContext())
|
||||
{
|
||||
var recId = 1;
|
||||
var service = new LogsController(Mapper.Instance, mctx, _tele);
|
||||
@@ -103,7 +167,7 @@ namespace LanBackup.WebApp.Tests.IntegrationTests
|
||||
public async void GetByClientIdWithSqliteInmemoryTestMethod()
|
||||
{
|
||||
|
||||
using (var mctx = new GetSqliteMemoryContext().GetContext())
|
||||
using (var mctx = new SqliteMemoryContext().GetContext())
|
||||
{
|
||||
var clientId = "192.168.1.100";
|
||||
var service = new LogsController(Mapper.Instance, mctx, _tele);
|
||||
@@ -119,13 +183,13 @@ namespace LanBackup.WebApp.Tests.IntegrationTests
|
||||
|
||||
|
||||
|
||||
private class GetSqliteMemoryContext : IDisposable
|
||||
private class SqliteMemoryContext : IDisposable
|
||||
{
|
||||
private SqliteConnection connection;
|
||||
private BackupsContext _context;
|
||||
private DbContextOptions<BackupsContext> options;
|
||||
|
||||
public GetSqliteMemoryContext()
|
||||
public SqliteMemoryContext()
|
||||
{
|
||||
connection = new SqliteConnection("DataSource=:memory:");
|
||||
connection.Open();
|
||||
@@ -169,5 +233,8 @@ namespace LanBackup.WebApp.Tests.IntegrationTests
|
||||
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -21,7 +21,8 @@
|
||||
"FluentAssertions": "4.18.0",
|
||||
"LanBackup.WebApp": "1.0.0-*",
|
||||
"Moq": "4.6.38-alpha",
|
||||
"System.Diagnostics.TraceSource": "4.0.0"
|
||||
"System.Diagnostics.TraceSource": "4.0.0",
|
||||
"Microsoft.EntityFrameworkCore.InMemory": "1.1.0"
|
||||
},
|
||||
"testRunner": "xunit",
|
||||
"frameworks": {
|
||||
|
||||
Reference in New Issue
Block a user