Reo.Core.IntegrationTesting 10.0.29

There is a newer version of this package available.
See the version list below for details.
dotnet add package Reo.Core.IntegrationTesting --version 10.0.29
                    
NuGet\Install-Package Reo.Core.IntegrationTesting -Version 10.0.29
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Reo.Core.IntegrationTesting" Version="10.0.29" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Reo.Core.IntegrationTesting" Version="10.0.29" />
                    
Directory.Packages.props
<PackageReference Include="Reo.Core.IntegrationTesting" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Reo.Core.IntegrationTesting --version 10.0.29
                    
#r "nuget: Reo.Core.IntegrationTesting, 10.0.29"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Reo.Core.IntegrationTesting@10.0.29
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Reo.Core.IntegrationTesting&version=10.0.29
                    
Install as a Cake Addin
#tool nuget:?package=Reo.Core.IntegrationTesting&version=10.0.29
                    
Install as a Cake Tool

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 Модуль, управляющий жизненным циклом тестовых ресурсов (инициализация, очистка).

Требования


Установка

Используйте следующие команды для установки пакета:

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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
Loading failed