rename unit tests project

This commit is contained in:
ngfrolov 2024-08-19 10:57:31 +05:00
parent bc1c5fa00f
commit 90a782826c
Signed by untrusted user who does not match committer: ng.frolov
GPG Key ID: E99907A0357B29A7
35 changed files with 460 additions and 466 deletions

View File

@ -11,7 +11,7 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AsbCloudInfrastructure", "A
EndProject EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AsbCloudDb", "AsbCloudDb\AsbCloudDb.csproj", "{40FBD29B-724B-4496-B5D9-1A5D14102456}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AsbCloudDb", "AsbCloudDb\AsbCloudDb.csproj", "{40FBD29B-724B-4496-B5D9-1A5D14102456}"
EndProject EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AsbCloudWebApi.Tests", "AsbCloudWebApi.Tests\AsbCloudWebApi.Tests.csproj", "{9CF6FBB1-9AF5-45AB-A521-24F11A79B540}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AsbCloudInfrastructure.Tests", "AsbCloudInfrastructure.Tests\AsbCloudInfrastructure.Tests.csproj", "{9CF6FBB1-9AF5-45AB-A521-24F11A79B540}"
EndProject EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "SignalRTestClient", "SignalRTestClient\SignalRTestClient.csproj", "{E6B97963-4CEA-47B6-A0C8-625FFA9B7D69}" Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "SignalRTestClient", "SignalRTestClient\SignalRTestClient.csproj", "{E6B97963-4CEA-47B6-A0C8-625FFA9B7D69}"
EndProject EndProject

View File

@ -1,7 +1,7 @@
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
using System.Linq; using System.Linq;
namespace AsbCloudWebApi.Tests; namespace AsbCloudInfrastructure.Tests;
public static class AspExtensions public static class AspExtensions
{ {

View File

@ -7,7 +7,7 @@ using Microsoft.Extensions.DependencyInjection;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Background; namespace AsbCloudInfrastructure.Tests.Background;
public class BackgroundWorkerTest public class BackgroundWorkerTest
{ {

View File

@ -8,7 +8,7 @@ using Microsoft.Extensions.DependencyInjection;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Background; namespace AsbCloudInfrastructure.Tests.Background;
//TODO: нужно поправить тесты, иногда они не проходят //TODO: нужно поправить тесты, иногда они не проходят
public class PeriodicBackgroundWorkerTest public class PeriodicBackgroundWorkerTest
@ -55,7 +55,7 @@ public class PeriodicBackgroundWorkerTest
var stopwatch = Stopwatch.StartNew(); var stopwatch = Stopwatch.StartNew();
service.Add(work, period); service.Add(work, period);
var delay = (periodMs / 20) + (periodMs * workCount) - stopwatch.ElapsedMilliseconds; var delay = periodMs / 20 + periodMs * workCount - stopwatch.ElapsedMilliseconds;
await Task.Delay(TimeSpan.FromMilliseconds(delay)); await Task.Delay(TimeSpan.FromMilliseconds(delay));
//assert //assert

View File

@ -7,7 +7,7 @@ using Microsoft.Extensions.DependencyInjection;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Background; namespace AsbCloudInfrastructure.Tests.Background;
public class WorkTest public class WorkTest
{ {

View File

@ -1,7 +1,7 @@
using Mapster; using Mapster;
using System; using System;
namespace AsbCloudWebApi.Tests; namespace AsbCloudInfrastructure.Tests;
public static class CommonExtensions public static class CommonExtensions
{ {

View File

@ -1,10 +1,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace AsbCloudWebApi.Tests; namespace AsbCloudInfrastructure.Tests;
public static class ReflectionExtensions public static class ReflectionExtensions
{ {
@ -42,5 +39,5 @@ public static class ReflectionExtensions
} }
public static bool IsDefaultValue(this Type type, object? value) public static bool IsDefaultValue(this Type type, object? value)
=> (value?.Equals(type.GetDefaultValue()) != false); => value?.Equals(type.GetDefaultValue()) != false;
} }

View File

@ -23,7 +23,7 @@ using System.Threading.Tasks;
using AsbCloudApp.Data.WellOperation; using AsbCloudApp.Data.WellOperation;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class DailyReportServiceTest public class DailyReportServiceTest
{ {

View File

@ -14,7 +14,7 @@ using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class DataSaubStatServiceTest public class DataSaubStatServiceTest
{ {

View File

@ -4,7 +4,7 @@ using AsbCloudInfrastructure.Services.DetectOperations.Detectors;
using System; using System;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.DetectedOperations.Detectors; namespace AsbCloudInfrastructure.Tests.Services.DetectedOperations.Detectors;
/// <summary> /// <summary>
/// Тестирование автоопределения операции "Проработка" /// Тестирование автоопределения операции "Проработка"

View File

@ -4,97 +4,97 @@ using AsbCloudInfrastructure.Services.DetectOperations;
using AsbCloudInfrastructure.Services.DetectOperations.Detectors; using AsbCloudInfrastructure.Services.DetectOperations.Detectors;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.DetectedOperations.Detectors; namespace AsbCloudInfrastructure.Tests.Services.DetectedOperations.Detectors;
public class DetectorDrillingTests : DetectorDrilling public class DetectorDrillingTests : DetectorDrilling
{ {
private const int idSlide = 5002; private const int idSlide = 5002;
private const int idRotor = 5003; private const int idRotor = 5003;
[Theory] [Theory]
[MemberData(nameof(TelemetryRangeDrillingRotor))] [MemberData(nameof(TelemetryRangeDrillingRotor))]
public void DefineDrillingOperation_ShouldReturn_DrillingRotor(DetectableTelemetry[] telemetryRange) public void DefineDrillingOperation_ShouldReturn_DrillingRotor(DetectableTelemetry[] telemetryRange)
{ {
//act //act
var result = GetSpecificInformation(telemetryRange, 0, telemetryRange.Length); var result = GetSpecificInformation(telemetryRange, 0, telemetryRange.Length);
//assert //assert
Assert.Equal(idRotor, result.IdCategory); Assert.Equal(idRotor, result.IdCategory);
} }
[Theory] [Theory]
[MemberData(nameof(TelemetryRangeDrillingSlide))] [MemberData(nameof(TelemetryRangeDrillingSlide))]
public void DefineDrillingOperation_ShouldReturn_DrillingSlide(DetectableTelemetry[] telemetryRange) public void DefineDrillingOperation_ShouldReturn_DrillingSlide(DetectableTelemetry[] telemetryRange)
{ {
//act //act
var result = GetSpecificInformation(telemetryRange, 0, telemetryRange.Length); var result = GetSpecificInformation(telemetryRange, 0, telemetryRange.Length);
//assert //assert
Assert.Equal(idSlide, result.IdCategory); Assert.Equal(idSlide, result.IdCategory);
} }
[Theory] [Theory]
[MemberData(nameof(TelemetryRangeDrillingSlideWithOscillation))] [MemberData(nameof(TelemetryRangeDrillingSlideWithOscillation))]
public void DefineDrillingOperation_ShouldReturn_DrillingSlideWithOscillation(DetectableTelemetry[] telemetryRange) public void DefineDrillingOperation_ShouldReturn_DrillingSlideWithOscillation(DetectableTelemetry[] telemetryRange)
{ {
//act //act
var result = GetSpecificInformation(telemetryRange, 0, telemetryRange.Length); var result = GetSpecificInformation(telemetryRange, 0, telemetryRange.Length);
//assert //assert
var oHasOscillation = result.ExtraData[ExtraDataKeyHasOscillation]; var oHasOscillation = result.ExtraData[ExtraDataKeyHasOscillation];
Assert.Equal(idSlide, result.IdCategory); Assert.Equal(idSlide, result.IdCategory);
Assert.True(oHasOscillation is bool hasOscillation && hasOscillation); Assert.True(oHasOscillation is bool hasOscillation && hasOscillation);
} }
[Fact] [Fact]
public void IsValidOperationDetectorResult_ShouldReturn_True() public void IsValidOperationDetectorResult_ShouldReturn_True()
{ {
//arrange //arrange
var operationDetectorResult = new OperationDetectorResult var operationDetectorResult = new OperationDetectorResult
{ {
Operation = new DetectedOperationDto Operation = new DetectedOperationDto
{ {
DepthStart = 5000, DepthStart = 5000,
DepthEnd = 6000, DepthEnd = 6000,
DateStart = System.DateTimeOffset.Now.AddMinutes(-1),
DateEnd = System.DateTimeOffset.Now,
}
};
//act
var result = IsValidOperationDetectorResult(operationDetectorResult);
//assert
Assert.True(result);
}
[Fact]
public void IsValidOperationDetectorResult_ShouldReturn_False()
{
//arrange
var operationDetectorResult = new OperationDetectorResult
{
Operation = new DetectedOperationDto
{
DepthStart = 5000,
DepthEnd = 5000,
DateStart = System.DateTimeOffset.Now.AddMinutes(-1), DateStart = System.DateTimeOffset.Now.AddMinutes(-1),
DateEnd = System.DateTimeOffset.Now, DateEnd = System.DateTimeOffset.Now,
} }
}; };
//act //act
var result = IsValidOperationDetectorResult(operationDetectorResult); var result = IsValidOperationDetectorResult(operationDetectorResult);
//assert
Assert.False(result);
}
public static IEnumerable<object[]> TelemetryRangeDrillingRotor() //assert
{ Assert.True(result);
yield return new object[] }
{
[Fact]
public void IsValidOperationDetectorResult_ShouldReturn_False()
{
//arrange
var operationDetectorResult = new OperationDetectorResult
{
Operation = new DetectedOperationDto
{
DepthStart = 5000,
DepthEnd = 5000,
DateStart = System.DateTimeOffset.Now.AddMinutes(-1),
DateEnd = System.DateTimeOffset.Now,
}
};
//act
var result = IsValidOperationDetectorResult(operationDetectorResult);
//assert
Assert.False(result);
}
public static IEnumerable<object[]> TelemetryRangeDrillingRotor()
{
yield return new object[]
{
new[] new[]
{ {
new DetectableTelemetry new DetectableTelemetry
@ -152,13 +152,13 @@ public class DetectorDrillingTests : DetectorDrilling
RotorSpeed = 40.3f RotorSpeed = 40.3f
} }
} }
}; };
} }
public static IEnumerable<object[]> TelemetryRangeDrillingSlide() public static IEnumerable<object[]> TelemetryRangeDrillingSlide()
{ {
yield return new object[] yield return new object[]
{ {
new[] new[]
{ {
new DetectableTelemetry new DetectableTelemetry
@ -189,13 +189,13 @@ public class DetectorDrillingTests : DetectorDrilling
RotorSpeed = 0.1f RotorSpeed = 0.1f
}, },
} }
}; };
} }
public static IEnumerable<object[]> TelemetryRangeDrillingSlideWithOscillation() public static IEnumerable<object[]> TelemetryRangeDrillingSlideWithOscillation()
{ {
yield return new object[] yield return new object[]
{ {
new[] new[]
{ {
new DetectableTelemetry new DetectableTelemetry
@ -280,6 +280,6 @@ public class DetectorDrillingTests : DetectorDrilling
RotorSpeed = 71.5f RotorSpeed = 71.5f
} }
} }
}; };
} }
} }

View File

@ -3,7 +3,7 @@ using AsbCloudInfrastructure.Services.DetectOperations;
using AsbCloudInfrastructure.Services.DetectOperations.Detectors; using AsbCloudInfrastructure.Services.DetectOperations.Detectors;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.DetectedOperations.Detectors; namespace AsbCloudInfrastructure.Tests.Services.DetectedOperations.Detectors;
/// <summary> /// <summary>
/// Тестирование автоопределения операции "Промывка" /// Тестирование автоопределения операции "Промывка"

View File

@ -0,0 +1,87 @@
using System;
using AsbCloudInfrastructure.Services.DetectOperations;
using AsbCloudInfrastructure.Services.DetectOperations.Detectors;
using Xunit;
namespace AsbCloudInfrastructure.Tests.Services.DetectedOperations.Detectors;
public class DetectorSlipsTimeTests
{
private const int IdSlipsTime = 5011;
private readonly DetectableTelemetry telemetry = new()
{
WellDepth = 300,
Pressure = 15,
HookWeight = 20,
BlockPosition = 20,
BitDepth = 151,
AxialLoad = 19,
};
private readonly DetectorSlipsTime sut = new();
[Fact]
public void DetectOperation_by_change_block_position_and_axial_load_less_hook_weight_is_success()
{
//arrange
var point0 = telemetry.Copy();
var point1 = telemetry.Copy();
point1.BlockPosition = 21;
var telemetries = new[] { point0, point1 };
//act
var isDetectOperation = sut.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
//assert
Assert.True(isDetectOperation);
Assert.NotNull(result);
Assert.Equal(IdSlipsTime, result.Operation.IdCategory);
}
[Fact]
public void DetectOperation_by_high_pressure_is_success()
{
//arrange
var point0 = telemetry.Copy();
var point1 = telemetry.Copy();
point1.BlockPosition = 21;
point1.AxialLoad = 30;
point1.HookWeight = 20;
point1.Pressure = 23;
var telemetries = new[] { point0, point1 };
//act
var isDetectOperation = sut.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
//assert
Assert.True(isDetectOperation);
Assert.NotNull(result);
Assert.Equal(IdSlipsTime, result.Operation.IdCategory);
}
[Fact]
public void ValidateOperation_with_duration_more_30_minutes_is_invalid()
{
//arrange
var point0 = telemetry.Copy();
var point1 = telemetry.Copy();
point1.BlockPosition = 21;
point1.DateTime = DateTimeOffset.UtcNow.AddMinutes(30);
var telemetries = new[] { point0, point1 };
//act
var isDetectOperation = sut.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
//assert
Assert.False(isDetectOperation);
Assert.NotNull(result);
Assert.Equal(IdSlipsTime, result.Operation.IdCategory);
}
}

View File

@ -0,0 +1,42 @@
using AsbCloudApp.Data.DetectedOperation;
using Xunit;
namespace AsbCloudInfrastructure.Tests.Services.DetectedOperations;
public class EnabledSubsystemsTests
{
[Fact]
public void Create_enable_subsystem_with_the_systems_turned_off()
{
//act
EnabledSubsystems enableSubsystem = 0;
//arrange
Assert.False(enableSubsystem.IsAutoRotor);
Assert.False(enableSubsystem.IsAutoSlide);
Assert.False(enableSubsystem.IsAutoConditionig);
Assert.False(enableSubsystem.IsAutoSinking);
Assert.False(enableSubsystem.IsAutoLifting);
Assert.False(enableSubsystem.IsAutoLiftingWithConditionig);
Assert.False(enableSubsystem.IsAutoBlocknig);
Assert.False(enableSubsystem.IsAutoOscillation);
}
[Fact]
public void Create_enable_subsystem_with_the_auto_slide_subsystem()
{
//act
EnabledSubsystems enableSubsystem = 2;
//arrange
Assert.True(enableSubsystem.IsAutoSlide);
Assert.False(enableSubsystem.IsAutoRotor);
Assert.False(enableSubsystem.IsAutoConditionig);
Assert.False(enableSubsystem.IsAutoSinking);
Assert.False(enableSubsystem.IsAutoLifting);
Assert.False(enableSubsystem.IsAutoLiftingWithConditionig);
Assert.False(enableSubsystem.IsAutoBlocknig);
Assert.False(enableSubsystem.IsAutoOscillation);
}
}

View File

@ -11,7 +11,7 @@ using AsbCloudApp.Services;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class FileServiceTest public class FileServiceTest
{ {

View File

@ -10,7 +10,7 @@ using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class HelpPageServiceTest public class HelpPageServiceTest
{ {

View File

@ -12,7 +12,7 @@ using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.Notification; namespace AsbCloudInfrastructure.Tests.Services.Notification;
public class EmailNotificationTransportServiceTests public class EmailNotificationTransportServiceTests
{ {

View File

@ -10,7 +10,7 @@ using Microsoft.Extensions.DependencyInjection;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.SAUB; namespace AsbCloudInfrastructure.Tests.Services.SAUB;
public class TelemetryDataSaubCacheTests public class TelemetryDataSaubCacheTests
{ {
@ -60,6 +60,6 @@ public class TelemetryDataSaubCacheTests
var lastTelemetry = telemetryDataCache.GetLastOrDefault(idTelemetry); var lastTelemetry = telemetryDataCache.GetLastOrDefault(idTelemetry);
//assert //assert
Assert.Null(lastTelemetry ); Assert.Null(lastTelemetry);
} }
} }

View File

@ -9,12 +9,12 @@ using System.Threading.Tasks;
using AsbCloudApp.Requests.ExportOptions; using AsbCloudApp.Requests.ExportOptions;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.Trajectory; namespace AsbCloudInfrastructure.Tests.Services.Trajectory;
public class TrajectoryExportTest public class TrajectoryExportTest
{ {
private const int idWell = 4; private const int idWell = 4;
private IWellService wellService; private IWellService wellService;
private readonly ITrajectoryEditableRepository<TrajectoryGeoPlanDto> trajectoryPlanRepository; private readonly ITrajectoryEditableRepository<TrajectoryGeoPlanDto> trajectoryPlanRepository;
private readonly TrajectoryPlanExportService trajectoryPlanExportService; private readonly TrajectoryPlanExportService trajectoryPlanExportService;
@ -101,7 +101,7 @@ public class TrajectoryExportTest
{ {
trajectoryPlanRepository.GetAsync(idWell, CancellationToken.None) trajectoryPlanRepository.GetAsync(idWell, CancellationToken.None)
.Returns(trajectoryPlanRows); .Returns(trajectoryPlanRows);
var stream = await trajectoryPlanExportService.ExportAsync(exportOptions, CancellationToken.None); var stream = await trajectoryPlanExportService.ExportAsync(exportOptions, CancellationToken.None);
Assert.True(stream.File.Length > 0); Assert.True(stream.File.Length > 0);
} }
@ -111,7 +111,7 @@ public class TrajectoryExportTest
{ {
trajectoryFactManualReposirory.GetAsync(idWell, CancellationToken.None) trajectoryFactManualReposirory.GetAsync(idWell, CancellationToken.None)
.Returns(trajectoryFactRows); .Returns(trajectoryFactRows);
var stream = await trajectoryFactManualExportService.ExportAsync(exportOptions, CancellationToken.None); var stream = await trajectoryFactManualExportService.ExportAsync(exportOptions, CancellationToken.None);
Assert.True(stream.File.Length > 0); Assert.True(stream.File.Length > 0);
} }
@ -121,7 +121,7 @@ public class TrajectoryExportTest
{ {
trajectoryFactNnbRepository.GetAsync(idWell, CancellationToken.None) trajectoryFactNnbRepository.GetAsync(idWell, CancellationToken.None)
.Returns(trajectoryFactRows); .Returns(trajectoryFactRows);
var stream = await trajectoryFactNnbExportService.ExportAsync(exportOptions, CancellationToken.None); var stream = await trajectoryFactNnbExportService.ExportAsync(exportOptions, CancellationToken.None);
Assert.True(stream.File.Length > 0); Assert.True(stream.File.Length > 0);
} }

View File

@ -0,0 +1,44 @@
using System.Linq;
using AsbCloudApp.Requests.ParserOptions;
using AsbCloudInfrastructure.Services.Trajectory.Parser;
using Xunit;
namespace AsbCloudInfrastructure.Tests.Services.Trajectory;
public class TrajectoryParserTest
{
private const string UsingTemplateFile = "AsbCloudWebApi.Tests.Services.Trajectory.Templates";
private readonly WellRelatedParserRequest options = new(1);
private readonly TrajectoryPlanParser trajectoryPlanParser = new();
private readonly TrajectoryFactManualParser trajectoryFactManualParser = new();
[Fact]
public void Parse_trajectory_plan()
{
var stream = System.Reflection.Assembly.GetExecutingAssembly()
.GetManifestResourceStream($"{UsingTemplateFile}.TrajectoryPlanTemplate.xlsx");
if (stream is null)
Assert.Fail("Файла для импорта не существует");
var trajectoryRows = trajectoryPlanParser.Parse(stream, options);
Assert.Equal(3, trajectoryRows.Item.Count());
}
[Fact]
public void Parse_trajectory_fact_manual()
{
var stream = System.Reflection.Assembly.GetExecutingAssembly()
.GetManifestResourceStream($"{UsingTemplateFile}.TrajectoryFactManualTemplate.xlsx");
if (stream is null)
Assert.Fail("Файла для импорта не существует");
var trajectoryRows = trajectoryFactManualParser.Parse(stream, options);
Assert.Equal(4, trajectoryRows.Item.Count());
}
}

View File

@ -1,15 +1,13 @@
using System.Linq; using System.Linq;
using System.Threading; using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using AsbCloudApp.Data;
using AsbCloudApp.Data.Trajectory; using AsbCloudApp.Data.Trajectory;
using AsbCloudApp.Repositories; using AsbCloudApp.Repositories;
using AsbCloudApp.Requests;
using AsbCloudInfrastructure.Services.Trajectory; using AsbCloudInfrastructure.Services.Trajectory;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class TrajectoryVisualizationServiceTest public class TrajectoryVisualizationServiceTest
{ {

View File

@ -12,7 +12,7 @@ using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services.WellCompositeOperation; namespace AsbCloudInfrastructure.Tests.Services.WellCompositeOperation;
public class WellCompositeOperationServiceTest public class WellCompositeOperationServiceTest
{ {

View File

@ -13,7 +13,7 @@ using Microsoft.Extensions.Configuration;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class WellFinalDocumentsServiceTest public class WellFinalDocumentsServiceTest
{ {

View File

@ -12,7 +12,7 @@ using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class WellOperationServiceTest public class WellOperationServiceTest
{ {
private const int idWell = 1; private const int idWell = 1;
@ -108,7 +108,7 @@ public class WellOperationServiceTest
Assert.Equal(operationFactWithNpt.IdCategory, retrievedOperationFactWithNpt.IdCategory); Assert.Equal(operationFactWithNpt.IdCategory, retrievedOperationFactWithNpt.IdCategory);
var retrievedOperationFactRotor = facts.First(o => o.Id == operationFactRotor.Id); var retrievedOperationFactRotor = facts.First(o => o.Id == operationFactRotor.Id);
var expectedDay = operationFactWithNpt.DurationHours / 24; var expectedDay = operationFactWithNpt.DurationHours / 24;
Assert.Equal(expectedDay, retrievedOperationFactRotor.Day, 0.001); Assert.Equal(expectedDay, retrievedOperationFactRotor.Day, 0.001);
Assert.Equal(operationFactWithNpt.DurationHours, retrievedOperationFactRotor.NptHours, 0.001); Assert.Equal(operationFactWithNpt.DurationHours, retrievedOperationFactRotor.NptHours, 0.001);
Assert.Equal(retrievedOperationPlanRotor.Id, retrievedOperationFactRotor.IdPlan); Assert.Equal(retrievedOperationPlanRotor.Id, retrievedOperationFactRotor.IdPlan);

View File

@ -12,7 +12,7 @@ using AsbCloudInfrastructure.Services;
using NSubstitute; using NSubstitute;
using Xunit; using Xunit;
namespace AsbCloudWebApi.Tests.Services; namespace AsbCloudInfrastructure.Tests.Services;
public class WellboreServiceTest public class WellboreServiceTest
{ {

View File

@ -0,0 +1,169 @@
using System;
using System.IO;
using ClosedXML.Excel;
using Xunit;
namespace AsbCloudInfrastructure.Tests;
public class XLExtensionsTests
{
private const string cellUsed = "A1";
private const string sheetName = "test";
private readonly IXLWorkbook workbook;
public XLExtensionsTests()
{
workbook = new XLWorkbook();
workbook.Worksheets.Add(sheetName);
}
[Fact]
public void GetWorksheet_returns_sheet()
{
//act
var sheet = workbook.GetWorksheet(sheetName);
//assert
Assert.NotNull(sheet);
}
[Theory]
[MemberData(nameof(valueTypesToSet))]
public void SetCellValue_returns_success(object value, XLDataType expectedDataType)
{
//act
var cell = GetCell(cellUsed);
cell.SetCellValue(value);
//assert
Assert.Equal(expectedDataType, cell.DataType);
}
[Fact]
public void GetCellValue_returns_double()
{
//arrange
const double expectedValue = 2.0d;
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<double>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Fact]
public void GetCellValue_returns_float()
{
//arrange
const float expectedValue = 2.0f;
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<float>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Theory]
[InlineData("test")]
[InlineData(null)]
public void GetCellValue_returns_string(string? expectedValue)
{
//arrange
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<string>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Fact]
public void GetCellValue_returns_bool()
{
//arrange
const bool expectedValue = true;
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<bool>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Fact]
public void GetCellValue_returns_dateTime()
{
//arrange
var expectedValue = DateTime.Parse("2023-01-01");
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<DateTime>();
//assert
Assert.Equal(expectedValue, actualValue);
Assert.Equal(DateTimeKind.Unspecified, actualValue.Kind);
}
[Fact]
public void GetCellValue_returns_exception()
{
//arrange
SetCellValue("test");
//assert
Assert.Throws<FileFormatException>(() => GetCell(cellUsed).GetCellValue<double>());
}
[Fact]
public void GetCellValue_returns_nullable()
{
//act
var actualValue = GetCell(cellUsed).GetCellValue<object?>();
//assert
Assert.Null(actualValue);
}
[Fact]
public void SetHyperlink_returns_success()
{
//arrange
const string link = "http://test.ru";
//act
GetCell(cellUsed).SetHyperlink(link);
//assert
var hyperLink = GetCell(cellUsed).GetHyperlink();
Assert.NotNull(hyperLink);
}
private void SetCellValue<T>(T value)
{
var cell = GetCell(cellUsed);
cell.SetCellValue(value);
}
public static readonly object[][] valueTypesToSet =
{
new object[] { 2.0d, XLDataType.Number },
new object[] { 2.0f, XLDataType.Number },
new object[] { "test", XLDataType.Text },
new object[] { true, XLDataType.Boolean },
new object[] { DateTime.UtcNow, XLDataType.DateTime }
};
private IXLCell GetCell(string cellAddressInRange)
{
var sheet = workbook.GetWorksheet(sheetName);
return sheet.Cell(cellAddressInRange);
}
}

View File

@ -1,86 +0,0 @@
using System;
using AsbCloudInfrastructure.Services.DetectOperations;
using AsbCloudInfrastructure.Services.DetectOperations.Detectors;
using Xunit;
namespace AsbCloudWebApi.Tests.Services.DetectedOperations.Detectors;
public class DetectorSlipsTimeTests
{
private const int IdSlipsTime = 5011;
private readonly DetectableTelemetry telemetry = new() {
WellDepth = 300,
Pressure = 15,
HookWeight = 20,
BlockPosition = 20,
BitDepth = 151,
AxialLoad = 19,
};
private readonly DetectorSlipsTime sut = new();
[Fact]
public void DetectOperation_by_change_block_position_and_axial_load_less_hook_weight_is_success()
{
//arrange
var point0 = telemetry.Copy();
var point1 = telemetry.Copy();
point1.BlockPosition = 21;
var telemetries = new[] { point0, point1 };
//act
var isDetectOperation = sut.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
//assert
Assert.True(isDetectOperation);
Assert.NotNull(result);
Assert.Equal(IdSlipsTime, result.Operation.IdCategory);
}
[Fact]
public void DetectOperation_by_high_pressure_is_success()
{
//arrange
var point0 = telemetry.Copy();
var point1 = telemetry.Copy();
point1.BlockPosition = 21;
point1.AxialLoad = 30;
point1.HookWeight = 20;
point1.Pressure = 23;
var telemetries = new[] { point0, point1 };
//act
var isDetectOperation = sut.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
//assert
Assert.True(isDetectOperation);
Assert.NotNull(result);
Assert.Equal(IdSlipsTime, result.Operation.IdCategory);
}
[Fact]
public void ValidateOperation_with_duration_more_30_minutes_is_invalid()
{
//arrange
var point0 = telemetry.Copy();
var point1 = telemetry.Copy();
point1.BlockPosition = 21;
point1.DateTime = DateTimeOffset.UtcNow.AddMinutes(30);
var telemetries = new[] { point0, point1 };
//act
var isDetectOperation = sut.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
//assert
Assert.False(isDetectOperation);
Assert.NotNull(result);
Assert.Equal(IdSlipsTime, result.Operation.IdCategory);
}
}

View File

@ -1,42 +0,0 @@
using AsbCloudApp.Data.DetectedOperation;
using Xunit;
namespace AsbCloudWebApi.Tests.Services.DetectedOperations;
public class EnabledSubsystemsTests
{
[Fact]
public void Create_enable_subsystem_with_the_systems_turned_off()
{
//act
EnabledSubsystems enableSubsystem = 0;
//arrange
Assert.False(enableSubsystem.IsAutoRotor);
Assert.False(enableSubsystem.IsAutoSlide);
Assert.False(enableSubsystem.IsAutoConditionig);
Assert.False(enableSubsystem.IsAutoSinking);
Assert.False(enableSubsystem.IsAutoLifting);
Assert.False(enableSubsystem.IsAutoLiftingWithConditionig);
Assert.False(enableSubsystem.IsAutoBlocknig);
Assert.False(enableSubsystem.IsAutoOscillation);
}
[Fact]
public void Create_enable_subsystem_with_the_auto_slide_subsystem()
{
//act
EnabledSubsystems enableSubsystem = 2;
//arrange
Assert.True(enableSubsystem.IsAutoSlide);
Assert.False(enableSubsystem.IsAutoRotor);
Assert.False(enableSubsystem.IsAutoConditionig);
Assert.False(enableSubsystem.IsAutoSinking);
Assert.False(enableSubsystem.IsAutoLifting);
Assert.False(enableSubsystem.IsAutoLiftingWithConditionig);
Assert.False(enableSubsystem.IsAutoBlocknig);
Assert.False(enableSubsystem.IsAutoOscillation);
}
}

View File

@ -1,45 +0,0 @@
using System.Linq;
using AsbCloudApp.Data.Trajectory;
using AsbCloudApp.Requests.ParserOptions;
using AsbCloudInfrastructure.Services.Trajectory.Parser;
using Xunit;
namespace AsbCloudWebApi.Tests.Services.Trajectory;
public class TrajectoryParserTest
{
private const string UsingTemplateFile = "AsbCloudWebApi.Tests.Services.Trajectory.Templates";
private readonly WellRelatedParserRequest options = new(1);
private readonly TrajectoryPlanParser trajectoryPlanParser = new();
private readonly TrajectoryFactManualParser trajectoryFactManualParser = new();
[Fact]
public void Parse_trajectory_plan()
{
var stream = System.Reflection.Assembly.GetExecutingAssembly()
.GetManifestResourceStream($"{UsingTemplateFile}.TrajectoryPlanTemplate.xlsx");
if (stream is null)
Assert.Fail("Файла для импорта не существует");
var trajectoryRows = trajectoryPlanParser.Parse(stream, options);
Assert.Equal(3, trajectoryRows.Item.Count());
}
[Fact]
public void Parse_trajectory_fact_manual()
{
var stream = System.Reflection.Assembly.GetExecutingAssembly()
.GetManifestResourceStream($"{UsingTemplateFile}.TrajectoryFactManualTemplate.xlsx");
if (stream is null)
Assert.Fail("Файла для импорта не существует");
var trajectoryRows = trajectoryFactManualParser.Parse(stream, options);
Assert.Equal(4, trajectoryRows.Item.Count());
}
}

View File

@ -1,170 +0,0 @@
using System;
using System.IO;
using AsbCloudInfrastructure;
using ClosedXML.Excel;
using Xunit;
namespace AsbCloudWebApi.Tests;
public class XLExtensionsTests
{
private const string cellUsed = "A1";
private const string sheetName = "test";
private readonly IXLWorkbook workbook;
public XLExtensionsTests()
{
workbook = new XLWorkbook();
workbook.Worksheets.Add(sheetName);
}
[Fact]
public void GetWorksheet_returns_sheet()
{
//act
var sheet = workbook.GetWorksheet(sheetName);
//assert
Assert.NotNull(sheet);
}
[Theory]
[MemberData(nameof(valueTypesToSet))]
public void SetCellValue_returns_success(object value, XLDataType expectedDataType)
{
//act
var cell = GetCell(cellUsed);
cell.SetCellValue(value);
//assert
Assert.Equal(expectedDataType, cell.DataType);
}
[Fact]
public void GetCellValue_returns_double()
{
//arrange
const double expectedValue = 2.0d;
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<double>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Fact]
public void GetCellValue_returns_float()
{
//arrange
const float expectedValue = 2.0f;
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<float>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Theory]
[InlineData("test")]
[InlineData(null)]
public void GetCellValue_returns_string(string? expectedValue)
{
//arrange
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<string>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Fact]
public void GetCellValue_returns_bool()
{
//arrange
const bool expectedValue = true;
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<bool>();
//assert
Assert.Equal(expectedValue, actualValue);
}
[Fact]
public void GetCellValue_returns_dateTime()
{
//arrange
var expectedValue = DateTime.Parse("2023-01-01");
SetCellValue(expectedValue);
//act
var actualValue = GetCell(cellUsed).GetCellValue<DateTime>();
//assert
Assert.Equal(expectedValue, actualValue);
Assert.Equal(DateTimeKind.Unspecified, actualValue.Kind);
}
[Fact]
public void GetCellValue_returns_exception()
{
//arrange
SetCellValue("test");
//assert
Assert.Throws<FileFormatException>(() => GetCell(cellUsed).GetCellValue<double>());
}
[Fact]
public void GetCellValue_returns_nullable()
{
//act
var actualValue = GetCell(cellUsed).GetCellValue<object?>();
//assert
Assert.Null(actualValue);
}
[Fact]
public void SetHyperlink_returns_success()
{
//arrange
const string link = "http://test.ru";
//act
GetCell(cellUsed).SetHyperlink(link);
//assert
var hyperLink = GetCell(cellUsed).GetHyperlink();
Assert.NotNull(hyperLink);
}
private void SetCellValue<T>(T value)
{
var cell = GetCell(cellUsed);
cell.SetCellValue(value);
}
public static readonly object[][] valueTypesToSet =
{
new object[] { 2.0d, XLDataType.Number },
new object[] { 2.0f, XLDataType.Number },
new object[] { "test", XLDataType.Text },
new object[] { true, XLDataType.Boolean },
new object[] { DateTime.UtcNow, XLDataType.DateTime }
};
private IXLCell GetCell(string cellAddressInRange)
{
var sheet = workbook.GetWorksheet(sheetName);
return sheet.Cell(cellAddressInRange);
}
}