fix: merge Task_1

This commit is contained in:
I1nur 2025-02-10 21:50:27 +04:00
commit 8634db837c
22 changed files with 54 additions and 37 deletions

2
.gitignore vendored
View File

@ -397,4 +397,4 @@ FodyWeavers.xsd
# JetBrains Rider
*.sln.iml
*/*.idea

View File

@ -20,17 +20,17 @@ public class ClientDataModel(string id, string fio, string phoneNumber) : IValid
public void Validate()
{
if (id.isEmpty())
if (Id.isEmpty())
throw new ValidationFieldException("Field Id is empty");
if (!id.isGuid())
if (!Id.isGuid())
throw new ValidationFieldException("The value in the field Id is not a unique identifier");
if (FIO.isEmpty())
throw new ValidationFieldException("Field FIO is empty");
if (!Regex.IsMatch(FIO, @"^[A-ZА-ЯЁ][a-zа-яё]+ [A-ZА-ЯЁ][a-zа-яё]+ [A-ZA-ЯЁ][a-zа-яё]+$"))
throw new ValidationFieldException("Field FIO is not a fio");
if (!Regex.IsMatch(FIO, @"^[A-ZА-ЯЁ][a-zа-яё]+(?:-[A-ZА-ЯЁ][a-zа-яё]+)?\s[A-ZА-ЯЁ][a-zа-яё]+(?:-[A-ZА-ЯЁ][a-zа-яё]+)?\s[A-ZА-ЯЁ][a-zа-яё]+(?:-[A-ZА-ЯЁ][a-zа-яё]+)?$"))
throw new ValidationFieldException("Field FIO is not a valid full name.");
if (PhoneNumber.isEmpty())
throw new ValidationFieldException("Field PhoneNumber is empty");

View File

@ -11,12 +11,17 @@ using System.Threading.Tasks;
namespace SoftwareInstallationContracts.DataModels;
public class CompanyDataModel(string id, string companyName, string prevCompanyName, string prevPrevCompanyName) : IValidation
public class CompanyDataModel(string id, string companyName, string prevCompanyName,
string prevPrevCompanyName) : IValidation
{
public string Id { get; private set; } = id;
public string CompanyName { get; private set; } = companyName;
public string? PrevCompanyName { get; private set; } = prevCompanyName;
public string? PrevPrevCompanyName { get; private set; } = prevPrevCompanyName;
public void Validate()
{
if (Id.isEmpty())

View File

@ -10,7 +10,8 @@ using System.Threading.Tasks;
namespace SoftwareInstallationContracts.DataModels;
public class InstallationDataModel(string id, string workerId, string clientId, double sum, bool isCancel, List<InstallationSoftwareDataModel> programs) : IValidation
public class InstallationDataModel(string id, string workerId, string clientId,
double sum, bool isCancel, List<InstallationSoftwareDataModel> programs) : IValidation
{
public string Id { get; private set; } = id;
@ -18,7 +19,7 @@ public class InstallationDataModel(string id, string workerId, string clientId,
public string? ClientId { get; private set; } = clientId;
public DateTime SaleDate { get; private set; } = DateTime.UtcNow;
public DateTime InstallationDate { get; private set; } = DateTime.UtcNow;
public double Sum { get; private set; } = sum;

View File

@ -9,11 +9,11 @@ using System.Threading.Tasks;
namespace SoftwareInstallationContracts.DataModels;
public class InstallationSoftwareDataModel(string saleId, string programId, int count) : IValidation
public class InstallationSoftwareDataModel(string installationId, string programId, int count) : IValidation
{
public string ProgramId { get; private set; } = programId;
public string SaleId { get; private set; } = saleId;
public string InstallationId { get; private set; } = installationId;
public int Count { get; private set; } = count;
@ -25,11 +25,11 @@ public class InstallationSoftwareDataModel(string saleId, string programId, int
if (!ProgramId.isGuid())
throw new ValidationFieldException("The value in the field ProgramId is not a unique identifier");
if (SaleId.isEmpty())
throw new ValidationFieldException("Field SaleId is empty");
if (InstallationId.isEmpty())
throw new ValidationFieldException("Field InstallationId is empty");
if (!SaleId.isGuid())
throw new ValidationFieldException("The value in the field SaleId is not a unique identifier");
if (!InstallationId.isGuid())
throw new ValidationFieldException("The value in the field InstallationId is not a unique identifier");
if (Count <= 0)
throw new ValidationFieldException("Field Count is less than or equal to 0");

View File

@ -10,7 +10,8 @@ using System.Threading.Tasks;
namespace SoftwareInstallationContracts.DataModels;
public class PostDataModel(string id, string postId, string postName, PostType postType, double salary, bool isActual, DateTime changeDate) : IValidation
public class PostDataModel(string id, string postId, string postName, PostType postType,
double salary, bool isActual, DateTime changeDate) : IValidation
{
public string Id { get; private set; } = id;

View File

@ -10,7 +10,8 @@ using System.Threading.Tasks;
namespace SoftwareInstallationContracts.DataModels;
public class SoftwareDataModel(string id, string softwareName, SoftwareType softwareType, string companyId, double price, bool isDeleted) : IValidation
public class SoftwareDataModel(string id, string softwareName, SoftwareType softwareType,
string companyId, double price, bool isDeleted) : IValidation
{
public string Id { get; private set; } = id;
@ -33,10 +34,10 @@ public class SoftwareDataModel(string id, string softwareName, SoftwareType soft
throw new ValidationFieldException("The value in the field Id is not a unique identifier");
if (SoftwareName.isEmpty())
throw new ValidationFieldException("Field ProgramName is empty");
throw new ValidationFieldException("Field SoftwareName is empty");
if (SoftwareType == SoftwareType.None)
throw new ValidationFieldException("Field ProgramType is empty");
throw new ValidationFieldException("Field SoftwareType is empty");
if (CompanyId.isEmpty())
throw new ValidationFieldException("Field CompanyId is empty");

View File

@ -21,10 +21,10 @@ public class SoftwareHistoryDataModel(string softwareId, double oldPrice) : IVal
public void Validate()
{
if (SoftwareId.isEmpty())
throw new ValidationFieldException("Field ProgramId is empty");
throw new ValidationFieldException("Field SoftwareId is empty");
if (!SoftwareId.isGuid())
throw new ValidationFieldException("The value in the field ProgramId is not a unique identifier");
throw new ValidationFieldException("The value in the field SoftwareId is not a unique identifier");
if (OldPrice <= 0)
throw new ValidationFieldException("Field OldPrice is less than or equal to 0");

View File

@ -10,13 +10,19 @@ using System.Threading.Tasks;
namespace SoftwareInstallationContracts.DataModels;
public class WorkerDataModel(string id, string fio, string postId, DateTime birthDate, DateTime employmentDate, bool isDeleted) : IValidation
public class WorkerDataModel(string id, string fio, string postId, DateTime birthDate, DateTime employmentDate,
bool isDeleted) : IValidation
{
public string Id { get; private set; } = id;
public string FIO { get; private set; } = fio;
public string PostId { get; private set; } = postId;
public DateTime BirthDate { get; private set; } = birthDate;
public DateTime EmploymentDate { get; private set; } = employmentDate;
public bool IsDeleted { get; private set; } = isDeleted;
public void Validate()
@ -43,6 +49,8 @@ public class WorkerDataModel(string id, string fio, string postId, DateTime birt
throw new ValidationFieldException("The date of employment cannot be less than the date of birth");
if ((EmploymentDate - BirthDate).TotalDays / 365 < 16)
throw new ValidationFieldException($"Minors cannot be hired (EmploymentDate - {EmploymentDate.ToShortDateString()}, BirthDate - {BirthDate.ToShortDateString()}");
throw new ValidationFieldException($"Minors cannot be hired " +
$"(EmploymentDate - {EmploymentDate.ToShortDateString()}," +
$" BirthDate - {BirthDate.ToShortDateString()}");
}
}

View File

@ -16,48 +16,48 @@ internal class ClientDataModelTests
[Test]
public void IdIsNullOrEmptyTest()
{
client = CreateDataModel(null, "fio", "number");
client = CreateDataModel(null, "Fio Fio Fio", "+7-777-777-77-77");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
client = CreateDataModel(string.Empty, "fio", "number");
client = CreateDataModel(string.Empty, "Fio Fio Fio", "+7-777-777-77-77");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
}
[Test]
public void IdIsNotGuidTest()
{
client = CreateDataModel("id", "fio", "number");
client = CreateDataModel("id", "Fio Fio Fio", "+7-777-777-77-77");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
}
[Test]
public void FIOIsNullOrEmptyTest()
{
client = CreateDataModel(Guid.NewGuid().ToString(), null, "number");
client = CreateDataModel(Guid.NewGuid().ToString(), null, "+7-777-777-77-77");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
client = CreateDataModel(Guid.NewGuid().ToString(), string.Empty, "number");
client = CreateDataModel(Guid.NewGuid().ToString(), string.Empty, "+7-777-777-77-77");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
}
[Test]
public void FIOIsIncorrectTest()
{
client = CreateDataModel(Guid.NewGuid().ToString(), "fio", "number");
client = CreateDataModel(Guid.NewGuid().ToString(), "fio", "+7-777-777-77-77");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
}
[Test]
public void PhoneNumberIsNullOrEmptyTest()
{
client = CreateDataModel(Guid.NewGuid().ToString(), "fio", null);
client = CreateDataModel(Guid.NewGuid().ToString(), "Fio Fio Fio", null);
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
client = CreateDataModel(Guid.NewGuid().ToString(), "fio", string.Empty);
client = CreateDataModel(Guid.NewGuid().ToString(), "Fio Fio Fio", string.Empty);
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
}
[Test]
public void PhoneNumberIsIncorrectTest()
{
client = CreateDataModel(Guid.NewGuid().ToString(), "fio", "777");
client = CreateDataModel(Guid.NewGuid().ToString(), "Fio Fio Fio", "777");
Assert.That(() => client.Validate(), Throws.TypeOf<ValidationFieldException>());
}
@ -65,7 +65,7 @@ internal class ClientDataModelTests
public void AllFieldsIsCorrectTest()
{
string phoneNumber = "+7-777-777-77-77";
string fio = "Василий Васильевич Васильев";
string fio = "Vasiliy Vasiliev Vasilievich";
string id = Guid.NewGuid().ToString();
client = CreateDataModel(id, fio, phoneNumber);
Assert.That(() => client.Validate(), Throws.Nothing);

View File

@ -56,6 +56,6 @@ internal class CompanyDataModelTests
});
}
private static CompanyDataModel CreateDataModel(string? id, string? companyName, string? prevcompanyName = null, string? prevPrevcompanyName = null) =>
new(id, companyName, prevcompanyName, prevPrevcompanyName);
private static CompanyDataModel CreateDataModel(string? id, string? companyName, string? prevcompanyName = null,
string? prevPrevcompanyName = null) => new(id, companyName, prevcompanyName, prevPrevcompanyName);
}

View File

@ -64,7 +64,7 @@ internal class InstallationSoftwareDataModelTests
Assert.That(() => installSoftware.Validate(), Throws.Nothing);
Assert.Multiple(() =>
{
Assert.That(installSoftware.SaleId, Is.EqualTo(installId));
Assert.That(installSoftware.InstallationId, Is.EqualTo(installId));
Assert.That(installSoftware.ProgramId, Is.EqualTo(softwareId));
Assert.That(installSoftware.Count, Is.EqualTo(count));
});

View File

@ -54,5 +54,6 @@ internal class SalaryDataModelTests
});
}
private static SalaryDataModel CreateDataModel(string? workerId, DateTime date, double workerSalary) => new(workerId, date, workerSalary);
private static SalaryDataModel CreateDataModel(string? workerId, DateTime date,
double workerSalary) => new(workerId, date, workerSalary);
}

View File

@ -17,7 +17,7 @@
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\..\SoftwareInstallationContracts\SoftwareInstallationContracts\SoftwareInstallationContracts.csproj" />
<ProjectReference Include="..\SoftwareInstallationContracts\SoftwareInstallationContracts\SoftwareInstallationContracts.csproj" />
</ItemGroup>
<ItemGroup>