Reo.Core.IntegrationTesting
10.0.30
dotnet add package Reo.Core.IntegrationTesting --version 10.0.30
NuGet\Install-Package Reo.Core.IntegrationTesting -Version 10.0.30
<PackageReference Include="Reo.Core.IntegrationTesting" Version="10.0.30" />
<PackageVersion Include="Reo.Core.IntegrationTesting" Version="10.0.30" />
<PackageReference Include="Reo.Core.IntegrationTesting" />
paket add Reo.Core.IntegrationTesting --version 10.0.30
#r "nuget: Reo.Core.IntegrationTesting, 10.0.30"
#:package Reo.Core.IntegrationTesting@10.0.30
#addin nuget:?package=Reo.Core.IntegrationTesting&version=10.0.30
#tool nuget:?package=Reo.Core.IntegrationTesting&version=10.0.30
Reo.Core.IntegrationTesting
Описание пакета
Reo.Core.IntegrationTesting — это библиотека для упрощения написания интеграционных тестов в .NET-приложениях. Она предоставляет фикстуры для работы с различными системами (PostgreSQL, Redis, MongoDB, Elasticsearch), автоматизирует настройку и очистку тестовых данных, а также интегрируется с Moq.AutoMock для создания мок-объектов.
Решает следующие проблемы:
- Сложности настройки тестовых сред для разных баз данных и сервисов.
- Повторяющийся код для инициализации и очистки ресурсов.
- Нужда в абстракции для тестирования слоев, зависящих от внешних сервисов.
Основные функции:
- Автоматическая настройка тестовых баз данных (PostgreSQL, MongoDB и др.).
- Инструменты для работы с Elasticsearch, Redis и другими сервисами.
- Интеграция с Moq.AutoMock для мокирования зависимостей.
- Поддержка тестов с использованием контейнеров (Testcontainers).
Основные компоненты
| Компонент | Описание |
|---|---|
PostgresFixture<TDbContext> |
Фикстура для настройки PostgreSQL в тестах. Предоставляет DbContext и обрабатывает инициализацию/очистку БД. |
ElasticFixture |
Фикстура для работы с Elasticsearch. Обеспечивает доступ к клиенту Elasticsearch и настройку индексов. |
RedisFixture |
Фикстура для тестирования Redis. Создаёт и удаляет тестовые ключи в кэше. |
MongoFixture |
Фикстура для MongoDB. Обеспечивает доступ к клиенту MongoDB и управление коллекциями. |
AutoMockerExtensions |
Методы расширения для настройки Moq.AutoMock с фикстурами. |
TestFramework |
Модуль, управляющий жизненным циклом тестовых ресурсов (инициализация, очистка). |
Требования
- .NET: 8.0, 9.0
- Зависимости:
- Moq.AutoMock
- Testcontainers
- Npgsql (для PostgreSQL)
- MongoDB.Driver
- Elasticsearch.Net
Установка
Используйте следующие команды для установки пакета:
NuGet Package Manager:
Install-Package Reo.Core.IntegrationTesting
.NET CLI:
dotnet add package Reo.Core.IntegrationTesting
Настройка
Регистрация в DI-контейнере (ASP.NET Core)
Добавьте сервисы в Startup.cs или Program.cs:
services.AddIntegrationTestingServices(); // Если есть кастомные настройки
Конфигурационные параметры
Укажите параметры в appsettings.json или через AddSingleton:
{
"Testcontainers": {
"Postgres": {
"Image": "postgres:15",
"Username": "test",
"Password": "test"
},
"Mongo": {
"Image": "mongo:5.0",
"Username": "test",
"Password": "test"
}
}
}
Использование
Пример 1: Тест с PostgreSQL
[Fact]
public async Task TestWithPostgres()
{
// Arrange
var fixture = new PostgresFixture<MyDbContext>();
var dbContext = fixture.CreateContext();
// Act
await dbContext.MyEntities.AddAsync(new MyEntity { Name = "Test" });
await dbContext.SaveChangesAsync();
// Assert
var result = await dbContext.MyEntities.FirstOrDefaultAsync();
Assert.NotNull(result);
Assert.Equal("Test", result.Name);
}
Пример 2: Тест с Elasticsearch
[Fact]
public async Task TestWithElasticsearch()
{
// Arrange
var fixture = new ElasticFixture();
var client = fixture.Client;
// Act
await client.IndexAsync(new { Id = 1, Name = "Test" }, idx => idx.Index("test-index"));
// Assert
var result = await client.SearchAsync<TestDocument>(s => s
.Index("test-index")
.Query(q => q.Match(m => m.Field("name").Query("Test"))));
Assert.Single(result.Documents);
}
Пример 3: Использование AutoMocker
var mocker = new AutoMocker();
mocker.SetupPostgres<MyDbContext>(fixture); // Для PostgreSQL
var service = mocker.CreateInstance<MyService>();
service.DoSomething(); // Тест логики, зависящей от БД
Лицензия
Данный пакет распространяется под лицензией MIT.
Разработано с любовью для тестирования сложных систем! 🚀
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net10.0
- AspNetCore.HealthChecks.Elasticsearch (>= 9.0.0)
- AspNetCore.HealthChecks.MongoDb (>= 9.0.0)
- AspNetCore.HealthChecks.NpgSql (>= 9.0.0)
- AspNetCore.HealthChecks.Redis (>= 9.0.0)
- AspNetCore.HealthChecks.UI.Client (>= 9.0.0)
- AwesomeAssertions (>= 9.3.0)
- AwesomeAssertions.Analyzers (>= 9.0.8)
- Bogus (>= 35.6.5)
- coverlet.collector (>= 6.0.4)
- ertelecom.Serilog.Sinks.Graylog (>= 1.1.0)
- FluentValidation (>= 12.1.1)
- FluentValidation.AspNetCore (>= 11.3.1)
- Flurl (>= 4.0.0)
- Flurl.Http (>= 4.0.2)
- Flurl.Http.Newtonsoft (>= 0.9.1)
- Humanizer (>= 3.0.1)
- Humanizer.Core (>= 3.0.1)
- Humanizer.Core.ru (>= 3.0.1)
- IdentityModel (>= 7.0.0)
- JetBrains.Annotations (>= 2025.2.4)
- LinqKit.Core (>= 1.2.9)
- MassTransit (>= 8.5.8 && < 9.0.0)
- MassTransit.RabbitMQ (>= 8.5.8 && < 9.0.0)
- Meziantou.FluentAssertionsAnalyzers (>= 1.0.22)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 10.0.2)
- Microsoft.AspNetCore.Authentication.OpenIdConnect (>= 10.0.2)
- Microsoft.AspNetCore.Mvc.NewtonsoftJson (>= 10.0.2)
- Microsoft.AspNetCore.TestHost (>= 10.0.2)
- Microsoft.Bcl.AsyncInterfaces (>= 10.0.2)
- Microsoft.CodeAnalysis.Analyzers (>= 3.11.0)
- Microsoft.CodeAnalysis.Common (>= 5.0.0)
- Microsoft.CodeAnalysis.CSharp (>= 5.0.0)
- Microsoft.CodeAnalysis.CSharp.Workspaces (>= 5.0.0)
- Microsoft.CodeAnalysis.Workspaces.Common (>= 5.0.0)
- Microsoft.CodeAnalysis.Workspaces.MSBuild (>= 5.0.0)
- Microsoft.EntityFrameworkCore (>= 10.0.2)
- Microsoft.EntityFrameworkCore.Design (>= 10.0.2)
- Microsoft.EntityFrameworkCore.InMemory (>= 10.0.2)
- Microsoft.EntityFrameworkCore.Relational (>= 10.0.2)
- Microsoft.EntityFrameworkCore.Sqlite (>= 10.0.2)
- Microsoft.Extensions.Caching.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Caching.Memory (>= 10.0.2)
- Microsoft.Extensions.Caching.StackExchangeRedis (>= 10.0.2)
- Microsoft.Extensions.Configuration (>= 10.0.2)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Configuration.Binder (>= 10.0.2)
- Microsoft.Extensions.DependencyInjection (>= 10.0.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Diagnostics.HealthChecks.EntityFrameworkCore (>= 10.0.2)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Http.Polly (>= 10.0.2)
- Microsoft.Extensions.Logging (>= 10.0.2)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.2)
- Microsoft.Extensions.Options (>= 10.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 10.0.2)
- Microsoft.Extensions.TimeProvider.Testing (>= 10.2.0)
- Microsoft.NET.Test.Sdk (>= 18.0.1)
- MongoDB.Analyzer (>= 2.0.0)
- MongoDB.Driver (>= 3.6.0)
- Moq.Analyzers (>= 0.4.0)
- Moq.AutoMock (>= 3.5.0 && < 3.6.0)
- NEST (>= 7.17.5)
- NEST.JsonNetSerializer (>= 7.17.5)
- Newtonsoft.Json (>= 13.0.4)
- Npgsql.EntityFrameworkCore.PostgreSQL (>= 10.0.0)
- Polly (>= 8.5.0)
- RabbitMQ.Client (>= 7.2.0)
- RedLock.net (>= 2.3.2)
- Reo.Core.Database (>= 10.0.30)
- Reo.Core.Elastic (>= 10.0.30)
- Reo.Core.Logging (>= 10.0.30)
- Reo.Core.Testing (>= 10.0.30)
- Reo.Core.Xunit.IntegrationTesting (>= 10.0.30)
- Respawn (>= 7.0.0)
- Serilog (>= 4.3.0)
- Serilog.AspNetCore (>= 10.0.0)
- stbychkov.AutoLoggerMessage (>= 1.0.15)
- Swashbuckle.AspNetCore (>= 10.1.2)
- System.ComponentModel.Annotations (>= 5.0.0)
- System.IO.Abstractions (>= 22.1.0)
- System.Linq.Async (>= 7.0.0)
- TestableIO.System.IO.Abstractions.TestingHelpers (>= 22.1.0)
- Testcontainers (>= 4.10.0)
- Testcontainers.Elasticsearch (>= 4.10.0)
- Testcontainers.MongoDb (>= 4.10.0)
- Testcontainers.PostgreSql (>= 4.10.0)
- Testcontainers.RabbitMq (>= 4.10.0)
- Testcontainers.Redis (>= 4.10.0)
- xunit (>= 2.9.3)
- xunit.abstractions (>= 2.0.3)
- xunit.analyzers (>= 1.27.0)
- xunit.extensibility.core (>= 2.9.3)
- xunit.extensibility.execution (>= 2.9.3)
- xunit.runner.visualstudio (>= 3.1.5)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 10.0.30 | 0 | 2/12/2026 |
| 10.0.29 | 0 | 2/12/2026 |
| 10.0.28 | 38 | 2/11/2026 |
| 10.0.27 | 41 | 2/11/2026 |
| 10.0.26 | 48 | 2/9/2026 |
| 10.0.25 | 48 | 2/9/2026 |
| 10.0.24 | 53 | 2/9/2026 |
| 10.0.23 | 47 | 2/9/2026 |
| 10.0.22 | 46 | 2/9/2026 |
| 10.0.21 | 48 | 2/9/2026 |
| 10.0.20 | 48 | 2/9/2026 |
| 10.0.15 | 47 | 2/6/2026 |
| 10.0.14 | 50 | 2/6/2026 |
| 10.0.13 | 84 | 2/4/2026 |
| 10.0.12 | 79 | 2/3/2026 |
| 10.0.11 | 88 | 2/2/2026 |
| 10.0.10 | 82 | 1/29/2026 |
| 10.0.9 | 82 | 1/29/2026 |
| 10.0.8 | 84 | 1/27/2026 |
| 10.0.6 | 85 | 1/26/2026 |