forked from ddrilling/AsbCloudServer
Интеграционный тест для сопоставления категорий между шаблонами импорта/экспорта ГГД и записями в БД
This commit is contained in:
parent
0b4fbe34ce
commit
dc96d03740
Binary file not shown.
Binary file not shown.
@ -29,4 +29,10 @@ public interface IWellOperationClient
|
|||||||
|
|
||||||
[Get(BaseRoute + "/export")]
|
[Get(BaseRoute + "/export")]
|
||||||
Task<IApiResponse<PhysicalFileResult>> ExportAsync(int idWell, int idType);
|
Task<IApiResponse<PhysicalFileResult>> ExportAsync(int idWell, int idType);
|
||||||
|
|
||||||
|
[Get(BaseRoute + "/template")]
|
||||||
|
Task<IApiResponse<Stream>> GetTemplate(int idWell, int idType);
|
||||||
|
|
||||||
|
[Get(BaseRoute + "/categories")]
|
||||||
|
Task<IApiResponse<IEnumerable<WellOperationCategoryDto>>> GetCategories(int idWell, bool includeParents, bool includeHidden);
|
||||||
}
|
}
|
@ -1,208 +1,250 @@
|
|||||||
using System.Net;
|
|
||||||
using System.Reflection;
|
|
||||||
using AsbCloudApp.Data.WellOperation;
|
using AsbCloudApp.Data.WellOperation;
|
||||||
using AsbCloudApp.Requests;
|
using AsbCloudApp.Requests;
|
||||||
using AsbCloudDb.Model;
|
using AsbCloudDb.Model;
|
||||||
|
using AsbCloudInfrastructure;
|
||||||
using AsbCloudWebApi.IntegrationTests.Clients;
|
using AsbCloudWebApi.IntegrationTests.Clients;
|
||||||
using AsbCloudWebApi.IntegrationTests.Data;
|
using AsbCloudWebApi.IntegrationTests.Data;
|
||||||
|
using ClosedXML.Excel;
|
||||||
using Mapster;
|
using Mapster;
|
||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using Refit;
|
using Refit;
|
||||||
|
using System.Net;
|
||||||
|
using System.Reflection;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace AsbCloudWebApi.IntegrationTests.Controllers.WellOperations;
|
namespace AsbCloudWebApi.IntegrationTests.Controllers.WellOperations;
|
||||||
|
|
||||||
public class WellOperationControllerTest : BaseIntegrationTest
|
public class WellOperationControllerTest : BaseIntegrationTest
|
||||||
{
|
{
|
||||||
private IWellOperationClient client;
|
private IWellOperationClient client;
|
||||||
|
|
||||||
public WellOperationControllerTest(WebAppFactoryFixture factory)
|
public WellOperationControllerTest(WebAppFactoryFixture factory)
|
||||||
: base(factory)
|
: base(factory)
|
||||||
{
|
{
|
||||||
client = factory.GetAuthorizedHttpClient<IWellOperationClient>(string.Empty);
|
client = factory.GetAuthorizedHttpClient<IWellOperationClient>(string.Empty);
|
||||||
|
|
||||||
dbContext.CleanupDbSet<WellOperation>();
|
dbContext.CleanupDbSet<WellOperation>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Успешное добавление операций (без предварительной очистки данных)
|
/// Успешное добавление операций (без предварительной очистки данных)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task InsertRange_returns_success()
|
public async Task InsertRange_returns_success()
|
||||||
{
|
{
|
||||||
//arrange
|
//arrange
|
||||||
var well = await dbContext.Wells.FirstAsync();
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
var entity = CreateWellOperation(well.Id);
|
var entity = CreateWellOperation(well.Id);
|
||||||
var dtos = new[] { entity.Adapt<WellOperationDto>() };
|
var dtos = new[] { entity.Adapt<WellOperationDto>() };
|
||||||
|
|
||||||
//act
|
//act
|
||||||
var response = await client.InsertRangeAsync(well.Id, false, dtos);
|
var response = await client.InsertRangeAsync(well.Id, false, dtos);
|
||||||
|
|
||||||
//assert
|
//assert
|
||||||
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Успешное добавление операций (с предварительной очисткой данных)
|
/// Успешное добавление операций (с предварительной очисткой данных)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task InsertRangeWithDeleteBefore_returns_success()
|
public async Task InsertRangeWithDeleteBefore_returns_success()
|
||||||
{
|
{
|
||||||
//arrange
|
//arrange
|
||||||
var well = await dbContext.Wells.FirstAsync();
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
var entity = CreateWellOperation(well.Id);
|
var entity = CreateWellOperation(well.Id);
|
||||||
var dtos = new[] { entity.Adapt<WellOperationDto>() };
|
var dtos = new[] { entity.Adapt<WellOperationDto>() };
|
||||||
|
|
||||||
//act
|
//act
|
||||||
var response = await client.InsertRangeAsync(well.Id, true, dtos);
|
var response = await client.InsertRangeAsync(well.Id, true, dtos);
|
||||||
|
|
||||||
//assert
|
//assert
|
||||||
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Успешное обновление операций
|
/// Успешное обновление операций
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task UpdateRangeAsync_returns_success()
|
public async Task UpdateRangeAsync_returns_success()
|
||||||
{
|
{
|
||||||
//arrange
|
//arrange
|
||||||
var well = await dbContext.Wells.FirstAsync();
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
var entity = CreateWellOperation(well.Id);
|
var entity = CreateWellOperation(well.Id);
|
||||||
dbContext.WellOperations.Add(entity);
|
dbContext.WellOperations.Add(entity);
|
||||||
await dbContext.SaveChangesAsync();
|
await dbContext.SaveChangesAsync();
|
||||||
|
|
||||||
var dtos = new[] { entity.Adapt<WellOperationDto>() };
|
var dtos = new[] { entity.Adapt<WellOperationDto>() };
|
||||||
|
|
||||||
//act
|
//act
|
||||||
var response = await client.UpdateRangeAsync(well.Id, dtos);
|
var response = await client.UpdateRangeAsync(well.Id, dtos);
|
||||||
|
|
||||||
//assert
|
//assert
|
||||||
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Получение плановых операций
|
/// Получение плановых операций
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task GetPageOperationsAsync_returns_first_page()
|
public async Task GetPageOperationsAsync_returns_first_page()
|
||||||
{
|
{
|
||||||
//arrange
|
//arrange
|
||||||
const int pageSize = 10;
|
const int pageSize = 10;
|
||||||
const int pageIndex = 0;
|
const int pageIndex = 0;
|
||||||
|
|
||||||
var well = await dbContext.Wells.FirstAsync();
|
|
||||||
var entity = CreateWellOperation(well.Id);
|
|
||||||
dbContext.WellOperations.Add(entity);
|
|
||||||
await dbContext.SaveChangesAsync();
|
|
||||||
|
|
||||||
var dto = entity.Adapt<WellOperationDto>();
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
var timezoneOffset = TimeSpan.FromHours(well.Timezone.Hours);
|
var entity = CreateWellOperation(well.Id);
|
||||||
dto.DateStart = dto.DateStart.ToOffset(timezoneOffset);
|
dbContext.WellOperations.Add(entity);
|
||||||
dto.LastUpdateDate = dto.LastUpdateDate?.ToOffset(timezoneOffset);
|
await dbContext.SaveChangesAsync();
|
||||||
|
|
||||||
var request = new WellOperationRequestBase
|
var dto = entity.Adapt<WellOperationDto>();
|
||||||
{
|
var timezoneOffset = TimeSpan.FromHours(well.Timezone.Hours);
|
||||||
OperationType = WellOperation.IdOperationTypePlan,
|
dto.DateStart = dto.DateStart.ToOffset(timezoneOffset);
|
||||||
Skip = pageIndex,
|
dto.LastUpdateDate = dto.LastUpdateDate?.ToOffset(timezoneOffset);
|
||||||
Take = pageSize,
|
|
||||||
};
|
|
||||||
|
|
||||||
//act
|
var request = new WellOperationRequestBase
|
||||||
var response = await client.GetPageOperationsAsync(well.Id, request);
|
{
|
||||||
|
OperationType = WellOperation.IdOperationTypePlan,
|
||||||
|
Skip = pageIndex,
|
||||||
|
Take = pageSize,
|
||||||
|
};
|
||||||
|
|
||||||
//assert
|
//act
|
||||||
Assert.Equal(response.StatusCode, HttpStatusCode.OK);
|
var response = await client.GetPageOperationsAsync(well.Id, request);
|
||||||
Assert.NotNull(response.Content);
|
|
||||||
|
|
||||||
var totalExpected = response.Content.Count - pageSize * pageIndex;
|
//assert
|
||||||
Assert.Equal(totalExpected, response.Content.Items.Count());
|
Assert.Equal(response.StatusCode, HttpStatusCode.OK);
|
||||||
|
Assert.NotNull(response.Content);
|
||||||
|
|
||||||
Assert.Single(response.Content.Items);
|
var totalExpected = response.Content.Count - pageSize * pageIndex;
|
||||||
var actualDto = response.Content.Items.First();
|
Assert.Equal(totalExpected, response.Content.Items.Count());
|
||||||
|
|
||||||
MatchHelper.Match(dto, actualDto);
|
Assert.Single(response.Content.Items);
|
||||||
}
|
var actualDto = response.Content.Items.First();
|
||||||
|
|
||||||
[Theory]
|
MatchHelper.Match(dto, actualDto);
|
||||||
[InlineData(WellOperation.IdOperationTypePlan, "PlanWellOperations.xlsx")]
|
}
|
||||||
[InlineData(WellOperation.IdOperationTypeFact, "FactWellOperations.xlsx")]
|
|
||||||
public async Task ParseAsync_returns_success(int idType, string fileName)
|
|
||||||
{
|
|
||||||
//arrange
|
|
||||||
var well = await dbContext.Wells.FirstAsync();
|
|
||||||
|
|
||||||
var expectedDto = new WellOperationDto
|
[Theory]
|
||||||
{
|
[InlineData(WellOperation.IdOperationTypePlan, "PlanWellOperations.xlsx")]
|
||||||
IdWell = well.Id,
|
[InlineData(WellOperation.IdOperationTypeFact, "FactWellOperations.xlsx")]
|
||||||
IdWellSectionType = 2,
|
public async Task ParseAsync_returns_success(int idType, string fileName)
|
||||||
IdCategory = WellOperationCategory.IdSlide,
|
{
|
||||||
IdPlan = null,
|
//arrange
|
||||||
CategoryInfo = "Доп.инфо",
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
IdType = idType,
|
|
||||||
DepthStart = 10.0,
|
|
||||||
DepthEnd = 20.0,
|
|
||||||
DateStart = new DateTimeOffset(new DateTime(2023, 1, 10), TimeSpan.FromHours(well.Timezone.Hours)),
|
|
||||||
DurationHours = 1.0,
|
|
||||||
Comment = "123",
|
|
||||||
};
|
|
||||||
|
|
||||||
var stream = Assembly.GetExecutingAssembly().GetFileCopyStream(fileName);
|
var expectedDto = new WellOperationDto
|
||||||
|
{
|
||||||
|
IdWell = well.Id,
|
||||||
|
IdWellSectionType = 2,
|
||||||
|
IdCategory = WellOperationCategory.IdSlide,
|
||||||
|
IdPlan = null,
|
||||||
|
CategoryInfo = "Доп.инфо",
|
||||||
|
IdType = idType,
|
||||||
|
DepthStart = 10.0,
|
||||||
|
DepthEnd = 20.0,
|
||||||
|
DateStart = new DateTimeOffset(new DateTime(2023, 1, 10), TimeSpan.FromHours(well.Timezone.Hours)),
|
||||||
|
DurationHours = 1.0,
|
||||||
|
Comment = "123",
|
||||||
|
};
|
||||||
|
|
||||||
var streamPart = new StreamPart(stream, fileName, "application/octet-stream");
|
var stream = Assembly.GetExecutingAssembly().GetFileCopyStream(fileName);
|
||||||
|
|
||||||
//act
|
var streamPart = new StreamPart(stream, fileName, "application/octet-stream");
|
||||||
var response = await client.ParseAsync(well.Id, idType, streamPart);
|
|
||||||
|
|
||||||
//assert
|
//act
|
||||||
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
var response = await client.ParseAsync(well.Id, idType, streamPart);
|
||||||
Assert.NotNull(response.Content);
|
|
||||||
|
|
||||||
var actualDto = response.Content.Item.First().Item;
|
//assert
|
||||||
|
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
||||||
|
Assert.NotNull(response.Content);
|
||||||
|
|
||||||
MatchHelper.Match(expectedDto, actualDto);
|
var actualDto = response.Content.Item.First().Item;
|
||||||
}
|
|
||||||
|
|
||||||
[Theory]
|
MatchHelper.Match(expectedDto, actualDto);
|
||||||
[InlineData(WellOperation.IdOperationTypePlan)]
|
}
|
||||||
[InlineData(WellOperation.IdOperationTypeFact)]
|
|
||||||
public async Task ExportAsync_returns_success(int idType)
|
|
||||||
{
|
|
||||||
//arrange
|
|
||||||
var well = await dbContext.Wells.FirstAsync();
|
|
||||||
|
|
||||||
var entity = CreateWellOperation(well.Id, idType);
|
[Theory]
|
||||||
dbContext.WellOperations.Add(entity);
|
[InlineData(WellOperation.IdOperationTypePlan)]
|
||||||
await dbContext.SaveChangesAsync();
|
[InlineData(WellOperation.IdOperationTypeFact)]
|
||||||
|
public async Task ExportAsync_returns_success(int idType)
|
||||||
|
{
|
||||||
|
//arrange
|
||||||
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
|
|
||||||
//act
|
var entity = CreateWellOperation(well.Id, idType);
|
||||||
var response = await client.ExportAsync(well.Id, idType);
|
dbContext.WellOperations.Add(entity);
|
||||||
|
await dbContext.SaveChangesAsync();
|
||||||
|
|
||||||
//assert
|
//act
|
||||||
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
var response = await client.ExportAsync(well.Id, idType);
|
||||||
Assert.Equal("application/octet-stream", response.ContentHeaders?.ContentType?.MediaType);
|
|
||||||
Assert.True(response.ContentHeaders?.ContentLength > 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static WellOperation CreateWellOperation(int idWell, int idType = WellOperation.IdOperationTypePlan) =>
|
//assert
|
||||||
new()
|
Assert.Equal(HttpStatusCode.OK, response.StatusCode);
|
||||||
{
|
Assert.Equal("application/octet-stream", response.ContentHeaders?.ContentType?.MediaType);
|
||||||
IdWell = idWell,
|
Assert.True(response.ContentHeaders?.ContentLength > 0);
|
||||||
IdWellSectionType = 2,
|
}
|
||||||
IdCategory = WellOperationCategory.IdSlide,
|
|
||||||
IdPlan = null,
|
[Theory]
|
||||||
CategoryInfo = "Доп.инфо",
|
[InlineData(WellOperation.IdOperationTypePlan)]
|
||||||
LastUpdateDate = new DateTimeOffset(new DateTime(2023, 1, 10)).ToUniversalTime(),
|
[InlineData(WellOperation.IdOperationTypeFact)]
|
||||||
IdType = idType,
|
public async Task MatchCategoriesFromTemplateAndDb_returns_success(int idType)
|
||||||
DepthStart = 10.0,
|
{
|
||||||
DepthEnd = 20.0,
|
//arrange
|
||||||
DateStart = new DateTimeOffset(new DateTime(2023, 1, 10), TimeSpan.FromHours(Defaults.Timezone.Hours)).ToUniversalTime(),
|
var well = await dbContext.Wells.FirstAsync();
|
||||||
DurationHours = 1.0,
|
var responseTemplate = await client.GetTemplate(well.Id, idType);
|
||||||
Comment = "1",
|
var stream = responseTemplate.Content;
|
||||||
IdUser = 1,
|
|
||||||
};
|
using var workbook = new XLWorkbook(stream);
|
||||||
|
var sheet = workbook.GetWorksheet("Справочники");
|
||||||
|
|
||||||
|
var count = sheet.RowsUsed().Count() - 1;
|
||||||
|
|
||||||
|
var categoryCaptionsInTemplate = new List<string>();
|
||||||
|
for (var i = 0; i < count; i++)
|
||||||
|
{
|
||||||
|
var xlRow = sheet.Row(i + 2);
|
||||||
|
var rowNumber = xlRow.RowNumber();
|
||||||
|
|
||||||
|
var xlCell = xlRow.Cell(1);
|
||||||
|
var cellValue = xlCell.GetText().Trim();
|
||||||
|
|
||||||
|
categoryCaptionsInTemplate.Add(cellValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
var responseCategories = await client.GetCategories(well.Id, false, false);
|
||||||
|
var categories = responseCategories.Content;
|
||||||
|
var categoryCaptionsInDb = categories!.Select(c => c.Name.Trim());
|
||||||
|
|
||||||
|
var notExistedInTemplate = categoryCaptionsInDb.Except(categoryCaptionsInTemplate);
|
||||||
|
var notExistedInDb = categoryCaptionsInTemplate.Except(categoryCaptionsInDb);
|
||||||
|
|
||||||
|
//assert
|
||||||
|
Assert.True(categoryCaptionsInDb.Count() == categoryCaptionsInTemplate.Count());
|
||||||
|
Assert.True(notExistedInTemplate.Count() == 0);
|
||||||
|
Assert.True(notExistedInDb.Count() == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static WellOperation CreateWellOperation(int idWell, int idType = WellOperation.IdOperationTypePlan) =>
|
||||||
|
new()
|
||||||
|
{
|
||||||
|
IdWell = idWell,
|
||||||
|
IdWellSectionType = 2,
|
||||||
|
IdCategory = WellOperationCategory.IdSlide,
|
||||||
|
IdPlan = null,
|
||||||
|
CategoryInfo = "Доп.инфо",
|
||||||
|
LastUpdateDate = new DateTimeOffset(new DateTime(2023, 1, 10)).ToUniversalTime(),
|
||||||
|
IdType = idType,
|
||||||
|
DepthStart = 10.0,
|
||||||
|
DepthEnd = 20.0,
|
||||||
|
DateStart = new DateTimeOffset(new DateTime(2023, 1, 10), TimeSpan.FromHours(Defaults.Timezone.Hours)).ToUniversalTime(),
|
||||||
|
DurationHours = 1.0,
|
||||||
|
Comment = "1",
|
||||||
|
IdUser = 1,
|
||||||
|
};
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user