diff --git a/North_Bridge/North_Bridge.sln b/North_Bridge/North_Bridge.sln index 1abbfaf..08918d1 100644 --- a/North_Bridge/North_Bridge.sln +++ b/North_Bridge/North_Bridge.sln @@ -7,6 +7,8 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "North_Bridge_Contract", "No EndProject Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "North_Bridge_Tests", "North_Bridge_Tests\North_Bridge_Tests.csproj", "{D77A42DA-D116-49A5-A735-95B5AC7B6D5D}" EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "North_Bridge_BusinessLogics", "North_Bridge_BusinessLogics\North_Bridge_BusinessLogics.csproj", "{51817427-2BC6-40CF-8269-3C55DBDBF867}" +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Any CPU = Debug|Any CPU @@ -21,6 +23,10 @@ Global {D77A42DA-D116-49A5-A735-95B5AC7B6D5D}.Debug|Any CPU.Build.0 = Debug|Any CPU {D77A42DA-D116-49A5-A735-95B5AC7B6D5D}.Release|Any CPU.ActiveCfg = Release|Any CPU {D77A42DA-D116-49A5-A735-95B5AC7B6D5D}.Release|Any CPU.Build.0 = Release|Any CPU + {51817427-2BC6-40CF-8269-3C55DBDBF867}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {51817427-2BC6-40CF-8269-3C55DBDBF867}.Debug|Any CPU.Build.0 = Debug|Any CPU + {51817427-2BC6-40CF-8269-3C55DBDBF867}.Release|Any CPU.ActiveCfg = Release|Any CPU + {51817427-2BC6-40CF-8269-3C55DBDBF867}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE diff --git a/North_Bridge/North_Bridge_BusinessLogics/Implementations/PostBusinessLogicContract.cs b/North_Bridge/North_Bridge_BusinessLogics/Implementations/PostBusinessLogicContract.cs new file mode 100644 index 0000000..52c098a --- /dev/null +++ b/North_Bridge/North_Bridge_BusinessLogics/Implementations/PostBusinessLogicContract.cs @@ -0,0 +1,97 @@ + +using Microsoft.Extensions.Logging; +using North_Bridge_Contract.BusinessLogicsContracts; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using System.Text.Json; + +namespace North_Bridge_BusinessLogics.Implementations; + +internal class PostBusinessLogicContract(IPostStorageContract postStorageContract, ILogger logger) : IPostBusinessLogicContract +{ + private readonly ILogger _logger = logger; + + private readonly IPostStorageContract _postStorageContract = postStorageContract; + + public List GetAllPosts(bool onlyActive = true) + { + _logger.LogInformation("GetAllPosts params: {onlyActive}", onlyActive); + return _postStorageContract.GetList(onlyActive) ?? throw new + NullListException(); + } + + public List GetAllDataOfPost(string postId) + { + _logger.LogInformation("GetAllDataOfPost for {postId}", postId); + if (postId.IsEmpty()) + { + throw new ArgumentNullException(nameof(postId)); + } + if (!postId.IsGuid()) + { + throw new ValidationException("The value in the field postId is not a unique identifier."); + } + return _postStorageContract.GetPostWithHistory(postId) ?? throw new NullListException(); + } + + public PostDataModel GetPostByData(string data) + { + _logger.LogInformation("Get element by data: {data}", data); + if (data.IsEmpty()) + { + throw new ArgumentNullException(nameof(data)); + } + if (data.IsGuid()) + { + return _postStorageContract.GetElementById(data) ?? throw new + ElementNotFoundException(data); + } + return _postStorageContract.GetElementByName(data) ?? throw new + ElementNotFoundException(data); + } + + public void InsertPost(PostDataModel postDataModel) + { + _logger.LogInformation("New data: {json}", + JsonSerializer.Serialize(postDataModel)); + ArgumentNullException.ThrowIfNull(postDataModel); + postDataModel.Validate(); + _postStorageContract.AddElement(postDataModel); + } + public void UpdatePost(PostDataModel postDataModel) + { + _logger.LogInformation("Update data: {json}", + JsonSerializer.Serialize(postDataModel)); + ArgumentNullException.ThrowIfNull(postDataModel); + postDataModel.Validate(); + _postStorageContract.UpdElement(postDataModel); + } + public void DeletePost(string id) + { + _logger.LogInformation("Delete by id: {id}", id); + if (id.IsEmpty()) + { + throw new ArgumentNullException(nameof(id)); + } + if (!id.IsGuid()) + { + throw new ValidationException("Id is not a unique identifier"); + } + _postStorageContract.DelElement(id); + } + public void RestorePost(string id) + { + _logger.LogInformation("Restore by id: {id}", id); + if (id.IsEmpty()) + { + throw new ArgumentNullException(nameof(id)); + } + if (!id.IsGuid()) + { + throw new ValidationException("Id is not a unique identifier"); + } + _postStorageContract.ResElement(id); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_BusinessLogics/Implementations/ProductBusinessLogicContract.cs b/North_Bridge/North_Bridge_BusinessLogics/Implementations/ProductBusinessLogicContract.cs new file mode 100644 index 0000000..64fe305 --- /dev/null +++ b/North_Bridge/North_Bridge_BusinessLogics/Implementations/ProductBusinessLogicContract.cs @@ -0,0 +1,86 @@ +using North_Bridge_Contract.BusinessLogicsContracts; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using System.Text.Json; + +namespace North_Bridge_BusinessLogics.Implementations; + +internal class ProductBusinessLogicContract(IProductStorageContract productStorageContract, ILogger logger) : IProductBusinessLogicContract +{ + private readonly ILogger _logger = logger; + + private readonly IProductStorageContract _productStorageContract = productStorageContract; + + public List GetAllProducts(bool onlyActive) + { + _logger.LogInformation("GetAllProducts params: {onlyActive}", onlyActive); + return _productStorageContract.GetList(onlyActive) ?? throw new + NullListException(); + } + + public List GetProductHistoryByProduct(string productId) + { + _logger.LogInformation("GetProductHistoryByProduct for {productId}", productId); + if (productId.IsEmpty()) + { + throw new ArgumentNullException(nameof(productId)); + } + if (!productId.IsGuid()) + { + throw new ValidationException("The value in the field productId is not a unique identifier."); + } + return _productStorageContract.GetHistoryByProductId(productId) ?? throw new NullListException(); + } + + public ProductDataModel GetProductByData(string data) + { + _logger.LogInformation("Get element by data: {data}", data); + if (data.IsEmpty()) + { + throw new ArgumentNullException(nameof(data)); + } + if (data.IsGuid()) + { + return _productStorageContract.GetElementById(data) ?? throw + new ElementNotFoundException(data); + } + return _productStorageContract.GetElementByName(data) ?? throw new + ElementNotFoundException(data); + } + + public void InsertProduct(ProductDataModel productDataModel) + { + _logger.LogInformation("New data: {json}", + JsonSerializer.Serialize(productDataModel)); + ArgumentNullException.ThrowIfNull(productDataModel); + productDataModel.Validate(); + _productStorageContract.AddElement(productDataModel); + + } + + public void UpdateProduct(ProductDataModel productDataModel) + { + _logger.LogInformation("Update data: {json}", + JsonSerializer.Serialize(productDataModel)); + ArgumentNullException.ThrowIfNull(productDataModel); + productDataModel.Validate(); + _productStorageContract.UpdElement(productDataModel); + } + + public void DeleteProduct(string id) + { + _logger.LogInformation("Delete by id: {id}", id); + if (id.IsEmpty()) + { + throw new ArgumentNullException(nameof(id)); + } + if (!id.IsGuid()) + { + throw new ValidationException("Id is not a unique identifier"); + } + _productStorageContract.DelElement(id); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_BusinessLogics/Implementations/SalaryBusinessLogicContract.cs b/North_Bridge/North_Bridge_BusinessLogics/Implementations/SalaryBusinessLogicContract.cs new file mode 100644 index 0000000..d257bf6 --- /dev/null +++ b/North_Bridge/North_Bridge_BusinessLogics/Implementations/SalaryBusinessLogicContract.cs @@ -0,0 +1,71 @@ +using North_Bridge_Contract.BusinessLogicsContracts; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; + +namespace North_Bridge_BusinessLogics.Implementations; + +internal class SalaryBusinessLogicContract(ISalaryStorageContract salaryStorageContract, ISaleStorageContract saleStorageContract, IPostStorageContract postStorageContract, IWorkerStorageContract workerStorageContract, ILogger logger) : ISalaryBusinessLogicContract +{ + private readonly ILogger _logger = logger; + + private readonly ISalaryStorageContract _salaryStorageContract = salaryStorageContract; + + private readonly ISaleStorageContract _saleStorageContract = saleStorageContract; + + private readonly IPostStorageContract _postStorageContract = postStorageContract; + + private readonly IWorkerStorageContract _workerStorageContract = workerStorageContract; + + public List GetAllSalariesByPeriod(DateTime fromDate, DateTime toDate) + { + _logger.LogInformation("GetAllSalaries params: {fromDate}, {toDate}", fromDate, toDate); + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + return _salaryStorageContract.GetList(fromDate, toDate) ?? throw new + NullListException(); + } + + public List GetAllSalariesByPeriodByWorker(DateTime fromDate, DateTime toDate, string workerId) + { + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + if (workerId.IsEmpty()) + { + throw new ArgumentNullException(nameof(workerId)); + } + if (!workerId.IsGuid()) + { + throw new ValidationException("The value in the field workerId is not a unique identifier."); + } + _logger.LogInformation("GetAllSalaries params: {fromDate}, {toDate}, { workerId}", fromDate, toDate, workerId); + return _salaryStorageContract.GetList(fromDate, toDate, workerId) ?? + throw new NullListException(); + } + + public void CalculateSalaryByMounth(DateTime date) + { + _logger.LogInformation("CalculateSalaryByMounth: {date}", date); + var startDate = new DateTime(date.Year, date.Month, 1); + var finishDate = new DateTime(date.Year, date.Month, + DateTime.DaysInMonth(date.Year, date.Month)); + var workers = _workerStorageContract.GetList() ?? throw new NullListException(); + foreach (var worker in workers) + { + var sales = _saleStorageContract.GetList(startDate, + finishDate, workerId: worker.Id)?.Sum(x => x.Sum) ?? + throw new NullListException(); + var post = _postStorageContract.GetElementById(worker.PostId) + ?? throw new NullListException(); + var salary = post.Salary + sales * 0.1; + _logger.LogDebug("The employee {workerId} was paid a salary of { salary}", worker.Id, salary); + _salaryStorageContract.AddElement(new SalaryDataModel(worker.Id, finishDate, salary)); + } + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_BusinessLogics/Implementations/SaleBusinessLogicContract.cs b/North_Bridge/North_Bridge_BusinessLogics/Implementations/SaleBusinessLogicContract.cs new file mode 100644 index 0000000..6e51fd7 --- /dev/null +++ b/North_Bridge/North_Bridge_BusinessLogics/Implementations/SaleBusinessLogicContract.cs @@ -0,0 +1,102 @@ +using Microsoft.Extensions.Logging; +using North_Bridge_Contract.BusinessLogicsContracts; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using System.Text.Json; + +namespace North_Bridge_BusinessLogics.Implementations; + +internal class SaleBusinessLogicContract(ISaleStorageContract saleStorageContract, ILogger logger) : ISaleBusinessLogicContract +{ + private readonly ILogger _logger = logger; + + private readonly ISaleStorageContract _saleStorageContract = saleStorageContract; + + public List GetAllSalesByPeriod(DateTime fromDate, DateTime toDate) + { + _logger.LogInformation("GetAllSales params: {fromDate}, {toDate}", fromDate, toDate); + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + return _saleStorageContract.GetList(fromDate, toDate) ?? throw new + NullListException(); + } + + public List GetAllSalesByWorkerByPeriod(string workerId, + DateTime fromDate, DateTime toDate) + { + _logger.LogInformation("GetAllSales params: {workerId}, {fromDate}, { toDate}", workerId, fromDate, toDate); + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + if (workerId.IsEmpty()) + { + throw new ArgumentNullException(nameof(workerId)); + } + if (!workerId.IsGuid()) + { + throw new ValidationException("The value in the field workerId is not a unique identifier."); + } + return _saleStorageContract.GetList(fromDate, toDate, workerId: workerId) ?? throw new NullListException(); + } + + public List GetAllSalesByProductByPeriod(string productId, DateTime fromDate, DateTime toDate) + { + _logger.LogInformation("GetAllSales params: {productId}, {fromDate}, { toDate}", productId, fromDate, toDate); + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + if (productId.IsEmpty()) + { + throw new ArgumentNullException(nameof(productId)); + } + if (!productId.IsGuid()) + { + throw new ValidationException("The value in the field productId is not a unique identifier."); + } + return _saleStorageContract.GetList(fromDate, toDate, productId: productId) ?? throw new NullListException(); + } + + public SaleDataModel GetSaleByData(string data) + { + _logger.LogInformation("Get element by data: {data}", data); + if (data.IsEmpty()) + { + throw new ArgumentNullException(nameof(data)); + } + if (!data.IsGuid()) + { + throw new ValidationException("Id is not a unique identifier"); + } + return _saleStorageContract.GetElementById(data) ?? throw new + ElementNotFoundException(data); + } + + public void InsertSale(SaleDataModel saleDataModel) + { + _logger.LogInformation("New data: {json}", + JsonSerializer.Serialize(saleDataModel)); + ArgumentNullException.ThrowIfNull(saleDataModel); + saleDataModel.Validate(); + _saleStorageContract.AddElement(saleDataModel); + } + + public void CancelSale(string id) + { + _logger.LogInformation("Cancel by id: {id}", id); + if (id.IsEmpty()) + { + throw new ArgumentNullException(nameof(id)); + } + if (!id.IsGuid()) + { + throw new ValidationException("Id is not a unique identifier"); + } + _saleStorageContract.DelElement(id); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_BusinessLogics/Implementations/WorkerBusinessLogicContract.cs b/North_Bridge/North_Bridge_BusinessLogics/Implementations/WorkerBusinessLogicContract.cs new file mode 100644 index 0000000..33d9c3c --- /dev/null +++ b/North_Bridge/North_Bridge_BusinessLogics/Implementations/WorkerBusinessLogicContract.cs @@ -0,0 +1,107 @@ +using Microsoft.Extensions.Logging; +using North_Bridge_Contract.BusinessLogicsContracts; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using System.Text.Json; + +namespace North_Bridge_BusinessLogics.Implementations; + +internal class WorkerBusinessLogicContract(IWorkerStorageContract workerStorageContract, ILogger logger) : IWorkerBusinessLogicContract +{ + private readonly ILogger _logger = logger; + + private readonly IWorkerStorageContract _workerStorageContract = workerStorageContract; + + public List GetAllWorkers(bool onlyActive = true) + { + _logger.LogInformation("GetAllWorkers params: {onlyActive}", onlyActive); + return _workerStorageContract.GetList(onlyActive) ?? throw new NullListException(); + } + + public List GetAllWorkersByPost(string postId, bool + onlyActive = true) + { + _logger.LogInformation("GetAllWorkers params: {postId}, { onlyActive},", postId, onlyActive); + if (postId.IsEmpty()) + { + throw new ArgumentNullException(nameof(postId)); + } + if (!postId.IsGuid()) + { + throw new ValidationException("The value in the field postId is not a unique identifier."); + } + return _workerStorageContract.GetList(onlyActive, postId) ?? throw new NullListException(); + } + + public List GetAllWorkersByBirthDate(DateTime fromDate, DateTime toDate, bool onlyActive = true) + { + _logger.LogInformation("GetAllWorkers params: {onlyActive}, { fromDate}, { toDate}", onlyActive, fromDate, toDate); + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + return _workerStorageContract.GetList(onlyActive, fromBirthDate: + fromDate, toBirthDate: toDate) ?? throw new NullListException(); + } + + public List GetAllWorkersByEmploymentDate(DateTime fromDate, DateTime toDate, bool onlyActive = true) + { + _logger.LogInformation("GetAllWorkers params: {onlyActive}, { fromDate}, { toDate}", onlyActive, fromDate, toDate); + if (fromDate.IsDateNotOlder(toDate)) + { + throw new IncorrectDatesException(fromDate, toDate); + } + return _workerStorageContract.GetList(onlyActive, fromEmploymentDate: + fromDate, toEmploymentDate: toDate) ?? throw new NullListException(); + } + + public WorkerDataModel GetWorkerByData(string data) + { + _logger.LogInformation("Get element by data: {data}", data); + if (data.IsEmpty()) + { + throw new ArgumentNullException(nameof(data)); + } + if (data.IsGuid()) + { + return _workerStorageContract.GetElementById(data) ?? throw + new ElementNotFoundException(data); + } + return _workerStorageContract.GetElementByFIO(data) ?? throw new + ElementNotFoundException(data); + } + + public void InsertWorker(WorkerDataModel workerDataModel) + { + _logger.LogInformation("New data: {json}", + JsonSerializer.Serialize(workerDataModel)); + ArgumentNullException.ThrowIfNull(workerDataModel); + workerDataModel.Validate(); + _workerStorageContract.AddElement(workerDataModel); + } + + public void UpdateWorker(WorkerDataModel workerDataModel) + { + _logger.LogInformation("Update data: {json}", + JsonSerializer.Serialize(workerDataModel)); + ArgumentNullException.ThrowIfNull(workerDataModel); + workerDataModel.Validate(); + _workerStorageContract.UpdElement(workerDataModel); + } + + public void DeleteWorker(string id) + { + _logger.LogInformation("Delete by id: {id}", id); + if (id.IsEmpty()) + { + throw new ArgumentNullException(nameof(id)); + } + if (!id.IsGuid()) + { + throw new ValidationException("Id is not a unique identifier"); + } + _workerStorageContract.DelElement(id); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_BusinessLogics/North_Bridge_BusinessLogics.csproj b/North_Bridge/North_Bridge_BusinessLogics/North_Bridge_BusinessLogics.csproj new file mode 100644 index 0000000..3db437a --- /dev/null +++ b/North_Bridge/North_Bridge_BusinessLogics/North_Bridge_BusinessLogics.csproj @@ -0,0 +1,22 @@ + + + + net8.0 + enable + enable + + + + + + + + + + + + + + + + diff --git a/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IPostBusinessLogicContract.cs b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IPostBusinessLogicContract.cs new file mode 100644 index 0000000..53e2978 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IPostBusinessLogicContract.cs @@ -0,0 +1,20 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.BusinessLogicsContracts; + +public interface IPostBusinessLogicContract +{ + List GetAllPosts(bool onlyActive); + + List GetAllDataOfPost(string postId); + + PostDataModel GetPostByData(string data); + + void InsertPost(PostDataModel postDataModel); + + void UpdatePost(PostDataModel postDataModel); + + void DeletePost(string id); + + void RestorePost(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IProductBusinessLogicContract.cs b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IProductBusinessLogicContract.cs new file mode 100644 index 0000000..b3e11fb --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IProductBusinessLogicContract.cs @@ -0,0 +1,18 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.BusinessLogicsContracts; + +public interface IProductBusinessLogicContract +{ + List GetAllProducts(bool onlyActive = true); + + List GetProductHistoryByProduct(string productId); + + ProductDataModel GetProductByData(string data); + + void InsertProduct(ProductDataModel productDataModel); + + void UpdateProduct(ProductDataModel productDataModel); + + void DeleteProduct(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/ISalaryBusinessLogicContract.cs b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/ISalaryBusinessLogicContract.cs new file mode 100644 index 0000000..e32afe9 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/ISalaryBusinessLogicContract.cs @@ -0,0 +1,12 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.BusinessLogicsContracts; + +public interface ISalaryBusinessLogicContract +{ + List GetAllSalariesByPeriod(DateTime fromDate, DateTime toDate); + + List GetAllSalariesByPeriodByWorker(DateTime fromDate, DateTime toDate, string workerId); + + void CalculateSalaryByMounth(DateTime date); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/ISaleBusinessLogicContract.cs b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/ISaleBusinessLogicContract.cs new file mode 100644 index 0000000..717a82a --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/ISaleBusinessLogicContract.cs @@ -0,0 +1,18 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.BusinessLogicsContracts; + +public interface ISaleBusinessLogicContract +{ + List GetAllSalesByPeriod(DateTime fromDate, DateTime toDate); + + List GetAllSalesByWorkerByPeriod(string workerId, DateTime fromDate, DateTime toDate); + + List GetAllSalesByProductByPeriod(string productId, DateTime fromDate, DateTime toDate); + + SaleDataModel GetSaleByData(string data); + + void InsertSale(SaleDataModel saleDataModel); + + void CancelSale(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IWorkerBusinessLogicContract.cs b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IWorkerBusinessLogicContract.cs new file mode 100644 index 0000000..1a89ff4 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/BusinessLogicsContracts/IWorkerBusinessLogicContract.cs @@ -0,0 +1,27 @@ +using North_Bridge_Contract.DataModels; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace North_Bridge_Contract.BusinessLogicsContracts; + +public interface IWorkerBusinessLogicContract +{ + List GetAllWorkers(bool onlyActive = true); + + List GetAllWorkersByPost(string postId, bool onlyActive = true); + + List GetAllWorkersByBirthDate(DateTime fromDate, DateTime toDate, bool onlyActive = true); + + List GetAllWorkersByEmploymentDate(DateTime fromDate, DateTime toDate, bool onlyActive = true); + + WorkerDataModel GetWorkerByData(string data); + + void InsertWorker(WorkerDataModel workerDataModel); + + void UpdateWorker(WorkerDataModel workerDataModel); + + void DeleteWorker(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/DataModels/PostDataModel.cs b/North_Bridge/North_Bridge_Contract/DataModels/PostDataModel.cs index 73e5d11..472a030 100644 --- a/North_Bridge/North_Bridge_Contract/DataModels/PostDataModel.cs +++ b/North_Bridge/North_Bridge_Contract/DataModels/PostDataModel.cs @@ -9,8 +9,6 @@ public class PostDataModel : IValidation { public string Id { get; private set; } - public string PostId { get; private set; } - public string PostName { get; private set; } public PostType PostType { get; private set; } @@ -21,10 +19,9 @@ public class PostDataModel : IValidation public DateTime ChangeDate { get; private set; } - public PostDataModel(string id, string postId, string postName, PostType postType, double salary, bool isActual, DateTime changeDate) + public PostDataModel(string id, string postName, PostType postType, double salary, bool isActual, DateTime changeDate) { Id = id; - PostId = postId; PostName = postName; PostType = postType; Salary = salary; @@ -39,12 +36,6 @@ public class PostDataModel : IValidation if (!Id.IsGuid()) throw new ValidationException("The value in the field Id is not a unique identifier"); - - if (PostId.IsEmpty()) - throw new ValidationException("Field PostId is empty"); - - if (!PostId.IsGuid()) - throw new ValidationException("The value in the field PostId is not a unique identifier"); if (PostName.IsEmpty()) throw new ValidationException("Field PostName is empty"); diff --git a/North_Bridge/North_Bridge_Contract/DataModels/SaleDataModel.cs b/North_Bridge/North_Bridge_Contract/DataModels/SaleDataModel.cs index 544d8b0..1fd0b0d 100644 --- a/North_Bridge/North_Bridge_Contract/DataModels/SaleDataModel.cs +++ b/North_Bridge/North_Bridge_Contract/DataModels/SaleDataModel.cs @@ -18,17 +18,7 @@ public class SaleDataModel : IValidation public List Products { get; private set; } - public SaleDataModel(string id, string workerId, DateTime saleDate, double sum, bool isCancel, List products) - { - Id = id; - WorkerId = workerId; - SaleDate = saleDate; - Sum = sum; - IsCancel = isCancel; - Products = products; - } - - public SaleDataModel(string? id, string? workerId, double sum, bool isCancel, List? products) + public SaleDataModel(string id, string workerId, double sum, bool isCancel, List products) { Id = id; WorkerId = workerId; diff --git a/North_Bridge/North_Bridge_Contract/DataModels/WorkerDataModel.cs b/North_Bridge/North_Bridge_Contract/DataModels/WorkerDataModel.cs index b09cd89..cf18981 100644 --- a/North_Bridge/North_Bridge_Contract/DataModels/WorkerDataModel.cs +++ b/North_Bridge/North_Bridge_Contract/DataModels/WorkerDataModel.cs @@ -20,7 +20,7 @@ public class WorkerDataModel : IValidation public bool IsDeleted { get; private set; } - public WorkerDataModel(string id, string email, string fio, string postId, DateTime birthDate, DateTime employmentDate, bool isDeleted) + public WorkerDataModel(string id, string fio, string email, string postId, DateTime birthDate, DateTime employmentDate, bool isDeleted) { Id = id; FIO = fio; @@ -42,22 +42,25 @@ public class WorkerDataModel : IValidation if (FIO.IsEmpty()) throw new ValidationException("Field FIO is empty"); + if (Email.IsEmpty()) + throw new ValidationException("Field Email is empty"); + + if (!Regex.IsMatch(Email, @"^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$")) + throw new ValidationException("Field Email is not a valid email address"); + if (PostId.IsEmpty()) throw new ValidationException("Field PostId is empty"); if (!PostId.IsGuid()) throw new ValidationException("The value in the field PostId is not a unique identifier"); - if (BirthDate.Date > DateTime.Now.AddYears(-16).Date) - throw new ValidationException($"Minors cannot be hired (BirthDate = { BirthDate.ToShortDateString() })"); + if (BirthDate.Date > DateTime.Now.AddYears(-18).Date) + throw new ValidationException($"Only adults can be hired (BirthDate = {BirthDate.ToShortDateString()})"); if (EmploymentDate.Date < BirthDate.Date) throw new ValidationException("The date of employment cannot be less than the date of birth"); - if ((EmploymentDate - BirthDate).TotalDays / 365 < 16) // EmploymentDate.Year - BirthDate.Year - throw new ValidationException($"Minors cannot be hired (EmploymentDate - { EmploymentDate.ToShortDateString() }, BirthDate - { BirthDate.ToShortDateString()})"); - - if (!Regex.IsMatch(Email, @"^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$")) // example@example.com - throw new ValidationException("Field Email is not a email"); + if ((EmploymentDate - BirthDate).TotalDays / 365 < 18) + throw new ValidationException($"Only adults can be hired (EmploymentDate - {EmploymentDate.ToShortDateString()}, BirthDate - {BirthDate.ToShortDateString()})"); } } \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/Exceptions/ElementExistsException.cs b/North_Bridge/North_Bridge_Contract/Exceptions/ElementExistsException.cs new file mode 100644 index 0000000..04cada5 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/Exceptions/ElementExistsException.cs @@ -0,0 +1,15 @@ + +namespace North_Bridge_Contract.Extentions; + +public class ElementExistsException : Exception +{ + public string ParamName { get; private set; } + + public string ParamValue { get; private set; } + + public ElementExistsException(string paramName, string paramValue) : base($"There is already an element with value{paramValue} of parameter { paramName}") + { + ParamName = paramName; + ParamValue = paramValue; + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/Exceptions/ElementNotFoundException.cs b/North_Bridge/North_Bridge_Contract/Exceptions/ElementNotFoundException.cs new file mode 100644 index 0000000..2893100 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/Exceptions/ElementNotFoundException.cs @@ -0,0 +1,12 @@ + +namespace North_Bridge_Contract.Exceptions; + +public class ElementNotFoundException : Exception +{ + public string Value { get; private set; } + + public ElementNotFoundException(string value) : base($"Element not found at value = { value}") + { + Value = value; + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/Exceptions/IncorrectDatesException.cs b/North_Bridge/North_Bridge_Contract/Exceptions/IncorrectDatesException.cs new file mode 100644 index 0000000..c5772b5 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/Exceptions/IncorrectDatesException.cs @@ -0,0 +1,7 @@ + +namespace North_Bridge_Contract.Exceptions; + +public class IncorrectDatesException : Exception +{ + public IncorrectDatesException(DateTime start, DateTime end) : base($"The end date must be later than the start date..StartDate: { start: dd.MM.YYYY}. EndDate: {end:dd.MM.YYYY}") { } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/Exceptions/NullListException.cs b/North_Bridge/North_Bridge_Contract/Exceptions/NullListException.cs new file mode 100644 index 0000000..5ece098 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/Exceptions/NullListException.cs @@ -0,0 +1,6 @@ +namespace North_Bridge_Contract.Exceptions; + +public class NullListException : Exception +{ + public NullListException() : base("The returned list is null") { } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/Exceptions/StorageException.cs b/North_Bridge/North_Bridge_Contract/Exceptions/StorageException.cs new file mode 100644 index 0000000..c363106 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/Exceptions/StorageException.cs @@ -0,0 +1,6 @@ +namespace North_Bridge_Contract.Exceptions; + +public class StorageException : Exception +{ + public StorageException(Exception ex) : base($"Error while working in storage: {ex.Message}", ex) { } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/Extentions/DateTimeExtensions.cs b/North_Bridge/North_Bridge_Contract/Extentions/DateTimeExtensions.cs new file mode 100644 index 0000000..f455c43 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/Extentions/DateTimeExtensions.cs @@ -0,0 +1,10 @@ + +namespace North_Bridge_Contract.Extentions; + +public static class DateTimeExtensions +{ + public static bool IsDateNotOlder(this DateTime date, DateTime olderDate) + { + return date >= olderDate; + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/StoragesContracts/IPostStorageContract.cs b/North_Bridge/North_Bridge_Contract/StoragesContracts/IPostStorageContract.cs new file mode 100644 index 0000000..9ed9bc4 --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/StoragesContracts/IPostStorageContract.cs @@ -0,0 +1,22 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.StoragesContracts; + +public interface IPostStorageContract +{ + List GetList(bool onlyActual = true); + + List GetPostWithHistory(string postId); + + PostDataModel? GetElementById(string id); + + PostDataModel? GetElementByName(string name); + + void AddElement(PostDataModel postDataModel); + + void UpdElement(PostDataModel postDataModel); + + void DelElement(string id); + + void ResElement(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/StoragesContracts/IProductStorageContract.cs b/North_Bridge/North_Bridge_Contract/StoragesContracts/IProductStorageContract.cs new file mode 100644 index 0000000..970468d --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/StoragesContracts/IProductStorageContract.cs @@ -0,0 +1,20 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.StoragesContracts; + +public interface IProductStorageContract +{ + List GetList(bool onlyActive = true); + + List GetHistoryByProductId(string productId); + + ProductDataModel? GetElementById(string id); + + ProductDataModel? GetElementByName(string name); + + void AddElement(ProductDataModel productDataModel); + + void UpdElement(ProductDataModel productDataModel); + + void DelElement(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/StoragesContracts/ISalaryStorageContract.cs b/North_Bridge/North_Bridge_Contract/StoragesContracts/ISalaryStorageContract.cs new file mode 100644 index 0000000..85cc57c --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/StoragesContracts/ISalaryStorageContract.cs @@ -0,0 +1,10 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.StoragesContracts; + +public interface ISalaryStorageContract +{ + List GetList(DateTime startDate, DateTime endDate, string? workerId = null); + + void AddElement(SalaryDataModel salaryDataModel); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/StoragesContracts/ISaleStorageContract.cs b/North_Bridge/North_Bridge_Contract/StoragesContracts/ISaleStorageContract.cs new file mode 100644 index 0000000..e03adbe --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/StoragesContracts/ISaleStorageContract.cs @@ -0,0 +1,14 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.StoragesContracts; + +public interface ISaleStorageContract +{ + List GetList(DateTime? startDate = null, DateTime? endDate = null, string? workerId = null, string? productId = null); + + SaleDataModel? GetElementById(string id); + + void AddElement(SaleDataModel saleDataModel); + + void DelElement(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Contract/StoragesContracts/IWorkerStorageContract.cs b/North_Bridge/North_Bridge_Contract/StoragesContracts/IWorkerStorageContract.cs new file mode 100644 index 0000000..5e5baac --- /dev/null +++ b/North_Bridge/North_Bridge_Contract/StoragesContracts/IWorkerStorageContract.cs @@ -0,0 +1,18 @@ +using North_Bridge_Contract.DataModels; + +namespace North_Bridge_Contract.StoragesContracts; + +public interface IWorkerStorageContract +{ + List GetList(bool onlyActive = true, string? postId = null, DateTime? fromBirthDate = null, DateTime? toBirthDate = null, DateTime? fromEmploymentDate = null, DateTime? toEmploymentDate = null); + + WorkerDataModel? GetElementById(string id); + + WorkerDataModel? GetElementByFIO(string fio); + + void AddElement(WorkerDataModel workerDataModel); + + void UpdElement(WorkerDataModel workerDataModel); + + void DelElement(string id); +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/PostBusinessLogicContractTests.cs b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/PostBusinessLogicContractTests.cs new file mode 100644 index 0000000..5c3b0f2 --- /dev/null +++ b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/PostBusinessLogicContractTests.cs @@ -0,0 +1,590 @@ +using Moq; +using North_Bridge_BusinessLogics.Implementations; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Enums; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; + +namespace North_Bridge_Tests.BusinessLogicsContractsTests; + +[TestFixture] +internal class PostBusinessLogicContractTests +{ + private PostBusinessLogicContract _postBusinessLogicContract; + + private Mock _postStorageContract; + + [OneTimeSetUp] + public void OneTimeSetUp() + { + _postStorageContract = new Mock(); + _postBusinessLogicContract = new PostBusinessLogicContract(_postStorageContract.Object, new Mock().Object); + } + + [TearDown] + public void SetUp() + { + _postStorageContract.Reset(); + } + + [Test] + public void GetAllPosts_ReturnListOfRecords_Test() + { + //Arrange + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(),"name 1", PostType.Consultant, + 10, true, DateTime.UtcNow), + new(Guid.NewGuid().ToString(), "name 2", PostType.Consultant, + 10, false, DateTime.UtcNow), + new(Guid.NewGuid().ToString(), "name 3", PostType.Consultant, + 10, true, DateTime.UtcNow), + }; + _postStorageContract.Setup(x => + x.GetList(It.IsAny())).Returns(listOriginal); + //Act + var listOnlyActive = _postBusinessLogicContract.GetAllPosts(true); + var listAll = _postBusinessLogicContract.GetAllPosts(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(listAll, Is.Not.Null); + Assert.That(listOnlyActive, Is.EquivalentTo(listOriginal)); + Assert.That(listAll, Is.EquivalentTo(listOriginal)); + }); + _postStorageContract.Verify(x => x.GetList(true), Times.Once); + _postStorageContract.Verify(x => x.GetList(false), Times.Once); + } + + [Test] + public void GetAllPosts_ReturnEmptyList_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.GetList(It.IsAny())).Returns([]); + //Act + var listOnlyActive = _postBusinessLogicContract.GetAllPosts(true); + var listAll = _postBusinessLogicContract.GetAllPosts(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(listAll, Is.Not.Null); + Assert.That(listOnlyActive, Has.Count.EqualTo(0)); + Assert.That(listAll, Has.Count.EqualTo(0)); + }); + _postStorageContract.Verify(x => x.GetList(It.IsAny()), + Times.Exactly(2)); + } + + [Test] + public void GetAllPosts_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.GetAllPosts(It.IsAny()), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.GetList(It.IsAny()), + Times.Once); + } + + [Test] + public void GetAllPosts_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.GetList(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.GetAllPosts(It.IsAny()), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.GetList(It.IsAny()), + Times.Once); + } + + [Test] + public void GetAllDataOfPost_ReturnListOfRecords_Test() + { + //Arrange + var postId = Guid.NewGuid().ToString(); + var listOriginal = new List() + { + new(postId, "name 1", PostType.Consultant, 10, true, + DateTime.UtcNow), + new(postId, "name 2", PostType.Consultant, 10, false, + DateTime.UtcNow) + }; + _postStorageContract.Setup(x => + x.GetPostWithHistory(It.IsAny())).Returns(listOriginal); + //Act + var list = _postBusinessLogicContract.GetAllDataOfPost(postId); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(2)); + _postStorageContract.Verify(x => x.GetPostWithHistory(postId), Times.Once); + } + + [Test] + public void GetAllDataOfPost_ReturnEmptyList_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.GetPostWithHistory(It.IsAny())).Returns([]); + //Act + var list = + _postBusinessLogicContract.GetAllDataOfPost(Guid.NewGuid().ToString()); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _postStorageContract.Verify(x => + x.GetPostWithHistory(It.IsAny()), Times.Once); + } + + [Test] + public void GetAllDataOfPost_PostIdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.GetAllDataOfPost(null), + Throws.TypeOf()); + Assert.That(() => + _postBusinessLogicContract.GetAllDataOfPost(string.Empty), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetPostWithHistory(It.IsAny()), Times.Never); + } + + [Test] + public void GetAllDataOfPost_PostIdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.GetAllDataOfPost("id"), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetPostWithHistory(It.IsAny()), Times.Never); + } + + [Test] + public void GetAllDataOfPost_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.GetAllDataOfPost(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetPostWithHistory(It.IsAny()), Times.Once); + } + + [Test] + public void GetAllDataOfPost_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.GetPostWithHistory(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.GetAllDataOfPost(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetPostWithHistory(It.IsAny()), Times.Once); + } + + [Test] + public void GetPostByData_GetById_ReturnRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var record = new PostDataModel(id, "name", PostType.Consultant, 10, + true, DateTime.UtcNow); + _postStorageContract.Setup(x => + x.GetElementById(id)).Returns(record); + //Act + var element = _postBusinessLogicContract.GetPostByData(id); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.Id, Is.EqualTo(id)); + _postStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void GetPostByData_GetByName_ReturnRecord_Test() + { + //Arrange + var postName = "name"; + var record = new PostDataModel(Guid.NewGuid().ToString(), postName, + PostType.Consultant, 10, true, DateTime.UtcNow); + _postStorageContract.Setup(x => + x.GetElementByName(postName)).Returns(record); + //Act + var element = _postBusinessLogicContract.GetPostByData(postName); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.PostName, Is.EqualTo(postName)); + _postStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Once); + } + + [Test] + public void GetPostByData_EmptyData_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.GetPostByData(null), + Throws.TypeOf()); + Assert.That(() => + _postBusinessLogicContract.GetPostByData(string.Empty), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Never); + _postStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Never); + } + + [Test] + public void GetPostByData_GetById_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.GetPostByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + _postStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Never); + } + + [Test] + public void GetPostByData_GetByName_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.GetPostByData("name"), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Never); + _postStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Once); + } + + [Test] + public void GetPostByData_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.GetElementById(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + _postStorageContract.Setup(x => + x.GetElementByName(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.GetPostByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + Assert.That(() => _postBusinessLogicContract.GetPostByData("name"), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + _postStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Once); + } + + [Test] + public void InsertPost_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Supervisor, 10, true, DateTime.UtcNow.AddDays(-1)); + _postStorageContract.Setup(x => + x.AddElement(It.IsAny())) + .Callback((PostDataModel x) => + { + flag = x.Id == record.Id && x.PostName == + record.PostName && x.PostType == record.PostType && x.Salary == record.Salary && + x.ChangeDate == record.ChangeDate; + }); + //Act + _postBusinessLogicContract.InsertPost(record); + //Assert + _postStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void InsertPost_RecordWithExistsData_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new + ElementExistsException("Data", "Data")); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.InsertPost(new(Guid.NewGuid().ToString(), "name", + PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void InsertPost_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.InsertPost(null), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertPost_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.InsertPost(new + PostDataModel("id", "name", PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertPost_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.InsertPost(new(Guid.NewGuid().ToString(), "name", + PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdatePost_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Supervisor, 10, true, DateTime.UtcNow.AddDays(-1)); + _postStorageContract.Setup(x => + x.UpdElement(It.IsAny())) + .Callback((PostDataModel x) => + { + flag = x.Id == record.Id && x.PostName == + record.PostName && x.PostType == record.PostType && x.Salary == record.Salary && + x.ChangeDate == record.ChangeDate; + }); + //Act + _postBusinessLogicContract.UpdatePost(record); + //Assert + _postStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void UpdatePost_RecordWithIncorrectData_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new + ElementNotFoundException("")); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.UpdatePost(new(Guid.NewGuid().ToString(), "name", + PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdatePost_RecordWithExistsData_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new ElementExistsException("Data", "Data")); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.UpdatePost(new(Guid.NewGuid().ToString(), "anme", + PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdatePost_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.UpdatePost(null), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Never); + } + + [Test] + public void UpdatePost_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.UpdatePost(new + PostDataModel("id", "name", PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Never); + } + + [Test] + public void UpdatePost_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.UpdatePost(new(Guid.NewGuid().ToString(), "name", + PostType.Supervisor, 10, true, DateTime.UtcNow)), + Throws.TypeOf()); + _postStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void DeletePost_CorrectRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var flag = false; + _postStorageContract.Setup(x => x.DelElement(It.Is((string x) => x == + id))).Callback(() => { flag = true; }); + //Act + _postBusinessLogicContract.DeletePost(id); + //Assert + _postStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + Assert.That(flag); + } + + [Test] + public void DeletePost_RecordWithIncorrectId_ThrowException_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + _postStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new ElementNotFoundException(id)); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.DeletePost(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } + + [Test] + public void DeletePost_IdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.DeletePost(null), + Throws.TypeOf()); + Assert.That(() => + _postBusinessLogicContract.DeletePost(string.Empty), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void DeletePost_IdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.DeletePost("id"), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void DeletePost_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.DeletePost(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } + + [Test] + public void RestorePost_CorrectRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var flag = false; + _postStorageContract.Setup(x => x.ResElement(It.Is((string x) => x == + id))).Callback(() => { flag = true; }); + //Act + _postBusinessLogicContract.RestorePost(id); + //Assert + _postStorageContract.Verify(x => x.ResElement(It.IsAny()), + Times.Once); + Assert.That(flag); + } + + [Test] + public void RestorePost_RecordWithIncorrectId_ThrowException_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + _postStorageContract.Setup(x => + x.ResElement(It.IsAny())).Throws(new ElementNotFoundException(id)); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.RestorePost(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.ResElement(It.IsAny()), + Times.Once); + } + + [Test] + public void RestorePost_IdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.RestorePost(null), + Throws.TypeOf()); + Assert.That(() => + _postBusinessLogicContract.RestorePost(string.Empty), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.ResElement(It.IsAny()), + Times.Never); + } + + [Test] + public void RestorePost_IdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _postBusinessLogicContract.RestorePost("id"), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.ResElement(It.IsAny()), + Times.Never); + } + + [Test] + public void RestorePost_StorageThrowError_ThrowException_Test() + { + //Arrange + _postStorageContract.Setup(x => + x.ResElement(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _postBusinessLogicContract.RestorePost(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _postStorageContract.Verify(x => x.ResElement(It.IsAny()), + Times.Once); + } +} diff --git a/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/ProductBusinessLogicContractTests.cs b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/ProductBusinessLogicContractTests.cs new file mode 100644 index 0000000..59b0dec --- /dev/null +++ b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/ProductBusinessLogicContractTests.cs @@ -0,0 +1,520 @@ +using Moq; +using North_Bridge_BusinessLogics.Implementations; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Enums; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; + +namespace North_Bridge_Tests.BusinessLogicsContractsTests; + +[TestFixture] +internal class ProductBusinessLogicContractTests +{ + private ProductBusinessLogicContract _productBusinessLogicContract; + + private Mock _productStorageContract; + + [OneTimeSetUp] + public void OneTimeSetUp() + { + _productStorageContract = new Mock(); + _productBusinessLogicContract = new ProductBusinessLogicContract(_productStorageContract.Object, new Mock().Object); + } + + [TearDown] + public void SetUp() + { + _productStorageContract.Reset(); + } + + [Test] + public void GetAllProducts_ReturnListOfRecords_Test() + { + //Arrange + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), "name 1", + ProductType.SystemUnit , 10, false), + new(Guid.NewGuid().ToString(), "name 2", + ProductType.SystemUnit, 10, true), + new(Guid.NewGuid().ToString(), "name 3", + ProductType.SystemUnit, 10, false), + }; + _productStorageContract.Setup(x => x.GetList(It.IsAny())).Returns(listOriginal); + //Act + var listOnlyActive = _productBusinessLogicContract.GetAllProducts(true); + var list = _productBusinessLogicContract.GetAllProducts(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Is.EquivalentTo(listOriginal)); + Assert.That(list, Is.EquivalentTo(listOriginal)); + }); + _productStorageContract.Verify(x => x.GetList(true), + Times.Once); + _productStorageContract.Verify(x => x.GetList(false), + Times.Once); + } + + [Test] + public void GetAllProducts_ReturnEmptyList_Test() + { + //Arrange + _productStorageContract.Setup(x => x.GetList(It.IsAny())).Returns([]); + //Act + var listOnlyActive = _productBusinessLogicContract.GetAllProducts(true); + var list = _productBusinessLogicContract.GetAllProducts(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Has.Count.EqualTo(0)); + Assert.That(list, Has.Count.EqualTo(0)); + }); + _productStorageContract.Verify(x => x.GetList(It.IsAny()), Times.Exactly(2)); + } + + [Test] + public void GetAllProducts_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetAllProducts(It.IsAny()), + Throws.TypeOf()); + _productStorageContract.Verify(x => x.GetList(It.IsAny()), Times.Once); + } + + [Test] + public void GetAllProducts_StorageThrowError_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => x.GetList(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetAllProducts(It.IsAny()), + Throws.TypeOf()); + _productStorageContract.Verify(x => x.GetList(It.IsAny()), Times.Once); + } + + [Test] + public void GetProductHistoryByProduct_ReturnListOfRecords_Test() + { + //Arrange + var productId = Guid.NewGuid().ToString(); + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), 10), + new(Guid.NewGuid().ToString(), 15), + new(Guid.NewGuid().ToString(), 10), + }; + _productStorageContract.Setup(x => + x.GetHistoryByProductId(It.IsAny())).Returns(listOriginal); + //Act + var list = _productBusinessLogicContract.GetProductHistoryByProduct(productId); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Is.EquivalentTo(listOriginal)); + _productStorageContract.Verify(x => + x.GetHistoryByProductId(productId), Times.Once); + } + + [Test] + public void GetProductHistoryByProduct_ReturnEmptyList_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.GetHistoryByProductId(It.IsAny())).Returns([]); + //Act + var list = _productBusinessLogicContract.GetProductHistoryByProduct(Guid.NewGuid().ToString()); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _productStorageContract.Verify(x => + x.GetHistoryByProductId(It.IsAny()), Times.Once); + } + + [Test] + public void + GetProductHistoryByProduct_ProductIdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductHistoryByProduct(null), + Throws.TypeOf()); + Assert.That(() => + _productBusinessLogicContract.GetProductHistoryByProduct(string.Empty), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetHistoryByProductId(It.IsAny()), Times.Never); + } + + [Test] + public void GetProductHistoryByProduct_ProductIdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductHistoryByProduct("productId"), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetHistoryByProductId(It.IsAny()), Times.Never); + } + + [Test] + public void GetProductHistoryByProduct_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductHistoryByProduct(Guid.NewGuid().ToString()), Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetHistoryByProductId(It.IsAny()), Times.Once); + } + + [Test] + public void + GetProductHistoryByProduct_StorageThrowError_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.GetHistoryByProductId(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductHistoryByProduct(Guid.NewGuid().ToString()), Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetHistoryByProductId(It.IsAny()), Times.Once); + } + + [Test] + public void GetProductByData_GetById_ReturnRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var record = new ProductDataModel(id, "name", ProductType.SystemUnit, + 10, false); + _productStorageContract.Setup(x => + x.GetElementById(id)).Returns(record); + //Act + var element = _productBusinessLogicContract.GetProductByData(id); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.Id, Is.EqualTo(id)); + _productStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void GetProductByData_GetByName_ReturnRecord_Test() + { + //Arrange + var name = "name"; + var record = new ProductDataModel(Guid.NewGuid().ToString(), name, + ProductType.SystemUnit, 10, false); + _productStorageContract.Setup(x => + x.GetElementByName(name)).Returns(record); + //Act + var element = _productBusinessLogicContract.GetProductByData(name); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.ProductName, Is.EqualTo(name)); + _productStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Once); + } + + [Test] + public void GetProductByData_EmptyData_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductByData(null), + Throws.TypeOf()); + Assert.That(() => + _productBusinessLogicContract.GetProductByData(string.Empty), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Never); + _productStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Never); + } + + [Test] + public void GetProductByData_GetById_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void GetProductByData_GetByName_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductByData("name"), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Once); + } + + [Test] + public void GetProductByData_StorageThrowError_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.GetElementById(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + _productStorageContract.Setup(x => + x.GetElementByName(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.GetProductByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + Assert.That(() => + _productBusinessLogicContract.GetProductByData("name"), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + _productStorageContract.Verify(x => + x.GetElementByName(It.IsAny()), Times.Once); + } + + [Test] + public void InsertProduct_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new ProductDataModel(Guid.NewGuid().ToString(), "name", + ProductType.SystemUnit, 10, false); + _productStorageContract.Setup(x => + x.AddElement(It.IsAny())) + .Callback((ProductDataModel x) => + { + flag = x.Id == record.Id && x.ProductName == + record.ProductName && x.ProductType == record.ProductType && + x.Price == record.Price && x.IsDeleted == record.IsDeleted; + }); + //Act + _productBusinessLogicContract.InsertProduct(record); + //Assert + _productStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void InsertProduct_RecordWithExistsData_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new ElementExistsException("Data", "Data")); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.InsertProduct(new(Guid.NewGuid().ToString(), + "name", ProductType.SystemUnit, 10, false)), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void InsertProduct_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _productBusinessLogicContract.InsertProduct(null), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertProduct_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _productBusinessLogicContract.InsertProduct(new + ProductDataModel("id", "name", ProductType.SystemUnit, + 10, false)), Throws.TypeOf()); + _productStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertProduct_StorageThrowError_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.InsertProduct(new(Guid.NewGuid().ToString(), + "name", ProductType.SystemUnit, 10, false)), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdateProduct_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new ProductDataModel(Guid.NewGuid().ToString(), "name", + ProductType.SystemUnit, 10, false); + _productStorageContract.Setup(x => + x.UpdElement(It.IsAny())) + .Callback((ProductDataModel x) => + { + flag = x.Id == record.Id && x.ProductName == + record.ProductName && x.ProductType == record.ProductType && + x.Price == record.Price && x.IsDeleted == record.IsDeleted; + }); + //Act + _productBusinessLogicContract.UpdateProduct(record); + //Assert + _productStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void UpdateProduct_RecordWithIncorrectData_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new + ElementNotFoundException("")); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.UpdateProduct(new(Guid.NewGuid().ToString(), + "name", ProductType.SystemUnit, 10, false)), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdateProduct_RecordWithExistsData_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new + ElementExistsException("Data", "Data")); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.UpdateProduct(new(Guid.NewGuid().ToString(), + "anme", ProductType.SystemUnit, 10, false)), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdateProduct_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _productBusinessLogicContract.UpdateProduct(null), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Never); + } + + [Test] + public void UpdateProduct_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _productBusinessLogicContract.UpdateProduct(new ProductDataModel("id", "name", ProductType.SystemUnit, + 10, false)), Throws.TypeOf()); + _productStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Never); + } + + [Test] + public void UpdateProduct_StorageThrowError_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.UpdateProduct(new(Guid.NewGuid().ToString(), + "name", ProductType.SystemUnit, 10, false)), + Throws.TypeOf()); + _productStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void DeleteProduct_CorrectRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var flag = false; + _productStorageContract.Setup(x => x.DelElement(It.Is((string x) => x == id))).Callback(() => { flag = true; }); + //Act + _productBusinessLogicContract.DeleteProduct(id); + //Assert + _productStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + Assert.That(flag); + } + + [Test] + public void DeleteProduct_RecordWithIncorrectId_ThrowException_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + _productStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new ElementNotFoundException(id)); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.DeleteProduct(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _productStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } + + [Test] + public void DeleteProduct_IdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _productBusinessLogicContract.DeleteProduct(null), + Throws.TypeOf()); + Assert.That(() => + _productBusinessLogicContract.DeleteProduct(string.Empty), + Throws.TypeOf()); + _productStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void DeleteProduct_IdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _productBusinessLogicContract.DeleteProduct("id"), + Throws.TypeOf()); + _productStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void DeleteProduct_StorageThrowError_ThrowException_Test() + { + //Arrange + _productStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _productBusinessLogicContract.DeleteProduct(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _productStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/SalaryBusinessLogicContractTests.cs b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/SalaryBusinessLogicContractTests.cs new file mode 100644 index 0000000..1f5d325 --- /dev/null +++ b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/SalaryBusinessLogicContractTests.cs @@ -0,0 +1,476 @@ +using Moq; +using North_Bridge_BusinessLogics.Implementations; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Enums; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; + +namespace North_Bridge_Tests.BusinessLogicsContractsTests; + +[TestFixture] +internal class SalaryBusinessLogicContractTests +{ + private SalaryBusinessLogicContract _salaryBusinessLogicContract; + + private Mock _salaryStorageContract; + + private Mock _saleStorageContract; + + private Mock _postStorageContract; + + private Mock _workerStorageContract; + + [OneTimeSetUp] + public void OneTimeSetUp() + { + _salaryStorageContract = new Mock(); + + _saleStorageContract = new Mock(); + + _postStorageContract = new Mock(); + + _workerStorageContract = new Mock(); + + _salaryBusinessLogicContract = new SalaryBusinessLogicContract(_salaryStorageContract.Object, _saleStorageContract.Object, _postStorageContract.Object, _workerStorageContract.Object, new Mock().Object); + } + + [TearDown] + public void SetUp() + { + _salaryStorageContract.Reset(); + _saleStorageContract.Reset(); + _postStorageContract.Reset(); + _workerStorageContract.Reset(); + } + + [Test] + public void GetAllSalaries_ReturnListOfRecords_Test() + { + //Arrange + var startDate = DateTime.UtcNow; + var endDate = DateTime.UtcNow.AddDays(1); + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), DateTime.UtcNow, 10), + new(Guid.NewGuid().ToString(), DateTime.UtcNow.AddDays(1), 14), + new(Guid.NewGuid().ToString(), DateTime.UtcNow.AddDays(-1), 30), + }; + _salaryStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var list = + _salaryBusinessLogicContract.GetAllSalariesByPeriod(startDate, endDate); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Is.EquivalentTo(listOriginal)); + _salaryStorageContract.Verify(x => x.GetList(startDate, endDate, + null), Times.Once); + } + + [Test] + public void GetAllSalaries_ReturnEmptyList_Test() + { + //Arrange + _salaryStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny())).Returns([]); + //Act + var list = + _salaryBusinessLogicContract.GetAllSalariesByPeriod(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalaries_IncorrectDates_ThrowException_Test() + { + //Arrange + var dateTime = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriod(dateTime, dateTime), + Throws.TypeOf()); + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriod(dateTime, + dateTime.AddSeconds(-1)), Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalaries_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriod(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalaries_StorageThrowError_ThrowException_Test() + { + //Arrange + _salaryStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriod(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalariesByWorker_ReturnListOfRecords_Test() + { + //Arrange + var startDate = DateTime.UtcNow; + var endDate = DateTime.UtcNow.AddDays(1); + var workerId = Guid.NewGuid().ToString(); + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), DateTime.UtcNow, 10), + new(Guid.NewGuid().ToString(), DateTime.UtcNow.AddDays(1), 14), + new(Guid.NewGuid().ToString(), DateTime.UtcNow.AddDays(-1), 30), + }; + _salaryStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var list = _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(startDate, endDate, + workerId); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Is.EquivalentTo(listOriginal)); + _salaryStorageContract.Verify(x => x.GetList(startDate, endDate, + workerId), Times.Once); + } + + [Test] + public void GetAllSalariesByWorker_ReturnEmptyList_Test() + { + //Arrange + _salaryStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny())).Returns([]); + //Act + var list = _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), Guid.NewGuid().ToString()); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalariesByWorker_IncorrectDates_ThrowException_Test() + { + //Arrange + var dateTime = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(dateTime, dateTime, + Guid.NewGuid().ToString()), Throws.TypeOf()); + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(dateTime, + dateTime.AddSeconds(-1), Guid.NewGuid().ToString()), + Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void + GetAllSalariesByWorker_WorkerIdIsNUllOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), null), Throws.TypeOf()); + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), string.Empty), + Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalariesByWorker_WorkerIdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), "workerId"), Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalariesByWorker_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), Guid.NewGuid().ToString()), + Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalariesByWorker_StorageThrowError_ThrowException_Test() + { + //Arrange + _salaryStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.GetAllSalariesByPeriodByWorker(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), Guid.NewGuid().ToString()), + Throws.TypeOf()); + _salaryStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void CalculateSalaryByMounth_CalculateSalary_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + var saleSum = 200.0; + var postSalary = 2000.0; + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([new SaleDataModel(Guid.NewGuid().ToString(), + workerId, saleSum, false, [])]); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, postSalary, true, DateTime.UtcNow)); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns([new WorkerDataModel(workerId, "Test", + "example@example.com",Guid.NewGuid().ToString(), DateTime.UtcNow, DateTime.UtcNow, false)]); + var sum = 0.0; + var expectedSum = postSalary + saleSum * 0.1; + _salaryStorageContract.Setup(x => + x.AddElement(It.IsAny())) + .Callback((SalaryDataModel x) => + { + sum = x.Salary; + }); + //Act + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow); + //Assert + Assert.That(sum, Is.EqualTo(expectedSum)); + } + + [Test] + public void CalculateSalaryByMounth_WithSeveralWorkers_Test() + { + //Arrange + var worker1Id = Guid.NewGuid().ToString(); + var worker2Id = Guid.NewGuid().ToString(); + var worker3Id = Guid.NewGuid().ToString(); + var list = new List() + { + new(worker1Id, "Test","example@example.com", Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow, false), + new(worker2Id, "Test","example@example.com", Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow, false), + new(worker3Id, "Test","example@example.com", Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow, false) + }; + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([new SaleDataModel(Guid.NewGuid().ToString(), + worker1Id, 1, false, []), + new SaleDataModel(Guid.NewGuid().ToString(), worker1Id, + 1, false, []), + new SaleDataModel(Guid.NewGuid().ToString(), worker2Id, + 1, false, []), + new SaleDataModel(Guid.NewGuid().ToString(), worker3Id, + 1, false, []), + new SaleDataModel(Guid.NewGuid().ToString(), worker3Id, + 1, false, [])]); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, 2000, true, DateTime.UtcNow)); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns(list); + //Act + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow); + //Assert + _salaryStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Exactly(list.Count)); + } + + [Test] + public void CalculateSalaryByMounth_WithoitSalesByWorker_Test() + { + //Arrange + var postSalary = 2000.0; + var workerId = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([]); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, postSalary, true, DateTime.UtcNow)); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns([new WorkerDataModel(workerId, "Test", + "example@example.com", Guid.NewGuid().ToString(), DateTime.UtcNow, DateTime.UtcNow, false)]); + var sum = 0.0; + var expectedSum = postSalary; + _salaryStorageContract.Setup(x => + x.AddElement(It.IsAny())) + .Callback((SalaryDataModel x) => + { + sum = x.Salary; + }); + //Act + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow); + //Assert + Assert.That(sum, Is.EqualTo(expectedSum)); + } + + [Test] + public void + CalculateSalaryByMounth_SaleStorageReturnNull_ThrowException_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, 2000, true, DateTime.UtcNow)); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns([new WorkerDataModel(workerId, "Test", + "example@example.com", Guid.NewGuid().ToString(), DateTime.UtcNow, DateTime.UtcNow, false)]); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow), + Throws.TypeOf()); + } + + [Test] + public void + CalculateSalaryByMounth_PostStorageReturnNull_ThrowException_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([new SaleDataModel(Guid.NewGuid().ToString(), + workerId, 200, false, [])]); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns([new WorkerDataModel(workerId, "Test", + "example@example.com", Guid.NewGuid().ToString(), DateTime.UtcNow, DateTime.UtcNow, false)]); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow), + Throws.TypeOf()); + } + + [Test] + public void + CalculateSalaryByMounth_WorkerStorageReturnNull_ThrowException_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([new SaleDataModel(Guid.NewGuid().ToString(), + workerId, 200, false, [])]); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, 2000, true, DateTime.UtcNow)); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow), + Throws.TypeOf()); + } + + [Test] + public void + CalculateSalaryByMounth_SaleStorageThrowException_ThrowException_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Throws(new StorageException(new InvalidOperationException())); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, 2000, true, DateTime.UtcNow)); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns([new WorkerDataModel(workerId, "Test", + "example@example.com", Guid.NewGuid().ToString(), DateTime.UtcNow, DateTime.UtcNow, false)]); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow), + Throws.TypeOf()); + } + + [Test] + public void + CalculateSalaryByMounth_PostStorageThrowException_ThrowException_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([new SaleDataModel(Guid.NewGuid().ToString(), + workerId, 200, false, [])]); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Throws(new StorageException(new InvalidOperationException())); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Returns([new WorkerDataModel(workerId, "Test", + "example@example.com", Guid.NewGuid().ToString(), DateTime.UtcNow, DateTime.UtcNow, false)]); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow), + Throws.TypeOf()); + } + + [Test] + public void + CalculateSalaryByMounth_WorkerStorageThrowException_ThrowException_Test() + { + //Arrange + var workerId = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Returns([new SaleDataModel(Guid.NewGuid().ToString(), + workerId, 200, false, [])]); + _postStorageContract.Setup(x => x.GetElementById(It.IsAny())) + .Returns(new PostDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, 2000, true, DateTime.UtcNow)); + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())) + .Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _salaryBusinessLogicContract.CalculateSalaryByMounth(DateTime.UtcNow), + Throws.TypeOf()); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/SaleBusinessLogicContractTests.cs b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/SaleBusinessLogicContractTests.cs new file mode 100644 index 0000000..dc9dde0 --- /dev/null +++ b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/SaleBusinessLogicContractTests.cs @@ -0,0 +1,577 @@ +using Moq; +using North_Bridge_BusinessLogics.Implementations; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; + +namespace North_Bridge_Tests.BusinessLogicsContractsTests; + +[TestFixture] +internal class SaleBusinessLogicContractTests +{ + private SaleBusinessLogicContract _saleBusinessLogicContract; + + private Mock _saleStorageContract; + + [OneTimeSetUp] + public void OneTimeSetUp() + { + _saleStorageContract = new Mock(); + _saleBusinessLogicContract = new SaleBusinessLogicContract(_saleStorageContract.Object, new Mock().Object); + } + + [TearDown] + public void SetUp() + { + _saleStorageContract.Reset(); + } + + [Test] + public void GetAllSalesByPeriod_ReturnListOfRecords_Test() + { + //Arrange + var date = DateTime.UtcNow; + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, + [new ProductForSaleDataModel(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 5)]), + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, []), + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, []), + }; + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var list = _saleBusinessLogicContract.GetAllSalesByPeriod(date, + date.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Is.EquivalentTo(listOriginal)); + _saleStorageContract.Verify(x => x.GetList(date, date.AddDays(1), + null, null), Times.Once); + } + + [Test] + public void GetAllSalesByPeriod_ReturnEmptyList_Test() + { + //Arrange + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Returns([]); + //Act + var list = _saleBusinessLogicContract.GetAllSalesByPeriod(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalesByPeriod_IncorrectDates_ThrowException_Test() + { + //Arrange + var date = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByPeriod(date, date), + Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByPeriod(date, date.AddSeconds(-1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalesByPeriod_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByPeriod(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalesByPeriod_StorageThrowError_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByPeriod(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalesByWorkerByPeriod_ReturnListOfRecords_Test() + { + //Arrange + var date = DateTime.UtcNow; + var workerId = Guid.NewGuid().ToString(); + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, + [new ProductForSaleDataModel(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 5)]), + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, []), + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, []), + }; + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var list = _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(workerId, date, + date.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Is.EquivalentTo(listOriginal)); + _saleStorageContract.Verify(x => x.GetList(date, date.AddDays(1), + workerId, null), Times.Once); + } + + [Test] + public void GetAllSalesByWorkerByPeriod_ReturnEmptyList_Test() + { + //Arrange + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Returns([]); + //Act + var list = _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllSalesByWorkerByPeriod_IncorrectDates_ThrowException_Test() + { + //Arrange + var date = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(Guid.NewGuid().ToString(), + date, date), Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(Guid.NewGuid().ToString(), + date, date.AddSeconds(-1)), Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void + GetAllSalesByWorkerByPeriod_WorkerIdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(null, DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(string.Empty, + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalesByWorkerByPeriod_WorkerIdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod("workerId", + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalesByWorkerByPeriod_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllSalesByWorkerByPeriod_StorageThrowError_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())) + .Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByWorkerByPeriod(Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllSalesByProductByPeriod_ReturnListOfRecords_Test() + { + //Arrange + var date = DateTime.UtcNow; + var productId = Guid.NewGuid().ToString(); + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, + [new ProductForSaleDataModel(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 5)]), + new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, []),new(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), + 10, false, []), + }; + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var list = _saleBusinessLogicContract.GetAllSalesByProductByPeriod(productId, date, + date.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Is.EquivalentTo(listOriginal)); + _saleStorageContract.Verify(x => x.GetList(date, date.AddDays(1), + null, productId), Times.Once); + } + + [Test] + public void GetAllSalesByProductByPeriod_ReturnEmptyList_Test() + { + //Arrange + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Returns([]); + //Act + var list = _saleBusinessLogicContract.GetAllSalesByProductByPeriod(Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)); + //Assert + Assert.That(list, Is.Not.Null); + Assert.That(list, Has.Count.EqualTo(0)); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllSalesByProductByPeriod_IncorrectDates_ThrowException_Test() + { + //Arrange + var date = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod(Guid.NewGuid().ToString() + , date, date), Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod(Guid.NewGuid().ToString() + , date, date.AddSeconds(-1)), Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void + GetAllSalesByProductByPeriod_ProductIdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod(null, DateTime.UtcNow, + DateTime.UtcNow.AddDays(1)), Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod(string.Empty, + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void + GetAllSalesByProductByPeriod_ProductIdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod("productId", + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllSalesByProductByPeriod_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod(Guid.NewGuid().ToString() + , DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllSalesByProductByPeriod_StorageThrowError_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetAllSalesByProductByPeriod(Guid.NewGuid().ToString(), + DateTime.UtcNow, DateTime.UtcNow.AddDays(1)), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetSaleByData_GetById_ReturnRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var record = new SaleDataModel(id, Guid.NewGuid().ToString(), + 10, false, + [new ProductForSaleDataModel(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 5)]); + _saleStorageContract.Setup(x => + x.GetElementById(id)).Returns(record); + //Act + var element = _saleBusinessLogicContract.GetSaleByData(id); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.Id, Is.EqualTo(id)); + _saleStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void GetSaleByData_EmptyData_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _saleBusinessLogicContract.GetSaleByData(null), + Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.GetSaleByData(string.Empty), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Never); + } + + [Test] + public void GetSaleByData_IdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _saleBusinessLogicContract.GetSaleByData("saleId"), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Never); + } + + [Test] + public void GetSaleByData_GetById_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetSaleByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void GetSaleByData_StorageThrowError_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => + x.GetElementById(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.GetSaleByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void InsertSale_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new SaleDataModel(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 10, + false, [new ProductForSaleDataModel(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 5)]); + _saleStorageContract.Setup(x => + x.AddElement(It.IsAny())) + .Callback((SaleDataModel x) => + { + flag = x.Id == record.Id && x.WorkerId == record.WorkerId && + x.SaleDate == record.SaleDate && x.Sum == record.Sum && + x.IsCancel == record.IsCancel && x.Products.Count == + record.Products.Count && + x.Products.First().ProductId == + record.Products.First().ProductId && + x.Products.First().SaleId == + record.Products.First().SaleId && + x.Products.First().Count == + record.Products.First().Count; + }); + //Act + _saleBusinessLogicContract.InsertSale(record); + //Assert + _saleStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void InsertSale_RecordWithExistsData_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new + ElementExistsException("Data", "Data")); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.InsertSale(new(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 10, false, + [new ProductForSaleDataModel(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(),5)])), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void InsertSale_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _saleBusinessLogicContract.InsertSale(null), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertSale_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _saleBusinessLogicContract.InsertSale(new + SaleDataModel("id", Guid.NewGuid().ToString(), 10, + false, [])), Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertSale_StorageThrowError_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.InsertSale(new(Guid.NewGuid().ToString(), + Guid.NewGuid().ToString(), 10, false, + [new ProductForSaleDataModel(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(),5)])), + Throws.TypeOf()); + _saleStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void CancelSale_CorrectRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var flag = false; + _saleStorageContract.Setup(x => x.DelElement(It.Is((string x) => x == + id))).Callback(() => { flag = true; }); + //Act + _saleBusinessLogicContract.CancelSale(id); + //Assert + _saleStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + Assert.That(flag); + } + + [Test] + public void CancelSale_RecordWithIncorrectId_ThrowException_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + _saleStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new ElementNotFoundException(id)); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.CancelSale(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } + + [Test] + public void CancelSale_IdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _saleBusinessLogicContract.CancelSale(null), + Throws.TypeOf()); + Assert.That(() => + _saleBusinessLogicContract.CancelSale(string.Empty), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void CancelSale_IdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _saleBusinessLogicContract.CancelSale("id"), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void CancelSale_StorageThrowError_ThrowException_Test() + { + //Arrange + _saleStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _saleBusinessLogicContract.CancelSale(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _saleStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/WorkerBusinessLogicContractTests.cs b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/WorkerBusinessLogicContractTests.cs new file mode 100644 index 0000000..af09f0e --- /dev/null +++ b/North_Bridge/North_Bridge_Tests/BusinessLogicsContractsTests/WorkerBusinessLogicContractTests.cs @@ -0,0 +1,785 @@ +using Moq; +using North_Bridge_BusinessLogics.Implementations; +using North_Bridge_Contract.DataModels; +using North_Bridge_Contract.Exceptions; +using North_Bridge_Contract.Extentions; +using North_Bridge_Contract.StoragesContracts; +using Microsoft.Extensions.Logging; + +namespace North_Bridge_Tests.BusinessLogicsContractsTests; + +[TestFixture] +internal class WorkerBusinessLogicContractTests +{ + private WorkerBusinessLogicContract _workerBusinessLogicContract; + + private Mock _workerStorageContract; + + [OneTimeSetUp] + public void OneTimeSetUp() + { + _workerStorageContract = new Mock(); + + _workerBusinessLogicContract = new WorkerBusinessLogicContract(_workerStorageContract.Object, new Mock().Object); + } + + [TearDown] + public void SetUp() + { + _workerStorageContract.Reset(); + } + + [Test] + public void GetAllWorkers_ReturnListOfRecords_Test() + { + //Arrange + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), "fio 1", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + new(Guid.NewGuid().ToString(), "fio 2", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + true), + new(Guid.NewGuid().ToString(), "fio 3", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + }; + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkers(true); + var list = _workerBusinessLogicContract.GetAllWorkers(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Is.EquivalentTo(listOriginal)); + Assert.That(list, Is.EquivalentTo(listOriginal)); + }); + _workerStorageContract.Verify(x => x.GetList(true, null, null, null, + null, null), Times.Once); + _workerStorageContract.Verify(x => x.GetList(false, null, null, null, + null, null), Times.Once); + } + + [Test] + public void GetAllWorkers_ReturnEmptyList_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns([]); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkers(true); + var list = _workerBusinessLogicContract.GetAllWorkers(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Has.Count.EqualTo(0)); + Assert.That(list, Has.Count.EqualTo(0)); + }); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), null, + null, null, null, null), Times.Exactly(2)); + } + + [Test] + public void GetAllWorkers_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkers(It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllWorkers_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkers(It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), null, + null, null, null, null), Times.Once); + } + + [Test] + public void GetAllWorkersByPost_ReturnListOfRecords_Test() + { + //Arrange + var postId = Guid.NewGuid().ToString(); + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), "fio 1", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + new(Guid.NewGuid().ToString(), "fio 2", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + true), + new(Guid.NewGuid().ToString(), "fio 3", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + }; + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkersByPost(postId, true); + var list = _workerBusinessLogicContract.GetAllWorkersByPost(postId, + false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Is.EquivalentTo(listOriginal)); + Assert.That(list, Is.EquivalentTo(listOriginal)); + }); + _workerStorageContract.Verify(x => x.GetList(true, postId, null, + null, null, null), Times.Once); + _workerStorageContract.Verify(x => x.GetList(false, postId, null, + null, null, null), Times.Once); + } + + [Test] + public void GetAllWorkersByPost_ReturnEmptyList_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns([]); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkersByPost(Guid.NewGuid().ToString(), + true); + var list = _workerBusinessLogicContract.GetAllWorkersByPost(Guid.NewGuid().ToString(), + false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Has.Count.EqualTo(0)); + Assert.That(list, Has.Count.EqualTo(0)); + }); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Exactly(2)); + } + + [Test] + public void GetAllWorkersByPost_PostIdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByPost(null, It.IsAny()), + Throws.TypeOf()); + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByPost(string.Empty, It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllWorkersByPost_PostIdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByPost("postId", It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllWorkersByPost_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByPost(Guid.NewGuid().ToString(), + It.IsAny()), Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllWorkersByPost_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByPost(Guid.NewGuid().ToString(), + It.IsAny()), Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllWorkersByBirthDate_ReturnListOfRecords_Test() + { + //Arrange + var date = DateTime.UtcNow; + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), "fio 1", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + new(Guid.NewGuid().ToString(), "fio 2", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + true), + new(Guid.NewGuid().ToString(), "fio 3", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + }; + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkersByBirthDate(date, date.AddDays(1), + true); + var list = _workerBusinessLogicContract.GetAllWorkersByBirthDate(date, date.AddDays(1), + false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Is.EquivalentTo(listOriginal)); + Assert.That(list, Is.EquivalentTo(listOriginal)); + }); + _workerStorageContract.Verify(x => x.GetList(true, null, date, + date.AddDays(1), null, null), Times.Once); + _workerStorageContract.Verify(x => x.GetList(false, null, date, + date.AddDays(1), null, null), Times.Once); + } + + [Test] + public void GetAllWorkersByBirthDate_ReturnEmptyList_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns([]); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkersByBirthDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), true); + var list = _workerBusinessLogicContract.GetAllWorkers(false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Has.Count.EqualTo(0)); + Assert.That(list, Has.Count.EqualTo(0)); + }); + _workerStorageContract.Verify(x => x.GetList(true, null, + It.IsAny(), It.IsAny(), null, null), Times.Once); + _workerStorageContract.Verify(x => x.GetList(false, null, + It.IsAny(), It.IsAny(), null, null), Times.Once); + } + + [Test] + public void GetAllWorkersByBirthDate_IncorrectDates_ThrowException_Test() + { + //Arrange + var date = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByBirthDate(date, date, + It.IsAny()), Throws.TypeOf()); + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByBirthDate(date, date.AddSeconds(-1), + It.IsAny()), Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllWorkersByBirthDate_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByBirthDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllWorkersByBirthDate_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByBirthDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetAllWorkersByEmploymentDate_ReturnListOfRecords_Test() + { + //Arrange + var date = DateTime.UtcNow; + var listOriginal = new List() + { + new(Guid.NewGuid().ToString(), "fio 1", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + new(Guid.NewGuid().ToString(), "fio 2", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + true), + new(Guid.NewGuid().ToString(), "fio 3", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false), + }; + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns(listOriginal); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(date, date.AddDays(1), + true); + var list = _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(date, date.AddDays(1), + false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Is.EquivalentTo(listOriginal)); + Assert.That(list, Is.EquivalentTo(listOriginal)); + }); + _workerStorageContract.Verify(x => x.GetList(true, null, null, null, + date, date.AddDays(1)), Times.Once); + _workerStorageContract.Verify(x => x.GetList(false, null, null, null, + date, date.AddDays(1)), Times.Once); + } + + [Test] + public void GetAllWorkersByEmploymentDate_ReturnEmptyList_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Returns([]); + //Act + var listOnlyActive = _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), true); + var list = _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), false); + //Assert + Assert.Multiple(() => + { + Assert.That(listOnlyActive, Is.Not.Null); + Assert.That(list, Is.Not.Null); + Assert.That(listOnlyActive, Has.Count.EqualTo(0)); + Assert.That(list, Has.Count.EqualTo(0)); + }); + _workerStorageContract.Verify(x => x.GetList(true, null, null, null, + It.IsAny(), It.IsAny()), Times.Once); + _workerStorageContract.Verify(x => x.GetList(false, null, null, null, + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllWorkersByEmploymentDate_IncorrectDates_ThrowException_Test() + { + //Arrange + var date = DateTime.UtcNow; + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(date, date, + It.IsAny()), Throws.TypeOf()); + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(date, + date.AddSeconds(-1), It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Never); + } + + [Test] + public void GetAllWorkersByEmploymentDate_ReturnNull_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void + GetAllWorkersByEmploymentDate_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetAllWorkersByEmploymentDate(DateTime.UtcNow, + DateTime.UtcNow.AddDays(1), It.IsAny()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.GetList(It.IsAny(), + It.IsAny(), It.IsAny(), It.IsAny(), + It.IsAny(), It.IsAny()), Times.Once); + } + + [Test] + public void GetWorkerByData_GetById_ReturnRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var record = new WorkerDataModel(id, "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false); + _workerStorageContract.Setup(x => + x.GetElementById(id)).Returns(record); + //Act + var element = _workerBusinessLogicContract.GetWorkerByData(id); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.Id, Is.EqualTo(id)); + _workerStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + } + + [Test] + public void GetWorkerByData_GetByFio_ReturnRecord_Test() + { + //Arrange + var fio = "fio"; + var record = new WorkerDataModel(Guid.NewGuid().ToString(), fio, "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-16).AddDays(-1), DateTime.Now, + false); + _workerStorageContract.Setup(x => + x.GetElementByFIO(fio)).Returns(record); + //Act + var element = _workerBusinessLogicContract.GetWorkerByData(fio); + //Assert + Assert.That(element, Is.Not.Null); + Assert.That(element.FIO, Is.EqualTo(fio)); + _workerStorageContract.Verify(x => + x.GetElementByFIO(It.IsAny()), Times.Once); + } + + [Test] + public void GetWorkerByData_EmptyData_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.GetWorkerByData(null), + Throws.TypeOf()); + Assert.That(() => + _workerBusinessLogicContract.GetWorkerByData(string.Empty), + Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Never); + _workerStorageContract.Verify(x => + x.GetElementByFIO(It.IsAny()), Times.Never); + } + + [Test] + public void GetWorkerByData_GetById_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetWorkerByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + _workerStorageContract.Verify(x => + x.GetElementByFIO(It.IsAny()), Times.Never); + } + + [Test] + public void GetWorkerByData_GetByFio_NotFoundRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetWorkerByData("fio"), + Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Never); + _workerStorageContract.Verify(x => + x.GetElementByFIO(It.IsAny()), Times.Once); + } + + [Test] + public void GetWorkerByData_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => + x.GetElementById(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + _workerStorageContract.Setup(x => + x.GetElementByFIO(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.GetWorkerByData(Guid.NewGuid().ToString()), + Throws.TypeOf()); + Assert.That(() => + _workerBusinessLogicContract.GetWorkerByData("fio"), + Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.GetElementById(It.IsAny()), Times.Once); + _workerStorageContract.Verify(x => + x.GetElementByFIO(It.IsAny()), Times.Once); + } + + [Test] + public void InsertWorker_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new WorkerDataModel(Guid.NewGuid().ToString(), "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18).AddDays(-1), DateTime.Now, + false); + _workerStorageContract.Setup(x => + x.AddElement(It.IsAny())) + .Callback((WorkerDataModel x) => + { + flag = x.Id == record.Id && x.FIO == record.FIO && x.Email == record.Email && + x.PostId == record.PostId && x.BirthDate == record.BirthDate && + x.EmploymentDate == record.EmploymentDate && + x.IsDeleted == record.IsDeleted; + }); + //Act + _workerBusinessLogicContract.InsertWorker(record); + //Assert + _workerStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void InsertWorker_RecordWithExistsData_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new ElementExistsException("Data", "Data")); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.InsertWorker(new(Guid.NewGuid().ToString(), "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18).AddDays(-1), DateTime.Now, + false)), Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void InsertWorker_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.InsertWorker(null), + Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertWorker_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.InsertWorker(new WorkerDataModel("id", + "fio", "example@example.com", Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18) + .AddDays(-1), DateTime.Now, false)), Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Never); + } + + [Test] + public void InsertWorker_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => + x.AddElement(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.InsertWorker(new(Guid.NewGuid().ToString(), "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18).AddDays(-1), DateTime.Now, + false)), Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.AddElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdateWorker_CorrectRecord_Test() + { + //Arrange + var flag = false; + var record = new WorkerDataModel(Guid.NewGuid().ToString(), "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18).AddDays(-1), DateTime.Now, + false); + _workerStorageContract.Setup(x => + x.UpdElement(It.IsAny())) + .Callback((WorkerDataModel x) => + { + flag = x.Id == record.Id && x.FIO == record.FIO && x.Email == record.Email && + x.PostId == record.PostId && x.BirthDate == record.BirthDate && + x.EmploymentDate == record.EmploymentDate && + x.IsDeleted == record.IsDeleted; + }); + //Act + _workerBusinessLogicContract.UpdateWorker(record); + //Assert + _workerStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + Assert.That(flag); + } + + [Test] + public void UpdateWorker_RecordWithIncorrectData_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new ElementNotFoundException("")); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.UpdateWorker(new(Guid.NewGuid().ToString(), "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18).AddDays(-1), DateTime.Now, + false)), Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void UpdateWorker_NullRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.UpdateWorker(null), + Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Never); + } + + [Test] + public void UpdateWorker_InvalidRecord_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.UpdateWorker(new + WorkerDataModel("id", "fio", "example@example.com", Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18) + .AddDays(-1), DateTime.Now, false)), Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Never); + } + + [Test] + public void UpdateWorker_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => + x.UpdElement(It.IsAny())).Throws(new StorageException(new InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.UpdateWorker(new(Guid.NewGuid().ToString(), "fio", "example@example.com", + Guid.NewGuid().ToString(), DateTime.Now.AddYears(-18).AddDays(-1), DateTime.Now, + false)), Throws.TypeOf()); + _workerStorageContract.Verify(x => + x.UpdElement(It.IsAny()), Times.Once); + } + + [Test] + public void DeleteWorker_CorrectRecord_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + var flag = false; + _workerStorageContract.Setup(x => x.DelElement(It.Is((string x) => x== id))) + .Callback(() => { flag = true; }); + //Act + _workerBusinessLogicContract.DeleteWorker(id); + //Assert + _workerStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + Assert.That(flag); + } + + [Test] + public void DeleteWorker_RecordWithIncorrectId_ThrowException_Test() + { + //Arrange + var id = Guid.NewGuid().ToString(); + _workerStorageContract.Setup(x => x.DelElement(It.Is((string x) => x != id))) + .Throws(new ElementNotFoundException(id)); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.DeleteWorker(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } + + [Test] + public void DeleteWorker_IdIsNullOrEmpty_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.DeleteWorker(null), + Throws.TypeOf()); + Assert.That(() => + _workerBusinessLogicContract.DeleteWorker(string.Empty), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void DeleteWorker_IdIsNotGuid_ThrowException_Test() + { + //Act&Assert + Assert.That(() => _workerBusinessLogicContract.DeleteWorker("id"), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Never); + } + + [Test] + public void DeleteWorker_StorageThrowError_ThrowException_Test() + { + //Arrange + _workerStorageContract.Setup(x => + x.DelElement(It.IsAny())).Throws(new StorageException(new + InvalidOperationException())); + //Act&Assert + Assert.That(() => + _workerBusinessLogicContract.DeleteWorker(Guid.NewGuid().ToString()), + Throws.TypeOf()); + _workerStorageContract.Verify(x => x.DelElement(It.IsAny()), + Times.Once); + } +} \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/DataModelsTests/PostDataModelTests.cs b/North_Bridge/North_Bridge_Tests/DataModelsTests/PostDataModelTests.cs index 6b2a656..63993df 100644 --- a/North_Bridge/North_Bridge_Tests/DataModelsTests/PostDataModelTests.cs +++ b/North_Bridge/North_Bridge_Tests/DataModelsTests/PostDataModelTests.cs @@ -9,10 +9,12 @@ internal class PostDataModelTests [Test] public void IdIsNullOrEmptyTest() { - var post = CreateDataModel(null, Guid.NewGuid().ToString(), "name", PostType.Consultant, 10000, true, DateTime.UtcNow); + var post = CreateDataModel(null, "name", PostType.Consultant, 10, + true, DateTime.UtcNow); Assert.That(() => post.Validate(), Throws.TypeOf()); - post = CreateDataModel(string.Empty, Guid.NewGuid().ToString(), "name", PostType.Loader, 10500, true, DateTime.UtcNow); + post = CreateDataModel(string.Empty, "name", PostType.Consultant, 10, + true, DateTime.UtcNow); Assert.That(() => post.Validate(), Throws.TypeOf()); } @@ -20,26 +22,8 @@ internal class PostDataModelTests [Test] public void IdIsNotGuidTest() { - var post = CreateDataModel("id", Guid.NewGuid().ToString(), "name", PostType.Cashier, 10, true, DateTime.UtcNow); - Assert.That(() => post.Validate(), - Throws.TypeOf()); - } - - [Test] - public void PostIdIsNullEmptyTest() - { - var post = CreateDataModel(Guid.NewGuid().ToString(), null, "name", PostType.Cashier, 10, true, DateTime.UtcNow); - Assert.That(() => post.Validate(), - Throws.TypeOf()); - post = CreateDataModel(Guid.NewGuid().ToString(), string.Empty, "name", PostType.Cashier, 10, true, DateTime.UtcNow); - Assert.That(() => post.Validate(), - Throws.TypeOf()); - } - - [Test] - public void PostIdIsNotGuidTest() - { - var post = CreateDataModel(Guid.NewGuid().ToString(), "postId", "name", PostType.Cashier, 10, true, DateTime.UtcNow); + var post = CreateDataModel("id", "name", PostType.Consultant, 10, + true, DateTime.UtcNow); Assert.That(() => post.Validate(), Throws.TypeOf()); } @@ -47,10 +31,12 @@ internal class PostDataModelTests [Test] public void PostNameIsEmptyTest() { - var manufacturer = CreateDataModel(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), null, PostType.Cashier, 10, true, DateTime.UtcNow); + var manufacturer = CreateDataModel(Guid.NewGuid().ToString(), null, + PostType.Consultant, 10, true, DateTime.UtcNow); Assert.That(() => manufacturer.Validate(), Throws.TypeOf()); - manufacturer = CreateDataModel(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), string.Empty, PostType.Cashier, 10, true, DateTime.UtcNow); + manufacturer = CreateDataModel(Guid.NewGuid().ToString(), + string.Empty, PostType.Consultant, 10, true, DateTime.UtcNow); Assert.That(() => manufacturer.Validate(), Throws.TypeOf()); } @@ -58,8 +44,8 @@ internal class PostDataModelTests [Test] public void PostTypeIsNoneTest() { - var post = CreateDataModel(Guid.NewGuid().ToString(), - Guid.NewGuid().ToString(), "name", PostType.None, 10, true, DateTime.UtcNow); + var post = CreateDataModel(Guid.NewGuid().ToString(), "name", + PostType.None, 10, true, DateTime.UtcNow); Assert.That(() => post.Validate(), Throws.TypeOf()); } @@ -67,10 +53,12 @@ internal class PostDataModelTests [Test] public void SalaryIsLessOrZeroTest() { - var post = CreateDataModel(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), "name", PostType.Cashier, 0, true, DateTime.UtcNow); + var post = CreateDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, 0, true, DateTime.UtcNow); Assert.That(() => post.Validate(), Throws.TypeOf()); - post = CreateDataModel(Guid.NewGuid().ToString(), Guid.NewGuid().ToString(), "name", PostType.Cashier, -10, true, DateTime.UtcNow); + post = CreateDataModel(Guid.NewGuid().ToString(), "name", + PostType.Consultant, -10, true, DateTime.UtcNow); Assert.That(() => post.Validate(), Throws.TypeOf()); } @@ -79,19 +67,17 @@ internal class PostDataModelTests public void AllFieldsIsCorrectTest() { var postId = Guid.NewGuid().ToString(); - var postPostId = Guid.NewGuid().ToString(); var postName = "name"; - var postType = PostType.Cashier; + var postType = PostType.Consultant; var salary = 10; var isActual = false; var changeDate = DateTime.UtcNow.AddDays(-1); - var post = CreateDataModel(postId, postPostId, postName, postType, - salary, isActual, changeDate); + var post = CreateDataModel(postId, postName, postType, salary, + isActual, changeDate); Assert.That(() => post.Validate(), Throws.Nothing); Assert.Multiple(() => { Assert.That(post.Id, Is.EqualTo(postId)); - Assert.That(post.PostId, Is.EqualTo(postPostId)); Assert.That(post.PostName, Is.EqualTo(postName)); Assert.That(post.PostType, Is.EqualTo(postType)); Assert.That(post.Salary, Is.EqualTo(salary)); @@ -100,7 +86,7 @@ internal class PostDataModelTests }); } - private static PostDataModel CreateDataModel(string? id, string? postId, + private static PostDataModel CreateDataModel(string? id, string? postName, PostType postType, double salary, bool isActual, DateTime changeDate) => - new (id, postId, postName, postType, salary, isActual, changeDate); + new (id, postName, postType, salary, isActual, changeDate); } \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/DataModelsTests/WorkerDataModelTests.cs b/North_Bridge/North_Bridge_Tests/DataModelsTests/WorkerDataModelTests.cs index 751a89c..0baf001 100644 --- a/North_Bridge/North_Bridge_Tests/DataModelsTests/WorkerDataModelTests.cs +++ b/North_Bridge/North_Bridge_Tests/DataModelsTests/WorkerDataModelTests.cs @@ -99,26 +99,26 @@ internal class WorkerDataModelTests { var workerId = Guid.NewGuid().ToString(); var fio = "fio"; - var email = "example@example.com"; + var Email = "example@example.com"; var postId = Guid.NewGuid().ToString(); - var birthDate = DateTime.Now.AddYears(-16).AddDays(-1); + var birthDate = DateTime.Now.AddYears(-18).AddDays(-1); var employmentDate = DateTime.Now; var isDelete = false; - var worker = CreateDataModel(workerId, fio, email, postId, birthDate, employmentDate, isDelete); + var worker = CreateDataModel(workerId, fio, Email, postId, birthDate, employmentDate, isDelete); Assert.That(() => worker.Validate(), Throws.Nothing); Assert.Multiple(() => { Assert.That(worker.Id, Is.EqualTo(workerId)); Assert.That(worker.FIO, Is.EqualTo(fio)); - Assert.That(worker.Email, Is.EqualTo(email)); + Assert.That(worker.Email, Is.EqualTo(Email)); Assert.That(worker.PostId, Is.EqualTo(postId)); Assert.That(worker.BirthDate, Is.EqualTo(birthDate)); - Assert.That(worker.EmploymentDate,Is.EqualTo(employmentDate)); + Assert.That(worker.EmploymentDate, Is.EqualTo(employmentDate)); Assert.That(worker.IsDeleted, Is.EqualTo(isDelete)); }); } - private static WorkerDataModel CreateDataModel(string? id, string? fio, string email, + private static WorkerDataModel CreateDataModel(string? id, string? fio, string? email, string? postId, DateTime birthDate, DateTime employmentDate, bool isDeleted) => new(id, fio, email, postId, birthDate, employmentDate, isDeleted); } \ No newline at end of file diff --git a/North_Bridge/North_Bridge_Tests/North_Bridge_Tests.csproj b/North_Bridge/North_Bridge_Tests/North_Bridge_Tests.csproj index 6168504..363321f 100644 --- a/North_Bridge/North_Bridge_Tests/North_Bridge_Tests.csproj +++ b/North_Bridge/North_Bridge_Tests/North_Bridge_Tests.csproj @@ -12,12 +12,14 @@ + +