forked from ddrilling/AsbCloudServer
128 lines
3.8 KiB
C#
128 lines
3.8 KiB
C#
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using AsbCloudApp.Data.DetectedOperation;
|
|
using AsbCloudDb.Model;
|
|
using AsbCloudInfrastructure.Services.DetectOperations;
|
|
using AsbCloudInfrastructure.Services.DetectOperations.Detectors;
|
|
using Xunit;
|
|
|
|
namespace AsbCloudWebApi.Tests.Services.DetectedOperations.Detectors;
|
|
|
|
/// <summary>
|
|
/// Òåñòèðîâàíèå àâòîîïðåäåëåíèÿ îïåðàöèè "Ïðîìûâêà"
|
|
/// </summary>
|
|
public class DetectorFlashingTests : DetectorFlashing
|
|
{
|
|
private readonly DetectorFlashing detector = new();
|
|
|
|
/// <summary>
|
|
/// Îïåðàöèÿ, ïîïàäàþùàÿ ïîä àâòîîïðåäåëåíèå îïåðàöèè ïðîìûâêè
|
|
/// </summary>
|
|
private readonly DetectableTelemetry telemetry = new()
|
|
{
|
|
Pressure = 21,
|
|
WellDepth = 152,
|
|
BitDepth = 151,
|
|
RotorSpeed = 9,
|
|
DateTime = System.DateTimeOffset.Now
|
|
};
|
|
|
|
|
|
/// <summary>
|
|
/// Òåñòèðîâàíèå îïåðàöèé, ïîïàäàþùåé ïîä àâòîîïðåäåëåíèå îïåðàöèè ïðîìûâêè, ïðè ýòîì
|
|
/// - íàéäåí ïðèçíàê íà÷àëà îïåðàöèè
|
|
/// - íå íàéäåí ïðèçíàê îêîí÷àíèÿ îïåðàöèè
|
|
/// </summary>
|
|
[Fact]
|
|
public void DetectOperation_find_startOperation_notFind_endOperation()
|
|
{
|
|
//arrange
|
|
var point0 = telemetry.Copy();
|
|
var point1 = telemetry.Copy();
|
|
point1.DateTime = System.DateTimeOffset.Now.AddMinutes(5);
|
|
|
|
var telemetries = new[] { point0, point1 };
|
|
|
|
//act
|
|
var isDetectOperation = detector.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
|
|
|
|
//assert
|
|
Assert.True(isDetectOperation);
|
|
Assert.NotNull(result);
|
|
Assert.Equal(WellOperationCategory.IdFlashing, result.Operation.IdCategory);
|
|
Assert.Equal(IdReasonOfEnd_NotDetected, result.Operation.ExtraData["IdReasonOfEnd"]);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Îïåðàöèÿ, ó êîòîðîé ãëóáèíà äîëîòà = 150ì, íå ÿâëÿåòñÿ ïðîìûâêîé
|
|
/// </summary>
|
|
[Fact]
|
|
public void DetectOperation_with_BitDepth_LE_150_is_fail()
|
|
{
|
|
//arrange
|
|
var point0 = telemetry.Copy();
|
|
point0.BitDepth = 150;
|
|
|
|
var point1 = telemetry.Copy();
|
|
|
|
var telemetries = new[] { point0, point1 };
|
|
|
|
//act
|
|
|
|
var isDetectOperation = detector.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
|
|
|
|
//assert
|
|
Assert.False(isDetectOperation);
|
|
Assert.Null(result);
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// Îïåðàöèÿ, ó êîòîðîé ìåíÿåòñÿ ãëóáèíà çàáîÿ, íå ÿâëÿåòñÿ ïðîìûâêîé
|
|
/// </summary>
|
|
[Fact]
|
|
public void DetectOperation_with_DeltaWellDepth_NotEqual_0_is_fail()
|
|
{
|
|
//arrange
|
|
var point0 = telemetry.Copy();
|
|
var point1 = telemetry.Copy();
|
|
point1.WellDepth = point0.WellDepth + 10;
|
|
|
|
var telemetries = new[] { point0, point1 };
|
|
|
|
//act
|
|
var isDetectOperation = detector.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
|
|
|
|
//assert
|
|
Assert.False(isDetectOperation);
|
|
Assert.Null(result);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Íàéäåíû íà÷àëüíàÿ è êîíå÷íàÿ îïåðàöèè ïðîìûâêè,
|
|
/// Ïðèçíàê îêîí÷àíèÿ îïåðàöèè - ñíèæåíèå äàâëåíèÿ ìåíåå 10 àòì
|
|
/// </summary>
|
|
[Fact]
|
|
public void DetectOperations_Begin_And_End_by_Pressure_Less_20_is_success()
|
|
{
|
|
//arrange
|
|
var point0 = telemetry.Copy();
|
|
var point1 = telemetry.Copy();
|
|
point1.Pressure = 9;
|
|
point1.BitDepth = 140.0001f;
|
|
point1.RotorSpeed = 10;
|
|
|
|
var telemetries = new[] { point0, point1 };
|
|
|
|
//act
|
|
var isDetectOperation = detector.TryDetect(0, telemetries, 0, telemetries.Length - 1, null, out var result);
|
|
|
|
//assert
|
|
Assert.False(isDetectOperation);
|
|
Assert.NotNull(result);
|
|
Assert.Equal(WellOperationCategory.IdFlashing, result.Operation.IdCategory);
|
|
Assert.Equal(IdReasonOfEnd_PressureIsLo, result.Operation.ExtraData["IdReasonOfEnd"]);
|
|
}
|
|
|
|
|
|
} |