Тесты контрактов хранилищ

This commit is contained in:
2025-03-09 16:04:50 +04:00
parent 9ed1d7b442
commit 72547eeb41
10 changed files with 350 additions and 430 deletions

View File

@@ -5,7 +5,7 @@ using CatHasPawsContratcs.Infrastructure;
namespace CatHasPawsContratcs.DataModels;
public class PostDataModel(string postId, string postName, PostType postType, double salary, bool isActual, DateTime changeDate) : IValidation
public class PostDataModel(string postId, string postName, PostType postType, double salary) : IValidation
{
public string Id { get; private set; } = postId;
@@ -15,10 +15,6 @@ public class PostDataModel(string postId, string postName, PostType postType, do
public double Salary { get; private set; } = salary;
public bool IsActual { get; private set; } = isActual;
public DateTime ChangeDate { get; private set; } = changeDate;
public void Validate()
{
if (Id.IsEmpty())

View File

@@ -5,25 +5,61 @@ using CatHasPawsContratcs.Infrastructure;
namespace CatHasPawsContratcs.DataModels;
public class SaleDataModel(string id, string workerId, string? buyerId, double sum, DiscountType discountType, double discount, bool isCancel, List<SaleProductDataModel> saleProducts) : IValidation
public class SaleDataModel : IValidation
{
public string Id { get; private set; } = id;
public string Id { get; private set; }
public string WorkerId { get; private set; } = workerId;
public string WorkerId { get; private set; }
public string? BuyerId { get; private set; } = buyerId;
public string? BuyerId { get; private set; }
public DateTime SaleDate { get; private set; } = DateTime.UtcNow;
public double Sum { get; private set; } = sum;
public double Sum { get; private set; }
public DiscountType DiscountType { get; private set; } = discountType;
public DiscountType DiscountType { get; private set; }
public double Discount { get; private set; } = discount;
public double Discount { get; private set; }
public bool IsCancel { get; private set; } = isCancel;
public bool IsCancel { get; private set; }
public List<SaleProductDataModel> Products { get; private set; } = saleProducts;
public List<SaleProductDataModel>? Products { get; private set; }
public SaleDataModel(string id, string workerId, string? buyerId, DiscountType discountType, bool isCancel, List<SaleProductDataModel> saleProducts)
{
Id = id;
WorkerId = workerId;
BuyerId = buyerId;
DiscountType = discountType;
IsCancel = isCancel;
Products = saleProducts;
var percent = 0.0;
foreach (DiscountType elem in Enum.GetValues<DiscountType>())
{
if ((elem & discountType) != 0)
{
switch (elem)
{
case DiscountType.None:
break;
case DiscountType.OnSale:
percent += 0.1;
break;
case DiscountType.RegularCustomer:
percent += 0.5;
break;
case DiscountType.Certificate:
percent += 0.3;
break;
}
}
}
Sum = Products?.Sum(x => x.Price * x.Count) ?? 0;
Discount = Sum * percent;
}
public SaleDataModel(string id, string workerId, string? buyerId, int discountType, List<SaleProductDataModel> products)
: this(id, workerId, buyerId, (DiscountType)discountType, false, products) { }
public void Validate()
{

View File

@@ -4,7 +4,7 @@ using CatHasPawsContratcs.Infrastructure;
namespace CatHasPawsContratcs.DataModels;
public class SaleProductDataModel(string saleId, string productId, int count) : IValidation
public class SaleProductDataModel(string saleId, string productId, int count, double price) : IValidation
{
public string SaleId { get; private set; } = saleId;
@@ -12,6 +12,8 @@ public class SaleProductDataModel(string saleId, string productId, int count) :
public int Count { get; private set; } = count;
public double Price { get; private set; } = price;
public void Validate()
{
if (SaleId.IsEmpty())

View File

@@ -15,6 +15,46 @@ internal static class CatHasPawsDbContextExtensions
return buyer;
}
public static Manufacturer InsertManufacturerToDatabaseAndReturn(this CatHasPawsDbContext dbContext, string? id = null, string manufacturerName = "test", string prevManufacturerName = "prev", string prevPrevManufacturerName = "prevPrev")
{
var manufacturer = new Manufacturer() { Id = id ?? Guid.NewGuid().ToString(), ManufacturerName = manufacturerName, PrevManufacturerName = prevManufacturerName, PrevPrevManufacturerName = prevPrevManufacturerName };
dbContext.Manufacturers.Add(manufacturer);
dbContext.SaveChanges();
return manufacturer;
}
public static Post InsertPostToDatabaseAndReturn(this CatHasPawsDbContext dbContext, string? id = null, string postName = "test", PostType postType = PostType.Assistant, double salary = 10, bool isActual = true, DateTime? changeDate = null)
{
var post = new Post() { Id = Guid.NewGuid().ToString(), PostId = id ?? Guid.NewGuid().ToString(), PostName = postName, PostType = postType, Salary = salary, IsActual = isActual, ChangeDate = changeDate ?? DateTime.UtcNow };
dbContext.Posts.Add(post);
dbContext.SaveChanges();
return post;
}
public static Product InsertProductToDatabaseAndReturn(this CatHasPawsDbContext dbContext, string manufacturerId, string? id = null, string productName = "test", ProductType productType = ProductType.Feed, double price = 1, bool isDeleted = false)
{
var product = new Product() { Id = id ?? Guid.NewGuid().ToString(), ManufacturerId = manufacturerId, ProductName = productName, ProductType = productType, Price = price, IsDeleted = isDeleted };
dbContext.Products.Add(product);
dbContext.SaveChanges();
return product;
}
public static ProductHistory InsertProductHistoryToDatabaseAndReturn(this CatHasPawsDbContext dbContext, string productId, double price = 10, DateTime? changeDate = null)
{
var productHistory = new ProductHistory() { Id = Guid.NewGuid().ToString(), ProductId = productId, OldPrice = price, ChangeDate = changeDate ?? DateTime.UtcNow };
dbContext.ProductHistories.Add(productHistory);
dbContext.SaveChanges();
return productHistory;
}
public static Salary InsertSalaryToDatabaseAndReturn(this CatHasPawsDbContext dbContext, string workerId, double workerSalary = 1, DateTime? salaryDate = null)
{
var salary = new Salary() { WorkerId = workerId, WorkerSalary = workerSalary, SalaryDate = salaryDate ?? DateTime.UtcNow };
dbContext.Salaries.Add(salary);
dbContext.SaveChanges();
return salary;
}
public static Sale InsertSaleToDatabaseAndReturn(this CatHasPawsDbContext dbContext, string workerId, string? buyerId = null, DateTime? saleDate = null, double sum = 1, DiscountType discountType = DiscountType.OnSale, double discount = 0, bool isCancel = false, List<(string, int, double)>? products = null)
{
var sale = new Sale() { WorkerId = workerId, BuyerId = buyerId, SaleDate = saleDate ?? DateTime.UtcNow, Sum = sum, DiscountType = discountType, Discount = discount, IsCancel = isCancel, SaleProducts = [] };
@@ -40,10 +80,32 @@ internal static class CatHasPawsDbContextExtensions
public static Buyer? GetBuyerFromDatabase(this CatHasPawsDbContext dbContext, string id) => dbContext.Buyers.FirstOrDefault(x => x.Id == id);
public static Manufacturer? GetManufacturerFromDatabase(this CatHasPawsDbContext dbContext, string id) => dbContext.Manufacturers.FirstOrDefault(x => x.Id == id);
public static Post? GetPostFromDatabaseByPostId(this CatHasPawsDbContext dbContext, string id) => dbContext.Posts.FirstOrDefault(x => x.PostId == id && x.IsActual);
public static Post[] GetPostsFromDatabaseByPostId(this CatHasPawsDbContext dbContext, string id) => [.. dbContext.Posts.Where(x => x.PostId == id).OrderByDescending(x => x.ChangeDate)];
public static Product? GetProductFromDatabaseById(this CatHasPawsDbContext dbContext, string id) => dbContext.Products.FirstOrDefault(x => x.Id == id);
public static Salary[] GetSalariesFromDatabaseByWorkerId(this CatHasPawsDbContext dbContext, string id) => [.. dbContext.Salaries.Where(x => x.WorkerId == id)];
public static Sale? GetSaleFromDatabaseById(this CatHasPawsDbContext dbContext, string id) => dbContext.Sales.Include(x => x.SaleProducts).FirstOrDefault(x => x.Id == id);
public static Sale[] GetSalesByBuyerId(this CatHasPawsDbContext dbContext, string? buyerId) => [.. dbContext.Sales.Include(x => x.SaleProducts).Where(x => x.BuyerId == buyerId)];
public static Worker? GetWorkerFromDatabaseById(this CatHasPawsDbContext dbContext, string id) => dbContext.Workers.FirstOrDefault(x => x.Id == id);
public static void RemoveBuyersFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Buyers\" CASCADE;");
public static void RemoveManufacturersFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Manufacturers\" CASCADE;");
public static void RemovePostsFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Posts\" CASCADE;");
public static void RemoveProductsFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Products\" CASCADE;");
public static void RemoveSalariesFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Salaries\" CASCADE;");
public static void RemoveSalesFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Sales\" CASCADE;");
public static void RemoveWorkersFromDatabase(this CatHasPawsDbContext dbContext) => dbContext.ExecuteSqlRaw("TRUNCATE \"Workers\" CASCADE;");

View File

@@ -1,8 +1,9 @@
using CatHasPawsContratcs.DataModels;
using CatHasPawsContratcs.Exceptions;
using CatHasPawsDatabase;
using CatHasPawsDatabase.Implementations;
using CatHasPawsDatabase.Models;
using Microsoft.EntityFrameworkCore;
using CatHasPawsTests.Infrastructure;
namespace CatHasPawsTests.StoragesContracts;
@@ -20,16 +21,16 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
[TearDown]
public void TearDown()
{
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Products\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Manufacturers\" CASCADE;");
CatHasPawsDbContext.RemoveProductsFromDatabase();
CatHasPawsDbContext.RemoveManufacturersFromDatabase();
}
[Test]
public void Try_GetList_WhenHaveRecords_Test()
{
var manufacturer = InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 1");
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 2");
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 3");
var manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: "name 1");
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: "name 2");
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: "name 3");
var list = _manufacturerStorageContract.GetList();
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
@@ -47,35 +48,35 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementById_WhenHaveRecord_Test()
{
var manufacturer = InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
var manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
AssertElement(_manufacturerStorageContract.GetElementById(manufacturer.Id), manufacturer);
}
[Test]
public void Try_GetElementById_WhenNoRecord_Test()
{
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
Assert.That(() => _manufacturerStorageContract.GetElementById(Guid.NewGuid().ToString()), Is.Null);
}
[Test]
public void Try_GetElementByName_WhenHaveRecord_Test()
{
var manufacturer = InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
var manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
AssertElement(_manufacturerStorageContract.GetElementByName(manufacturer.ManufacturerName), manufacturer);
}
[Test]
public void Try_GetElementByName_WhenNoRecord_Test()
{
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
Assert.That(() => _manufacturerStorageContract.GetElementByName("name"), Is.Null);
}
[Test]
public void Try_GetElementByOldName_WhenHaveRecord_Test()
{
var manufacturer = InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
var manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
AssertElement(_manufacturerStorageContract.GetElementByOldName(manufacturer.PrevManufacturerName!), manufacturer);
AssertElement(_manufacturerStorageContract.GetElementByOldName(manufacturer.PrevPrevManufacturerName!), manufacturer);
}
@@ -83,7 +84,7 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementByOldName_WhenNoRecord_Test()
{
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
Assert.That(() => _manufacturerStorageContract.GetElementByOldName("name"), Is.Null);
}
@@ -92,14 +93,14 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
{
var manufacturer = CreateModel(Guid.NewGuid().ToString());
_manufacturerStorageContract.AddElement(manufacturer);
AssertElement(GetManufacturerFromDatabase(manufacturer.Id), manufacturer);
AssertElement(CatHasPawsDbContext.GetManufacturerFromDatabase(manufacturer.Id), manufacturer);
}
[Test]
public void Try_AddElement_WhenHaveRecordWithSameId_Test()
{
var manufacturer = CreateModel(Guid.NewGuid().ToString(), "name unique");
InsertManufacturerToDatabaseAndReturn(manufacturer.Id);
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturer.Id);
Assert.That(() => _manufacturerStorageContract.AddElement(manufacturer), Throws.TypeOf<ElementExistsException>());
}
@@ -107,7 +108,7 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
public void Try_AddElement_WhenHaveRecordWithSameManufacturerName_Test()
{
var manufacturer = CreateModel(Guid.NewGuid().ToString(), "name unique");
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString(), manufacturerName: manufacturer.ManufacturerName);
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: manufacturer.ManufacturerName);
Assert.That(() => _manufacturerStorageContract.AddElement(manufacturer), Throws.TypeOf<ElementExistsException>());
}
@@ -115,18 +116,18 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_Test()
{
var manufacturer = CreateModel(Guid.NewGuid().ToString(), "name new", "test", "prev");
InsertManufacturerToDatabaseAndReturn(manufacturer.Id, manufacturerName: manufacturer.PrevManufacturerName!, prevManufacturerName: manufacturer.PrevPrevManufacturerName!);
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturer.Id, manufacturerName: manufacturer.PrevManufacturerName!, prevManufacturerName: manufacturer.PrevPrevManufacturerName!);
_manufacturerStorageContract.UpdElement(CreateModel(manufacturer.Id, "name new", "some name", "some name"));
AssertElement(GetManufacturerFromDatabase(manufacturer.Id), manufacturer);
AssertElement(CatHasPawsDbContext.GetManufacturerFromDatabase(manufacturer.Id), manufacturer);
}
[Test]
public void Try_UpdElement_WhenNoChangeManufacturerName_Test()
{
var manufacturer = CreateModel(Guid.NewGuid().ToString(), "name new", "test", "prev");
InsertManufacturerToDatabaseAndReturn(manufacturer.Id, manufacturerName: manufacturer.ManufacturerName!, prevManufacturerName: manufacturer.PrevManufacturerName!, prevPrevManufacturerName: manufacturer.PrevPrevManufacturerName!);
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturer.Id, manufacturerName: manufacturer.ManufacturerName!, prevManufacturerName: manufacturer.PrevManufacturerName!, prevPrevManufacturerName: manufacturer.PrevPrevManufacturerName!);
_manufacturerStorageContract.UpdElement(manufacturer);
AssertElement(GetManufacturerFromDatabase(manufacturer.Id), manufacturer);
AssertElement(CatHasPawsDbContext.GetManufacturerFromDatabase(manufacturer.Id), manufacturer);
}
[Test]
@@ -139,26 +140,24 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenHaveRecordWithSameManufacturerName_Test()
{
var manufacturer = CreateModel(Guid.NewGuid().ToString(), "name unique");
InsertManufacturerToDatabaseAndReturn(manufacturer.Id, manufacturerName: "some name");
InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString(), manufacturerName: manufacturer.ManufacturerName);
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturer.Id, manufacturerName: "some name");
CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: manufacturer.ManufacturerName);
Assert.That(() => _manufacturerStorageContract.UpdElement(manufacturer), Throws.TypeOf<ElementExistsException>());
}
[Test]
public void Try_DelElement_WhenNoProducts_Test()
{
var manufacturer = InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
var manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
_manufacturerStorageContract.DelElement(manufacturer.Id);
var element = GetManufacturerFromDatabase(manufacturer.Id);
Assert.That(element, Is.Null);
Assert.That(CatHasPawsDbContext.GetManufacturerFromDatabase(manufacturer.Id), Is.Null);
}
[Test]
public void Try_DelElement_WhenHaveProducts_Test()
{
var manufacturer = InsertManufacturerToDatabaseAndReturn(Guid.NewGuid().ToString());
CatHasPawsDbContext.Products.Add(new Product() { Id = Guid.NewGuid().ToString(), ProductName = "name", ManufacturerId = manufacturer.Id, Price = 10, IsDeleted = false });
CatHasPawsDbContext.SaveChanges();
var manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(manufacturer.Id);
Assert.That(() => _manufacturerStorageContract.DelElement(manufacturer.Id), Throws.TypeOf<StorageException>());
}
@@ -168,14 +167,6 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
Assert.That(() => _manufacturerStorageContract.DelElement(Guid.NewGuid().ToString()), Throws.TypeOf<ElementNotFoundException>());
}
private Manufacturer InsertManufacturerToDatabaseAndReturn(string id, string manufacturerName = "test", string prevManufacturerName = "prev", string prevPrevManufacturerName = "prevPrev")
{
var manufacturer = new Manufacturer() { Id = id, ManufacturerName = manufacturerName, PrevManufacturerName = prevManufacturerName, PrevPrevManufacturerName = prevPrevManufacturerName };
CatHasPawsDbContext.Manufacturers.Add(manufacturer);
CatHasPawsDbContext.SaveChanges();
return manufacturer;
}
private static void AssertElement(ManufacturerDataModel? actual, Manufacturer expected)
{
Assert.That(actual, Is.Not.Null);
@@ -191,8 +182,6 @@ internal class ManufacturerStorageContractTests : BaseStorageContractTest
private static ManufacturerDataModel CreateModel(string id, string manufacturerName = "test", string prevManufacturerName = "prev", string prevPrevManufacturerName = "prevPrev")
=> new(id, manufacturerName, prevManufacturerName, prevPrevManufacturerName);
private Manufacturer? GetManufacturerFromDatabase(string id) => CatHasPawsDbContext.Manufacturers.FirstOrDefault(x => x.Id == id);
private static void AssertElement(Manufacturer? actual, ManufacturerDataModel expected)
{
Assert.That(actual, Is.Not.Null);

View File

@@ -3,7 +3,7 @@ using CatHasPawsContratcs.Enums;
using CatHasPawsContratcs.Exceptions;
using CatHasPawsDatabase.Implementations;
using CatHasPawsDatabase.Models;
using Microsoft.EntityFrameworkCore;
using CatHasPawsTests.Infrastructure;
namespace CatHasPawsTests.StoragesContracts;
@@ -21,15 +21,15 @@ internal class PostStorageContractTests : BaseStorageContractTest
[TearDown]
public void TearDown()
{
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Posts\" CASCADE;");
CatHasPawsDbContext.RemovePostsFromDatabase();
}
[Test]
public void Try_GetList_WhenHaveRecords_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 1");
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 2");
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 3");
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: "name 1");
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: "name 2");
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: "name 3");
var list = _postStorageContract.GetList();
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
@@ -44,44 +44,13 @@ internal class PostStorageContractTests : BaseStorageContractTest
Assert.That(list, Is.Empty);
}
[Test]
public void Try_GetList_OnlyActual_Test()
{
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 1", isActual: true);
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 2", isActual: true);
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 3", isActual: false);
var list = _postStorageContract.GetList(onlyActual: true);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
{
Assert.That(list, Has.Count.EqualTo(2));
Assert.That(!list.Any(x => !x.IsActual));
});
}
[Test]
public void Try_GetList_IncludeNoActual_Test()
{
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 1", isActual: true);
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 2", isActual: true);
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 3", isActual: false);
var list = _postStorageContract.GetList(onlyActual: false);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
{
Assert.That(list, Has.Count.EqualTo(3));
Assert.That(list.Count(x => x.IsActual), Is.EqualTo(2));
Assert.That(list.Count(x => !x.IsActual), Is.EqualTo(1));
});
}
[Test]
public void Try_GetPostWithHistory_WhenHaveRecords_Test()
{
var postId = Guid.NewGuid().ToString();
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 1", isActual: true);
InsertPostToDatabaseAndReturn(postId, "name 2", isActual: true);
InsertPostToDatabaseAndReturn(postId, "name 2", isActual: false);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: "name 1", isActual: true);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postId, "name 2", isActual: true);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postId, "name 2", isActual: false);
var list = _postStorageContract.GetPostWithHistory(postId);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -91,9 +60,9 @@ internal class PostStorageContractTests : BaseStorageContractTest
public void Try_GetPostWithHistory_WhenNoRecords_Test()
{
var postId = Guid.NewGuid().ToString();
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), "name 1", isActual: true);
InsertPostToDatabaseAndReturn(postId, "name 2", isActual: true);
InsertPostToDatabaseAndReturn(postId, "name 2", isActual: false);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: "name 1", isActual: true);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postId, "name 2", isActual: true);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postId, "name 2", isActual: false);
var list = _postStorageContract.GetPostWithHistory(Guid.NewGuid().ToString());
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(0));
@@ -102,81 +71,73 @@ internal class PostStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementById_WhenHaveRecord_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString());
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn();
AssertElement(_postStorageContract.GetElementById(post.PostId), post);
}
[Test]
public void Try_GetElementById_WhenNoRecord_Test()
{
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString());
CatHasPawsDbContext.InsertPostToDatabaseAndReturn();
Assert.That(() => _postStorageContract.GetElementById(Guid.NewGuid().ToString()), Is.Null);
}
[Test]
public void Try_GetElementById_WhenRecordHasDeleted_Test()
public void Try_GetElementById_WhenRecordWasDeleted_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), isActual: false);
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(isActual: false);
Assert.That(() => _postStorageContract.GetElementById(post.PostId), Is.Null);
}
[Test]
public void Try_GetElementById_WhenTrySearchById_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString());
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn();
Assert.That(() => _postStorageContract.GetElementById(post.Id), Is.Null);
}
[Test]
public void Try_GetElementByName_WhenHaveRecord_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString());
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn();
AssertElement(_postStorageContract.GetElementByName(post.PostName), post);
}
[Test]
public void Try_GetElementByName_WhenNoRecord_Test()
{
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString());
CatHasPawsDbContext.InsertPostToDatabaseAndReturn();
Assert.That(() => _postStorageContract.GetElementByName("name"), Is.Null);
}
[Test]
public void Try_GetElementByName_WhenRecordHasDeleted_Test()
public void Try_GetElementByName_WhenRecordWasDeleted_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), isActual: false);
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(isActual: false);
Assert.That(() => _postStorageContract.GetElementById(post.PostName), Is.Null);
}
[Test]
public void Try_AddElement_Test()
{
var post = CreateModel(Guid.NewGuid().ToString(), isActual: true);
var post = CreateModel(Guid.NewGuid().ToString());
_postStorageContract.AddElement(post);
AssertElement(GetPostFromDatabaseByPostId(post.Id), post);
}
[Test]
public void Try_AddElement_WhenActualIsFalse_Test()
{
var post = CreateModel(Guid.NewGuid().ToString(), isActual: false);
Assert.That(() => _postStorageContract.AddElement(post), Throws.Nothing);
AssertElement(GetPostFromDatabaseByPostId(post.Id), CreateModel(post.Id, isActual: true));
AssertElement(CatHasPawsDbContext.GetPostFromDatabaseByPostId(post.Id), post);
}
[Test]
public void Try_AddElement_WhenHaveRecordWithSameName_Test()
{
var post = CreateModel(Guid.NewGuid().ToString(), "name unique", isActual: true);
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), postName: post.PostName, isActual: true);
var post = CreateModel(Guid.NewGuid().ToString(), "name unique");
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: post.PostName, isActual: true);
Assert.That(() => _postStorageContract.AddElement(post), Throws.TypeOf<ElementExistsException>());
}
[Test]
public void Try_AddElement_WhenHaveRecordWithSamePostIdAndActualIsTrue_Test()
public void Try_AddElement_WhenHaveRecordWithSamePostId_Test()
{
var post = CreateModel(Guid.NewGuid().ToString(), isActual: true);
InsertPostToDatabaseAndReturn(post.Id, isActual: true);
var post = CreateModel(Guid.NewGuid().ToString());
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(post.Id, isActual: true);
Assert.That(() => _postStorageContract.AddElement(post), Throws.TypeOf<ElementExistsException>());
}
@@ -184,21 +145,13 @@ internal class PostStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_Test()
{
var post = CreateModel(Guid.NewGuid().ToString());
InsertPostToDatabaseAndReturn(post.Id, isActual: true);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(post.Id, isActual: true);
_postStorageContract.UpdElement(post);
var posts = CatHasPawsDbContext.Posts.Where(x => x.PostId == post.Id).OrderByDescending(x => x.ChangeDate);
Assert.That(posts.Count(), Is.EqualTo(2));
AssertElement(posts.First(), CreateModel(post.Id, isActual: true));
AssertElement(posts.Last(), CreateModel(post.Id, isActual: false));
}
[Test]
public void Try_UpdElement_WhenActualIsFalse_Test()
{
var post = CreateModel(Guid.NewGuid().ToString(), isActual: false);
InsertPostToDatabaseAndReturn(post.Id, isActual: true);
_postStorageContract.UpdElement(post);
AssertElement(GetPostFromDatabaseByPostId(post.Id), CreateModel(post.Id, isActual: true));
var posts = CatHasPawsDbContext.GetPostsFromDatabaseByPostId(post.Id);
Assert.That(posts, Is.Not.Null);
Assert.That(posts, Has.Length.EqualTo(2));
AssertElement(posts[0], CreateModel(post.Id));
AssertElement(posts[^1], CreateModel(post.Id));
}
[Test]
@@ -211,8 +164,8 @@ internal class PostStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenHaveRecordWithSameName_Test()
{
var post = CreateModel(Guid.NewGuid().ToString(), "New Name");
InsertPostToDatabaseAndReturn(post.Id, postName: "name");
InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), postName: post.PostName);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(post.Id, postName: "name");
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(postName: post.PostName);
Assert.That(() => _postStorageContract.UpdElement(post), Throws.TypeOf<ElementExistsException>());
}
@@ -220,21 +173,16 @@ internal class PostStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenRecordWasDeleted_Test()
{
var post = CreateModel(Guid.NewGuid().ToString());
InsertPostToDatabaseAndReturn(post.Id, isActual: false);
CatHasPawsDbContext.InsertPostToDatabaseAndReturn(post.Id, isActual: false);
Assert.That(() => _postStorageContract.UpdElement(post), Throws.TypeOf<ElementDeletedException>());
}
[Test]
public void Try_DelElement_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), isActual: true);
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(isActual: true);
_postStorageContract.DelElement(post.PostId);
var element = GetPostFromDatabaseByPostId(post.PostId);
Assert.Multiple(() =>
{
Assert.That(element, Is.Not.Null);
Assert.That(!element!.IsActual);
});
Assert.That(CatHasPawsDbContext.GetPostFromDatabaseByPostId(post.PostId), Is.Null);
}
[Test]
@@ -246,16 +194,16 @@ internal class PostStorageContractTests : BaseStorageContractTest
[Test]
public void Try_DelElement_WhenRecordWasDeleted_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), isActual: false);
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(isActual: false);
Assert.That(() => _postStorageContract.DelElement(post.PostId), Throws.TypeOf<ElementDeletedException>());
}
[Test]
public void Try_ResElement_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), isActual: false);
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(isActual: false);
_postStorageContract.ResElement(post.PostId);
var element = GetPostFromDatabaseByPostId(post.PostId);
var element = CatHasPawsDbContext.GetPostFromDatabaseByPostId(post.PostId);
Assert.Multiple(() =>
{
Assert.That(element, Is.Not.Null);
@@ -272,18 +220,10 @@ internal class PostStorageContractTests : BaseStorageContractTest
[Test]
public void Try_ResElement_WhenRecordNotWasDeleted_Test()
{
var post = InsertPostToDatabaseAndReturn(Guid.NewGuid().ToString(), isActual: true);
var post = CatHasPawsDbContext.InsertPostToDatabaseAndReturn(isActual: true);
Assert.That(() => _postStorageContract.ResElement(post.PostId), Throws.Nothing);
}
private Post InsertPostToDatabaseAndReturn(string id, string postName = "test", PostType postType = PostType.Assistant, double salary = 10, bool isActual = true, DateTime? changeDate = null)
{
var post = new Post() { Id = Guid.NewGuid().ToString(), PostId = id, PostName = postName, PostType = postType, Salary = salary, IsActual = isActual, ChangeDate = changeDate ?? DateTime.UtcNow };
CatHasPawsDbContext.Posts.Add(post);
CatHasPawsDbContext.SaveChanges();
return post;
}
private static void AssertElement(PostDataModel? actual, Post expected)
{
Assert.That(actual, Is.Not.Null);
@@ -293,14 +233,11 @@ internal class PostStorageContractTests : BaseStorageContractTest
Assert.That(actual.PostName, Is.EqualTo(expected.PostName));
Assert.That(actual.PostType, Is.EqualTo(expected.PostType));
Assert.That(actual.Salary, Is.EqualTo(expected.Salary));
Assert.That(actual.IsActual, Is.EqualTo(expected.IsActual));
});
}
private static PostDataModel CreateModel(string postId, string postName = "test", PostType postType = PostType.Assistant, double salary = 10, bool isActual = false, DateTime? changeDate = null)
=> new(postId, postName, postType, salary, isActual, changeDate ?? DateTime.UtcNow);
private Post? GetPostFromDatabaseByPostId(string id) => CatHasPawsDbContext.Posts.Where(x => x.PostId == id).OrderByDescending(x => x.ChangeDate).FirstOrDefault();
private static PostDataModel CreateModel(string postId, string postName = "test", PostType postType = PostType.Assistant, double salary = 10)
=> new(postId, postName, postType, salary);
private static void AssertElement(Post? actual, PostDataModel expected)
{
@@ -311,7 +248,6 @@ internal class PostStorageContractTests : BaseStorageContractTest
Assert.That(actual.PostName, Is.EqualTo(expected.PostName));
Assert.That(actual.PostType, Is.EqualTo(expected.PostType));
Assert.That(actual.Salary, Is.EqualTo(expected.Salary));
Assert.That(actual.IsActual, Is.EqualTo(expected.IsActual));
});
}
}

View File

@@ -3,7 +3,7 @@ using CatHasPawsContratcs.Enums;
using CatHasPawsContratcs.Exceptions;
using CatHasPawsDatabase.Implementations;
using CatHasPawsDatabase.Models;
using Microsoft.EntityFrameworkCore;
using CatHasPawsTests.Infrastructure;
namespace CatHasPawsTests.StoragesContracts;
@@ -17,22 +17,22 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void SetUp()
{
_productStorageContract = new ProductStorageContract(CatHasPawsDbContext);
_manufacturer = InsertManufacturerToDatabaseAndReturn();
_manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
}
[TearDown]
public void TearDown()
{
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Products\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Manufacturers\" CASCADE;");
CatHasPawsDbContext.RemoveProductsFromDatabase();
CatHasPawsDbContext.RemoveManufacturersFromDatabase();
}
[Test]
public void Try_GetList_WhenHaveRecords_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1");
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 2");
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 3");
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 1");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 2");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 3");
var list = _productStorageContract.GetList();
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
@@ -50,9 +50,9 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_OnlyActual_Test()
{
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1", isDeleted: true);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 2", isDeleted: false);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 3", isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 1", isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 2", isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 3", isDeleted: false);
var list = _productStorageContract.GetList(onlyActive: true);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -65,9 +65,9 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_IncludeNoActual_Test()
{
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1", isDeleted: true);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 2", isDeleted: true);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 3", isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 1", isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 2", isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 3", isDeleted: false);
var list = _productStorageContract.GetList(onlyActive: false);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -81,10 +81,10 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByManufacturer_Test()
{
var manufacruer = InsertManufacturerToDatabaseAndReturn("name 2");
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1", isDeleted: true);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 2", isDeleted: false);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), manufacruer.Id, "name 3", isDeleted: false);
var manufacruer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: "name 2");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 1", isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 2", isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(manufacruer.Id, productName: "name 3", isDeleted: false);
var list = _productStorageContract.GetList(manufacturerId: _manufacturer.Id, onlyActive: false);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -97,10 +97,10 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByManufacturerOnlyActual_Test()
{
var manufacruer = InsertManufacturerToDatabaseAndReturn("name 2");
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1", isDeleted: true);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 2", isDeleted: false);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), manufacruer.Id, "name 3", isDeleted: false);
var manufacruer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn(manufacturerName: "name 2");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 1", isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "name 2", isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(manufacruer.Id, productName: "name 3", isDeleted: false);
var list = _productStorageContract.GetList(manufacturerId: _manufacturer.Id, onlyActive: true);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -113,10 +113,10 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetHistoryByProductId_WhenHaveRecords_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1");
InsertProductHistoryToDatabaseAndReturn(product.Id, 20, DateTime.UtcNow.AddDays(-1));
InsertProductHistoryToDatabaseAndReturn(product.Id, 30, DateTime.UtcNow.AddMinutes(-10));
InsertProductHistoryToDatabaseAndReturn(product.Id, 40, DateTime.UtcNow.AddDays(1));
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
CatHasPawsDbContext.InsertProductHistoryToDatabaseAndReturn(product.Id, 20, DateTime.UtcNow.AddDays(-1));
CatHasPawsDbContext.InsertProductHistoryToDatabaseAndReturn(product.Id, 30, DateTime.UtcNow.AddMinutes(-10));
CatHasPawsDbContext.InsertProductHistoryToDatabaseAndReturn(product.Id, 40, DateTime.UtcNow.AddDays(1));
var list = _productStorageContract.GetHistoryByProductId(product.Id);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
@@ -125,10 +125,10 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetHistoryByProductId_WhenNoRecords_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, "name 1");
InsertProductHistoryToDatabaseAndReturn(product.Id, 20, DateTime.UtcNow.AddDays(-1));
InsertProductHistoryToDatabaseAndReturn(product.Id, 30, DateTime.UtcNow.AddMinutes(-10));
InsertProductHistoryToDatabaseAndReturn(product.Id, 40, DateTime.UtcNow.AddDays(1));
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
CatHasPawsDbContext.InsertProductHistoryToDatabaseAndReturn(product.Id, 20, DateTime.UtcNow.AddDays(-1));
CatHasPawsDbContext.InsertProductHistoryToDatabaseAndReturn(product.Id, 30, DateTime.UtcNow.AddMinutes(-10));
CatHasPawsDbContext.InsertProductHistoryToDatabaseAndReturn(product.Id, 40, DateTime.UtcNow.AddDays(1));
var list = _productStorageContract.GetHistoryByProductId(Guid.NewGuid().ToString());
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(0));
@@ -137,42 +137,42 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementById_WhenHaveRecord_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
AssertElement(_productStorageContract.GetElementById(product.Id), product);
}
[Test]
public void Try_GetElementById_WhenNoRecord_Test()
{
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
Assert.That(() => _productStorageContract.GetElementById(Guid.NewGuid().ToString()), Is.Null);
}
[Test]
public void Try_GetElementById_WhenRecordHasDeleted_Test()
public void Try_GetElementById_WhenRecordWasDeleted_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: true);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, isDeleted: true);
Assert.That(() => _productStorageContract.GetElementById(product.Id), Is.Null);
}
[Test]
public void Try_GetElementByName_WhenHaveRecord_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
AssertElement(_productStorageContract.GetElementByName(product.ProductName), product);
}
[Test]
public void Try_GetElementByName_WhenNoRecord_Test()
{
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
Assert.That(() => _productStorageContract.GetElementByName("name"), Is.Null);
}
[Test]
public void Try_GetElementByName_WhenRecordHasDeleted_Test()
public void Try_GetElementByName_WhenRecordWasDeleted_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: true);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, isDeleted: true);
Assert.That(() => _productStorageContract.GetElementById(product.ProductName), Is.Null);
}
@@ -181,7 +181,7 @@ internal class ProductStorageContractTests : BaseStorageContractTest
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: false);
_productStorageContract.AddElement(product);
AssertElement(GetProductFromDatabaseById(product.Id), product);
AssertElement(CatHasPawsDbContext.GetProductFromDatabaseById(product.Id), product);
}
[Test]
@@ -189,14 +189,14 @@ internal class ProductStorageContractTests : BaseStorageContractTest
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: true);
Assert.That(() => _productStorageContract.AddElement(product), Throws.Nothing);
AssertElement(GetProductFromDatabaseById(product.Id), CreateModel(product.Id, _manufacturer.Id, isDeleted: false));
AssertElement(CatHasPawsDbContext.GetProductFromDatabaseById(product.Id), CreateModel(product.Id, _manufacturer.Id, isDeleted: false));
}
[Test]
public void Try_AddElement_WhenHaveRecordWithSameId_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id);
InsertProductToDatabaseAndReturn(product.Id, _manufacturer.Id, productName: "name unique");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, product.Id, productName: "name unique");
Assert.That(() => _productStorageContract.AddElement(product), Throws.TypeOf<ElementExistsException>());
}
@@ -204,7 +204,7 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void Try_AddElement_WhenHaveRecordWithSameName_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, "name unique", isDeleted: false);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, productName: product.ProductName, isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: product.ProductName, isDeleted: false);
Assert.That(() => _productStorageContract.AddElement(product), Throws.TypeOf<ElementExistsException>());
}
@@ -212,7 +212,7 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void Try_AddElement_WhenHaveRecordWithSameNameButOneWasDeleted_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, "name unique", isDeleted: false);
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, productName: product.ProductName, isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: product.ProductName, isDeleted: true);
Assert.That(() => _productStorageContract.AddElement(product), Throws.Nothing);
}
@@ -220,18 +220,18 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: false);
InsertProductToDatabaseAndReturn(product.Id, _manufacturer.Id, isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, id: product.Id, isDeleted: false);
_productStorageContract.UpdElement(product);
AssertElement(GetProductFromDatabaseById(product.Id), product);
AssertElement(CatHasPawsDbContext.GetProductFromDatabaseById(product.Id), product);
}
[Test]
public void Try_UpdElement_WhenIsDeletedIsTrue_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: true);
InsertProductToDatabaseAndReturn(product.Id, _manufacturer.Id, isDeleted: false);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, product.Id, isDeleted: false);
_productStorageContract.UpdElement(product);
AssertElement(GetProductFromDatabaseById(product.Id), CreateModel(product.Id, _manufacturer.Id, isDeleted: false));
AssertElement(CatHasPawsDbContext.GetProductFromDatabaseById(product.Id), CreateModel(product.Id, _manufacturer.Id, isDeleted: false));
}
[Test]
@@ -244,8 +244,8 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenHaveRecordWithSameName_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, "name unique", isDeleted: false);
InsertProductToDatabaseAndReturn(product.Id, _manufacturer.Id, productName: "name");
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, productName: product.ProductName);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, product.Id, productName: "name");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: product.ProductName);
Assert.That(() => _productStorageContract.UpdElement(product), Throws.TypeOf<ElementExistsException>());
}
@@ -253,8 +253,8 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenHaveRecordWithSameNameButOneWasDeleted_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id, "name unique", isDeleted: false);
InsertProductToDatabaseAndReturn(product.Id, _manufacturer.Id, productName: "name");
InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, productName: product.ProductName, isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, product.Id, productName: "name");
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: product.ProductName, isDeleted: true);
Assert.That(() => _productStorageContract.UpdElement(product), Throws.Nothing);
}
@@ -262,16 +262,16 @@ internal class ProductStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenRecordWasDeleted_Test()
{
var product = CreateModel(Guid.NewGuid().ToString(), _manufacturer.Id);
InsertProductToDatabaseAndReturn(product.Id, _manufacturer.Id, isDeleted: true);
CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, product.Id, isDeleted: true);
Assert.That(() => _productStorageContract.UpdElement(product), Throws.TypeOf<ElementNotFoundException>());
}
[Test]
public void Try_DelElement_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: false);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, isDeleted: false);
_productStorageContract.DelElement(product.Id);
var element = GetProductFromDatabaseById(product.Id);
var element = CatHasPawsDbContext.GetProductFromDatabaseById(product.Id);
Assert.Multiple(() =>
{
Assert.That(element, Is.Not.Null);
@@ -288,34 +288,10 @@ internal class ProductStorageContractTests : BaseStorageContractTest
[Test]
public void Try_DelElement_WhenRecordWasDeleted_Test()
{
var product = InsertProductToDatabaseAndReturn(Guid.NewGuid().ToString(), _manufacturer.Id, isDeleted: true);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, isDeleted: true);
Assert.That(() => _productStorageContract.DelElement(product.Id), Throws.TypeOf<ElementNotFoundException>());
}
private Manufacturer InsertManufacturerToDatabaseAndReturn(string manufacturerName = "name")
{
var manufacrurer = new Manufacturer() { Id = Guid.NewGuid().ToString(), ManufacturerName = manufacturerName };
CatHasPawsDbContext.Manufacturers.Add(manufacrurer);
CatHasPawsDbContext.SaveChanges();
return manufacrurer;
}
private Product InsertProductToDatabaseAndReturn(string id, string manufacturerId, string productName = "test", ProductType productType = ProductType.Feed, double price = 1, bool isDeleted = false)
{
var product = new Product() { Id = id, ManufacturerId = manufacturerId, ProductName = productName, ProductType = productType, Price = price, IsDeleted = isDeleted };
CatHasPawsDbContext.Products.Add(product);
CatHasPawsDbContext.SaveChanges();
return product;
}
private ProductHistory InsertProductHistoryToDatabaseAndReturn(string productId, double price, DateTime changeDate)
{
var productHistory = new ProductHistory() { Id = Guid.NewGuid().ToString(), ProductId = productId, OldPrice = price, ChangeDate = changeDate };
CatHasPawsDbContext.ProductHistories.Add(productHistory);
CatHasPawsDbContext.SaveChanges();
return productHistory;
}
private static void AssertElement(ProductDataModel? actual, Product expected)
{
Assert.That(actual, Is.Not.Null);
@@ -333,8 +309,6 @@ internal class ProductStorageContractTests : BaseStorageContractTest
private static ProductDataModel CreateModel(string id, string manufacturerId, string productName = "test", ProductType productType = ProductType.Feed, double price = 1, bool isDeleted = false)
=> new(id, productName, productType, manufacturerId, price, isDeleted);
private Product? GetProductFromDatabaseById(string id) => CatHasPawsDbContext.Products.FirstOrDefault(x => x.Id == id);
private static void AssertElement(Product? actual, ProductDataModel expected)
{
Assert.That(actual, Is.Not.Null);

View File

@@ -1,7 +1,8 @@
using CatHasPawsContratcs.DataModels;
using CatHasPawsDatabase;
using CatHasPawsDatabase.Implementations;
using CatHasPawsDatabase.Models;
using Microsoft.EntityFrameworkCore;
using CatHasPawsTests.Infrastructure;
namespace CatHasPawsTests.StoragesContracts;
@@ -15,26 +16,26 @@ internal class SalaryStorageContractTests : BaseStorageContractTest
public void SetUp()
{
_salaryStorageContract = new SalaryStorageContract(CatHasPawsDbContext);
_worker = InsertWorkerToDatabaseAndReturn();
_worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn();
}
[TearDown]
public void TearDown()
{
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Salaries\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Workers\" CASCADE;");
CatHasPawsDbContext.RemoveSalariesFromDatabase();
CatHasPawsDbContext.RemoveWorkersFromDatabase();
}
[Test]
public void Try_GetList_WhenHaveRecords_Test()
{
var salary = InsertSalaryToDatabaseAndReturn(_worker.Id, workerSalary: 100);
InsertSalaryToDatabaseAndReturn(_worker.Id);
InsertSalaryToDatabaseAndReturn(_worker.Id);
var salary = CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, workerSalary: 100);
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id);
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id);
var list = _salaryStorageContract.GetList(DateTime.UtcNow.AddDays(-10), DateTime.UtcNow.AddDays(10));
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
AssertElement(list.First(), salary);
AssertElement(list.Single(x => x.Salary == salary.WorkerSalary), salary);
}
[Test]
@@ -48,12 +49,12 @@ internal class SalaryStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_OnlyInDatePeriod_Test()
{
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-5));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(5));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(-5));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(5));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(-5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
var list = _salaryStorageContract.GetList(DateTime.UtcNow.AddDays(-1), DateTime.UtcNow.AddDays(1));
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -65,10 +66,10 @@ internal class SalaryStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByWorker_Test()
{
var worker = InsertWorkerToDatabaseAndReturn("name 2");
InsertSalaryToDatabaseAndReturn(_worker.Id);
InsertSalaryToDatabaseAndReturn(_worker.Id);
InsertSalaryToDatabaseAndReturn(worker.Id);
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "name 2");
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id);
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id);
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(worker.Id);
var list = _salaryStorageContract.GetList(DateTime.UtcNow.AddDays(-1), DateTime.UtcNow.AddDays(1), _worker.Id);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -81,13 +82,13 @@ internal class SalaryStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByWorkerOnlyInDatePeriod_Test()
{
var worker = InsertWorkerToDatabaseAndReturn("name 2");
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(5));
InsertSalaryToDatabaseAndReturn(worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(5));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(-5));
InsertSalaryToDatabaseAndReturn(worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(-5));
InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "name 2");
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(worker.Id, salaryDate: DateTime.UtcNow.AddDays(-1).AddMinutes(5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(-5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(worker.Id, salaryDate: DateTime.UtcNow.AddDays(1).AddMinutes(-5));
CatHasPawsDbContext.InsertSalaryToDatabaseAndReturn(_worker.Id, salaryDate: DateTime.UtcNow.AddDays(-2));
var list = _salaryStorageContract.GetList(DateTime.UtcNow.AddDays(-1), DateTime.UtcNow.AddDays(1), _worker.Id);
Assert.That(list, Is.Not.Null);
Assert.Multiple(() =>
@@ -102,23 +103,7 @@ internal class SalaryStorageContractTests : BaseStorageContractTest
{
var salary = CreateModel(_worker.Id);
_salaryStorageContract.AddElement(salary);
AssertElement(GetSalaryFromDatabaseByWorkerId(_worker.Id), salary);
}
private Worker InsertWorkerToDatabaseAndReturn(string workerFIO = "fio")
{
var worker = new Worker() { Id = Guid.NewGuid().ToString(), PostId = Guid.NewGuid().ToString(), FIO = workerFIO, IsDeleted = false };
CatHasPawsDbContext.Workers.Add(worker);
CatHasPawsDbContext.SaveChanges();
return worker;
}
private Salary InsertSalaryToDatabaseAndReturn(string workerId, double workerSalary = 1, DateTime? salaryDate = null)
{
var salary = new Salary() { WorkerId = workerId, WorkerSalary = workerSalary, SalaryDate = salaryDate ?? DateTime.UtcNow };
CatHasPawsDbContext.Salaries.Add(salary);
CatHasPawsDbContext.SaveChanges();
return salary;
AssertElement(CatHasPawsDbContext.GetSalariesFromDatabaseByWorkerId(_worker.Id).First(), salary);
}
private static void AssertElement(SalaryDataModel? actual, Salary expected)
@@ -134,8 +119,6 @@ internal class SalaryStorageContractTests : BaseStorageContractTest
private static SalaryDataModel CreateModel(string workerId, double workerSalary = 1, DateTime? salaryDate = null)
=> new(workerId, salaryDate ?? DateTime.UtcNow, workerSalary);
private Salary? GetSalaryFromDatabaseByWorkerId(string id) => CatHasPawsDbContext.Salaries.FirstOrDefault(x => x.WorkerId == id);
private static void AssertElement(Salary? actual, SalaryDataModel expected)
{
Assert.That(actual, Is.Not.Null);

View File

@@ -3,7 +3,7 @@ using CatHasPawsContratcs.Enums;
using CatHasPawsContratcs.Exceptions;
using CatHasPawsDatabase.Implementations;
using CatHasPawsDatabase.Models;
using Microsoft.EntityFrameworkCore;
using CatHasPawsTests.Infrastructure;
namespace CatHasPawsTests.StoragesContracts;
@@ -13,35 +13,35 @@ internal class SaleStorageContractTests : BaseStorageContractTest
private SaleStorageContract _saletStorageContract;
private Buyer _buyer;
private Worker _worker;
private Product _product;
private Manufacturer _manufacturer;
private Product _product;
[SetUp]
public void SetUp()
{
_saletStorageContract = new SaleStorageContract(CatHasPawsDbContext);
_manufacturer = InsertManufacturerToDatabaseAndReturn();
_buyer = InsertBuyerToDatabaseAndReturn();
_worker = InsertWorkerToDatabaseAndReturn();
_product = InsertProductToDatabaseAndReturn();
_manufacturer = CatHasPawsDbContext.InsertManufacturerToDatabaseAndReturn();
_buyer = CatHasPawsDbContext.InsertBuyerToDatabaseAndReturn();
_worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn();
_product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id);
}
[TearDown]
public void TearDown()
{
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Sales\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Buyers\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Workers\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Products\" CASCADE;");
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Manufacturers\" CASCADE;");
CatHasPawsDbContext.RemoveSalesFromDatabase();
CatHasPawsDbContext.RemoveWorkersFromDatabase();
CatHasPawsDbContext.RemoveBuyersFromDatabase();
CatHasPawsDbContext.RemoveProductsFromDatabase();
CatHasPawsDbContext.RemoveManufacturersFromDatabase();
}
[Test]
public void Try_GetList_WhenHaveRecords_Test()
{
var sale = InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 5)]);
InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(_product.Id, 10)]);
var sale = CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 5, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(_product.Id, 10, 1.2)]);
var list = _saletStorageContract.GetList();
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
@@ -59,10 +59,10 @@ internal class SaleStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByPeriod_Test()
{
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, null, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, null, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(3), products: [(_product.Id, 1)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, null, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, null, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(3), products: [(_product.Id, 1, 1.2)]);
var list = _saletStorageContract.GetList(startDate: DateTime.UtcNow.AddDays(-1), endDate: DateTime.UtcNow.AddDays(1));
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -71,10 +71,10 @@ internal class SaleStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByWorkerId_Test()
{
var worker = InsertWorkerToDatabaseAndReturn("Other worker");
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(worker.Id, null, products: [(_product.Id, 1)]);
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "Other worker");
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(worker.Id, null, products: [(_product.Id, 1, 1.2)]);
var list = _saletStorageContract.GetList(workerId: _worker.Id);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -84,11 +84,11 @@ internal class SaleStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByBuyerId_Test()
{
var buyer = InsertBuyerToDatabaseAndReturn("Other fio", "+8-888-888-88-88");
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, buyer.Id, products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(_product.Id, 1)]);
var buyer = CatHasPawsDbContext.InsertBuyerToDatabaseAndReturn(fio: "Other fio", phoneNumber: "+8-888-888-88-88");
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, buyer.Id, products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(_product.Id, 1, 1.2)]);
var list = _saletStorageContract.GetList(buyerId: _buyer.Id);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -98,30 +98,30 @@ internal class SaleStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByProductId_Test()
{
var product = InsertProductToDatabaseAndReturn("Other name");
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 5)]);
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1), (product.Id, 4)]);
InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(product.Id, 1), (_product.Id, 1)]);
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "Other name");
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 5, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2), (product.Id, 4, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, null, products: [(product.Id, 1, 1.2), (_product.Id, 1, 1.2)]);
var list = _saletStorageContract.GetList(productId: _product.Id);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
Assert.That(list.All(x => x.Products.Any(y => y.ProductId == _product.Id)));
Assert.That(list.All(x => x.Products!.Any(y => y.ProductId == _product.Id)));
}
[Test]
public void Try_GetList_ByAllParameters_Test()
{
var worker = InsertWorkerToDatabaseAndReturn("Other worker");
var buyer = InsertBuyerToDatabaseAndReturn("Other fio", "+8-888-888-88-88");
var product = InsertProductToDatabaseAndReturn("Other name");
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(worker.Id, null, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, buyer.Id, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(_product.Id, 1)]);
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(product.Id, 1)]);
InsertSaleToDatabaseAndReturn(worker.Id, null, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(_product.Id, 1)]);
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "Other worker");
var buyer = CatHasPawsDbContext.InsertBuyerToDatabaseAndReturn(fio: "Other fio", phoneNumber: "+8-888-888-88-88");
var product = CatHasPawsDbContext.InsertProductToDatabaseAndReturn(_manufacturer.Id, productName: "Other name");
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(worker.Id, null, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(-1).AddMinutes(3), products: [(product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, buyer.Id, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(_product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(product.Id, 1, 1.2)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(worker.Id, null, saleDate: DateTime.UtcNow.AddDays(1).AddMinutes(-3), products: [(_product.Id, 1, 1.2)]);
var list = _saletStorageContract.GetList(startDate: DateTime.UtcNow.AddDays(-1), endDate: DateTime.UtcNow.AddDays(1), workerId: _worker.Id, buyerId: _buyer.Id, productId: product.Id);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(1));
@@ -130,46 +130,46 @@ internal class SaleStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementById_WhenHaveRecord_Test()
{
var sale = InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
var sale = CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
AssertElement(_saletStorageContract.GetElementById(sale.Id), sale);
}
[Test]
public void Try_GetElementById_WhenNoRecord_Test()
{
InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)]);
CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)]);
Assert.That(() => _saletStorageContract.GetElementById(Guid.NewGuid().ToString()), Is.Null);
}
[Test]
public void Try_GetElementById_WhenRecordHasCanceled_Test()
{
var sale = InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)], isCancel: true);
var sale = CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)], isCancel: true);
AssertElement(_saletStorageContract.GetElementById(sale.Id), sale);
}
[Test]
public void Try_AddElement_Test()
{
var sale = CreateModel(Guid.NewGuid().ToString(), _worker.Id, _buyer.Id, 1, DiscountType.RegularCustomer, 1, false, [_product.Id]);
var sale = CreateModel(Guid.NewGuid().ToString(), _worker.Id, _buyer.Id, DiscountType.RegularCustomer, false, [_product.Id]);
_saletStorageContract.AddElement(sale);
AssertElement(GetSaleFromDatabaseById(sale.Id), sale);
AssertElement(CatHasPawsDbContext.GetSaleFromDatabaseById(sale.Id), sale);
}
[Test]
public void Try_AddElement_WhenIsDeletedIsTrue_Test()
{
var sale = CreateModel(Guid.NewGuid().ToString(), _worker.Id, _buyer.Id, 1, DiscountType.RegularCustomer, 1, true, [_product.Id]);
var sale = CreateModel(Guid.NewGuid().ToString(), _worker.Id, _buyer.Id, DiscountType.RegularCustomer, true, [_product.Id]);
Assert.That(() => _saletStorageContract.AddElement(sale), Throws.Nothing);
AssertElement(GetSaleFromDatabaseById(sale.Id), CreateModel(sale.Id, _worker.Id, _buyer.Id, 1, DiscountType.RegularCustomer, 1, false, [_product.Id]));
AssertElement(CatHasPawsDbContext.GetSaleFromDatabaseById(sale.Id), CreateModel(sale.Id, _worker.Id, _buyer.Id, DiscountType.RegularCustomer, false, [_product.Id]));
}
[Test]
public void Try_DelElement_Test()
{
var sale = InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)], isCancel: false);
var sale = CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)], isCancel: false);
_saletStorageContract.DelElement(sale.Id);
var element = GetSaleFromDatabaseById(sale.Id);
var element = CatHasPawsDbContext.GetSaleFromDatabaseById(sale.Id);
Assert.Multiple(() =>
{
Assert.That(element, Is.Not.Null);
@@ -186,57 +186,10 @@ internal class SaleStorageContractTests : BaseStorageContractTest
[Test]
public void Try_DelElement_WhenRecordWasCanceled_Test()
{
var sale = InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1)], isCancel: true);
var sale = CatHasPawsDbContext.InsertSaleToDatabaseAndReturn(_worker.Id, _buyer.Id, products: [(_product.Id, 1, 1.2)], isCancel: true);
Assert.That(() => _saletStorageContract.DelElement(sale.Id), Throws.TypeOf<ElementDeletedException>());
}
private Buyer InsertBuyerToDatabaseAndReturn(string fio = "test", string phoneNumber = "+7-777-777-77-77")
{
var buyer = new Buyer() { Id = Guid.NewGuid().ToString(), FIO = fio, PhoneNumber = phoneNumber, DiscountSize = 10 };
CatHasPawsDbContext.Buyers.Add(buyer);
CatHasPawsDbContext.SaveChanges();
return buyer;
}
private Worker InsertWorkerToDatabaseAndReturn(string fio = "test")
{
var worker = new Worker() { Id = Guid.NewGuid().ToString(), FIO = fio, PostId = Guid.NewGuid().ToString() };
CatHasPawsDbContext.Workers.Add(worker);
CatHasPawsDbContext.SaveChanges();
return worker;
}
private Manufacturer InsertManufacturerToDatabaseAndReturn()
{
var manufacrurer = new Manufacturer() { Id = Guid.NewGuid().ToString(), ManufacturerName = "name" };
CatHasPawsDbContext.Manufacturers.Add(manufacrurer);
CatHasPawsDbContext.SaveChanges();
return manufacrurer;
}
private Product InsertProductToDatabaseAndReturn(string productName = "test", ProductType productType = ProductType.Feed, double price = 1, bool isDeleted = false)
{
var product = new Product() { Id = Guid.NewGuid().ToString(), ManufacturerId = _manufacturer.Id, ProductName = productName, ProductType = productType, Price = price, IsDeleted = isDeleted };
CatHasPawsDbContext.Products.Add(product);
CatHasPawsDbContext.SaveChanges();
return product;
}
private Sale InsertSaleToDatabaseAndReturn(string workerId, string? buyerId, DateTime? saleDate = null, double sum = 1, DiscountType discountType = DiscountType.OnSale, double discount = 0, bool isCancel = false, List<(string, int)>? products = null)
{
var sale = new Sale() { WorkerId = workerId, BuyerId = buyerId, SaleDate = saleDate ?? DateTime.UtcNow, Sum = sum, DiscountType = discountType, Discount = discount, IsCancel = isCancel, SaleProducts = [] };
if (products is not null)
{
foreach (var elem in products)
{
sale.SaleProducts.Add(new SaleProduct { ProductId = elem.Item1, SaleId = sale.Id, Count = elem.Item2 });
}
}
CatHasPawsDbContext.Sales.Add(sale);
CatHasPawsDbContext.SaveChanges();
return sale;
}
private static void AssertElement(SaleDataModel? actual, Sale expected)
{
Assert.That(actual, Is.Not.Null);
@@ -269,14 +222,12 @@ internal class SaleStorageContractTests : BaseStorageContractTest
}
}
private static SaleDataModel CreateModel(string id, string workerId, string? buyerId, double sum, DiscountType discountType, double discount, bool isCancel, List<string> productIds)
private static SaleDataModel CreateModel(string id, string workerId, string? buyerId, DiscountType discountType, bool isCancel, List<string> productIds)
{
var products = productIds.Select(x => new SaleProductDataModel(id, x, 1)).ToList();
return new(id, workerId, buyerId, sum, discountType, discount, isCancel, products);
var products = productIds.Select(x => new SaleProductDataModel(id, x, 1, 1.1)).ToList();
return new(id, workerId, buyerId, discountType, isCancel, products);
}
private Sale? GetSaleFromDatabaseById(string id) => CatHasPawsDbContext.Sales.Include(x => x.SaleProducts).FirstOrDefault(x => x.Id == id);
private static void AssertElement(Sale? actual, SaleDataModel expected)
{
Assert.That(actual, Is.Not.Null);
@@ -300,6 +251,7 @@ internal class SaleStorageContractTests : BaseStorageContractTest
{
Assert.That(actual.SaleProducts[i].ProductId, Is.EqualTo(expected.Products[i].ProductId));
Assert.That(actual.SaleProducts[i].Count, Is.EqualTo(expected.Products[i].Count));
Assert.That(actual.SaleProducts[i].Price, Is.EqualTo(expected.Products[i].Price));
});
}
}

View File

@@ -2,7 +2,7 @@
using CatHasPawsContratcs.Exceptions;
using CatHasPawsDatabase.Implementations;
using CatHasPawsDatabase.Models;
using Microsoft.EntityFrameworkCore;
using CatHasPawsTests.Infrastructure;
namespace CatHasPawsTests.StoragesContracts;
@@ -20,19 +20,19 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
[TearDown]
public void TearDown()
{
CatHasPawsDbContext.Database.ExecuteSqlRaw("TRUNCATE \"Workers\" CASCADE;");
CatHasPawsDbContext.RemoveWorkersFromDatabase();
}
[Test]
public void Try_GetList_WhenHaveRecords_Test()
{
var worker = InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 1");
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 2");
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 3");
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 1");
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 2");
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 3");
var list = _workerStorageContract.GetList();
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(3));
AssertElement(list.First(), worker);
AssertElement(list.First(x => x.FIO == worker.FIO), worker);
}
[Test]
@@ -47,9 +47,9 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
public void Try_GetList_ByPostId_Test()
{
var postId = Guid.NewGuid().ToString();
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 1", postId);
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 2", postId);
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 3");
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 1", postId: postId);
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 2", postId: postId);
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 3");
var list = _workerStorageContract.GetList(postId: postId);
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -59,10 +59,10 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByBirthDate_Test()
{
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 1", birthDate: DateTime.UtcNow.AddYears(-25));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 2", birthDate: DateTime.UtcNow.AddYears(-21));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 3", birthDate: DateTime.UtcNow.AddYears(-20));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 4", birthDate: DateTime.UtcNow.AddYears(-19));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 1", birthDate: DateTime.UtcNow.AddYears(-25));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 2", birthDate: DateTime.UtcNow.AddYears(-21));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 3", birthDate: DateTime.UtcNow.AddYears(-20));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 4", birthDate: DateTime.UtcNow.AddYears(-19));
var list = _workerStorageContract.GetList(fromBirthDate: DateTime.UtcNow.AddYears(-21).AddMinutes(-1), toBirthDate: DateTime.UtcNow.AddYears(-20).AddMinutes(1));
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -71,10 +71,10 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetList_ByEmploymentDate_Test()
{
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 1", employmentDate: DateTime.UtcNow.AddDays(-2));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 2", employmentDate: DateTime.UtcNow.AddDays(-1));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 3", employmentDate: DateTime.UtcNow.AddDays(1));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 4", employmentDate: DateTime.UtcNow.AddDays(2));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 1", employmentDate: DateTime.UtcNow.AddDays(-2));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 2", employmentDate: DateTime.UtcNow.AddDays(-1));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 3", employmentDate: DateTime.UtcNow.AddDays(1));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 4", employmentDate: DateTime.UtcNow.AddDays(2));
var list = _workerStorageContract.GetList(fromEmploymentDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-1), toEmploymentDate: DateTime.UtcNow.AddDays(1).AddMinutes(1));
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(2));
@@ -84,10 +84,10 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
public void Try_GetList_ByAllParameters_Test()
{
var postId = Guid.NewGuid().ToString();
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 1", postId, birthDate: DateTime.UtcNow.AddYears(-25), employmentDate: DateTime.UtcNow.AddDays(-2));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 2", postId, birthDate: DateTime.UtcNow.AddYears(-22), employmentDate: DateTime.UtcNow.AddDays(-1));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 3", postId, birthDate: DateTime.UtcNow.AddYears(-21), employmentDate: DateTime.UtcNow.AddDays(-1));
InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString(), "fio 4", birthDate: DateTime.UtcNow.AddYears(-20), employmentDate: DateTime.UtcNow.AddDays(1));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 1", postId: postId, birthDate: DateTime.UtcNow.AddYears(-25), employmentDate: DateTime.UtcNow.AddDays(-2));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 2", postId: postId, birthDate: DateTime.UtcNow.AddYears(-22), employmentDate: DateTime.UtcNow.AddDays(-1));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 3", postId: postId, birthDate: DateTime.UtcNow.AddYears(-21), employmentDate: DateTime.UtcNow.AddDays(-1));
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(fio: "fio 4", birthDate: DateTime.UtcNow.AddYears(-20), employmentDate: DateTime.UtcNow.AddDays(1));
var list = _workerStorageContract.GetList(postId: postId, fromBirthDate: DateTime.UtcNow.AddYears(-21).AddMinutes(-1), toBirthDate: DateTime.UtcNow.AddYears(-20).AddMinutes(1), fromEmploymentDate: DateTime.UtcNow.AddDays(-1).AddMinutes(-1), toEmploymentDate: DateTime.UtcNow.AddDays(1).AddMinutes(1));
Assert.That(list, Is.Not.Null);
Assert.That(list, Has.Count.EqualTo(1));
@@ -96,7 +96,7 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementById_WhenHaveRecord_Test()
{
var worker = InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString());
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn();
AssertElement(_workerStorageContract.GetElementById(worker.Id), worker);
}
@@ -109,7 +109,7 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
[Test]
public void Try_GetElementByFIO_WhenHaveRecord_Test()
{
var worker = InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString());
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn();
AssertElement(_workerStorageContract.GetElementByFIO(worker.FIO), worker);
}
@@ -124,14 +124,14 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
{
var worker = CreateModel(Guid.NewGuid().ToString());
_workerStorageContract.AddElement(worker);
AssertElement(GetWorkerFromDatabase(worker.Id), worker);
AssertElement(CatHasPawsDbContext.GetWorkerFromDatabaseById(worker.Id), worker);
}
[Test]
public void Try_AddElement_WhenHaveRecordWithSameId_Test()
{
var worker = CreateModel(Guid.NewGuid().ToString());
InsertWorkerToDatabaseAndReturn(worker.Id);
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(worker.Id);
Assert.That(() => _workerStorageContract.AddElement(worker), Throws.TypeOf<ElementExistsException>());
}
@@ -139,9 +139,9 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_Test()
{
var worker = CreateModel(Guid.NewGuid().ToString(), "New Fio");
InsertWorkerToDatabaseAndReturn(worker.Id);
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(worker.Id);
_workerStorageContract.UpdElement(worker);
AssertElement(GetWorkerFromDatabase(worker.Id), worker);
AssertElement(CatHasPawsDbContext.GetWorkerFromDatabaseById(worker.Id), worker);
}
[Test]
@@ -154,16 +154,16 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
public void Try_UpdElement_WhenNoRecordWasDeleted_Test()
{
var worker = CreateModel(Guid.NewGuid().ToString());
InsertWorkerToDatabaseAndReturn(worker.Id, isDeleted: true);
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(worker.Id, isDeleted: true);
Assert.That(() => _workerStorageContract.UpdElement(worker), Throws.TypeOf<ElementNotFoundException>());
}
[Test]
public void Try_DelElement_Test()
{
var worker = InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString());
var worker = CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(Guid.NewGuid().ToString());
_workerStorageContract.DelElement(worker.Id);
var element = GetWorkerFromDatabase(worker.Id);
var element = CatHasPawsDbContext.GetWorkerFromDatabaseById(worker.Id);
Assert.That(element, Is.Not.Null);
Assert.That(element.IsDeleted);
}
@@ -178,18 +178,10 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
public void Try_DelElement_WhenNoRecordWasDeleted_Test()
{
var worker = CreateModel(Guid.NewGuid().ToString());
InsertWorkerToDatabaseAndReturn(worker.Id, isDeleted: true);
CatHasPawsDbContext.InsertWorkerToDatabaseAndReturn(worker.Id, isDeleted: true);
Assert.That(() => _workerStorageContract.DelElement(worker.Id), Throws.TypeOf<ElementNotFoundException>());
}
private Worker InsertWorkerToDatabaseAndReturn(string id, string fio = "test", string? postId = null, DateTime? birthDate = null, DateTime? employmentDate = null, bool isDeleted = false)
{
var worker = new Worker() { Id = id, FIO = fio, PostId = postId ?? Guid.NewGuid().ToString(), BirthDate = birthDate ?? DateTime.UtcNow.AddYears(-20), EmploymentDate = employmentDate ?? DateTime.UtcNow, IsDeleted = isDeleted };
CatHasPawsDbContext.Workers.Add(worker);
CatHasPawsDbContext.SaveChanges();
return worker;
}
private static void AssertElement(WorkerDataModel? actual, Worker expected)
{
Assert.That(actual, Is.Not.Null);
@@ -207,8 +199,6 @@ internal class WorkerStorageContractTests : BaseStorageContractTest
private static WorkerDataModel CreateModel(string id, string fio = "fio", string? postId = null, DateTime? birthDate = null, DateTime? employmentDate = null, bool isDeleted = false) =>
new(id, fio, postId ?? Guid.NewGuid().ToString(), birthDate ?? DateTime.UtcNow.AddYears(-20), employmentDate ?? DateTime.UtcNow, isDeleted);
private Worker? GetWorkerFromDatabase(string id) => CatHasPawsDbContext.Workers.FirstOrDefault(x => x.Id == id);
private static void AssertElement(Worker? actual, WorkerDataModel expected)
{
Assert.That(actual, Is.Not.Null);