PosInformatique.Testing.Databases.SqlServer.EntityFramework 3.0.0

Prefix Reserved
dotnet add package PosInformatique.Testing.Databases.SqlServer.EntityFramework --version 3.0.0
                    
NuGet\Install-Package PosInformatique.Testing.Databases.SqlServer.EntityFramework -Version 3.0.0
                    
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="PosInformatique.Testing.Databases.SqlServer.EntityFramework" Version="3.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="PosInformatique.Testing.Databases.SqlServer.EntityFramework" Version="3.0.0" />
                    
Directory.Packages.props
<PackageReference Include="PosInformatique.Testing.Databases.SqlServer.EntityFramework" />
                    
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 PosInformatique.Testing.Databases.SqlServer.EntityFramework --version 3.0.0
                    
#r "nuget: PosInformatique.Testing.Databases.SqlServer.EntityFramework, 3.0.0"
                    
#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 PosInformatique.Testing.Databases.SqlServer.EntityFramework@3.0.0
                    
#: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=PosInformatique.Testing.Databases.SqlServer.EntityFramework&version=3.0.0
                    
Install as a Cake Addin
#tool nuget:?package=PosInformatique.Testing.Databases.SqlServer.EntityFramework&version=3.0.0
                    
Install as a Cake Tool

PosInformatique.Testing.Databases

Package NuGet
PosInformatique.Testing.Databases.SqlServer NuGet
PosInformatique.Testing.Databases.SqlServer.Dac NuGet
PosInformatique.Testing.Databases.SqlServer.EntityFramework NuGet
PosInformatique.Testing.Databases.SqlServer.SqlCmd NuGet

PosInformatique.Testing.Databases is a set of tools for testing databases. It simplifies writing and executing tests, helping ensure your database and data access code are reliable and bug-free. It is ideal for developers who want to validate data access based on SQL Server code during their development.

This set of tools supports testing of the persistence layer based on SQL Server. Any kind of data access framework can be used with these tools:

  • Raw ADO .NET queries.
  • Entity Framework.
  • Dapper.
  • ...

You can also use this tools to create and run integration tests with the Integration tests in ASP.NET Core approach.

Main release improvements

๐Ÿ’ก The approach of these tools

The main approach of these tools is to perform tests without using mocking or in-memory alternatives for ADO .NET code or Entity Framework DbContext, instead using a real SQL Server database.

Also, these tools offer simple way to compare two SQL databases to test migration script (or Entity Framework migration) when upgrading a database.

  • Around 30% to 40% of the code in applications is located in the persistence layer or repository components. Because it is hard to test, developers often skip testing, resulting in lower code coverage.
  • When using a mock or in-memory approach for a DbContext, you don't truly test the Entity Framework mapping to your database, especially additional SQL constraints like nullability, uniqueness, foreign key cascades, etc. You also miss technical behaviors like transactions, connection management, triggers, etc.
  • When inserting data, it is crucial to ensure that the data in the columns are stored correctly (null/not null values, enum values to numerical values, custom or JSON serialized data, etc.).
  • If you use Entity Framework, you can detect warnings/errors raised by the DbContext during the development.
  • You perform test cases, meaning you write simple tests to validate small features instead of writing complex integration tests.
  • When changing the schema of the database, it is important to test and have a safeguard to check that the migration script (or Entity Framework migration actions) will update the database to the expected schema.

๐Ÿงช How to test a persistence layer

To perform tests of a persistence layer, the approach is straightforward using the Arrange/Act/Assert pattern:

Before each test (TestMethod or Fact methods):

  1. Create an empty database with the SQL schema of the application.

    There are three ways to do this:

  2. Fill the tables with the sample data needed.

  3. Execute the code (the method of the repository to be tested).

  4. Assert the results of the executed code.

    • If the tested method returns data (performs a SELECT query), assert the returned objects using your favorite assertion framework (e.g., FluentAssertions).
    • If the method inserts, updates, or deletes data, assert the content of the tables to check that all data is stored correctly.

To write a test using this approach with the PosInformatique.Testing.Databases tools, see the Write tests to test the persistence layer page.

๐Ÿงช How to test database migration

To perform tests of a database migration, the approach is straightforward and required only a test which perform the following actions:

  1. Create an empty database (initial database).

  2. Create a secondary database with the targeted schema (target database).

    There are three ways to do this:

  3. Execute your database migration code on the initial database.

    Your database migration code can be:

    • A simple SQL script file.
    • An Entity Framework migration sets executed with the MigrateAsync() method.
    • Or any other way that you usually use to migrate the schema of your database.
  4. Compare the two databases schemas (initial and target).

    If the database migration code works, the initial and target must have EXACTLY the same schema.

NB: The initial database is not necessarily empty. It can be at a specific schema version X if we want to test the migration from version X to Y.

This approach does not test the migration of the data within the database. We can modify this process to inject some data in the first step to test it, but writing the test can be time-consuming. By focusing on the schema migration of the database, you can verify at least 80-90% of your database migration code. It's better than nothing and very useful for detecting issues during development or in a CI process!

To write a test using this approach with the PosInformatique.Testing.Databases tools, see the Write tests to test database migration page.

๐Ÿ“ค What do the PosInformatique.Testing.Databases tools provide?

Using the previous approach, the PosInformatique.Testing.Databases libraries allow you to:

  • Easily deploy a database before each test execution. Database and schema creation can take a lot of time (around 5 to 10 seconds). The PosInformatique.Testing.Databases libraries physically create the database during the first test execution. For subsequent tests, all data is deleted in the database, which speeds up the test execution.

  • Provide a simple syntax to fill the tables with sample data.

  • Offer helpers to easily query and retrieve data from SQL tables (for assertions).

  • Contain a comparer tool to check schema differences between two databases.

๐Ÿ“ฆ NuGet packages

The PosInformatique.Testing.Databases tools are provided in two NuGet packages:

๐Ÿš€ Samples / Demo

A complete sample solution is available in this repository inside the samples folder.

The solution contains the following sample projects:

๐Ÿ“ Writing tests for a persistence layer

To write tests for a persistence layer, follow the Write tests to test the persistence layer documentation page, which explains the different steps to perform using the PosInformatique.Testing.Databases.SqlServer.EntityFramework library:

๐Ÿ“ Writing test to check database migration

To write an test to check the migration of database, follow the Write tests to test database migration documentation page.

For Entity Framework migration:

๐Ÿ“ฆ NuGet package dependency versions

These tools rely on a minimal set of NuGet dependencies to ensure broad compatibility.
They are built for .NET Core 6.0 and .NET Framework 4.6.2 but also work seamlessly with newer versions of .NET:

  • .NET Framework 4.6.2
  • .NET Framework 4.7
  • .NET Framework 4.7.1
  • .NET Framework 4.7.2
  • .NET Framework 4.8
  • .NET Framework 4.8.1
  • .NET Core 6.0
  • .NET Core 7.0
  • .NET Core 8.0
  • .NET Core 9.0
  • .NET Core 10.0

Dependency versions

All NuGet packages depend on low baseline versions of Microsoft libraries to remain compatible with any modern version:

Recommendation

We recommend using the latest versions of these libraries in your own projects to benefit from the most recent features, performance improvements, and security fixes.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  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
3.0.0 56 10/24/2025
3.0.0-rc.4 187 9/25/2025
3.0.0-rc.3 119 9/24/2025
3.0.0-rc.2 107 9/24/2025
3.0.0-rc.1 149 9/23/2025
2.3.0 156 9/21/2025
2.2.0 107 9/5/2025
2.1.0 299 10/17/2024
2.0.0 146 9/27/2024

3.0.0
     - Add new PosInformatique.Testing.Databases.SqlCmd to initialize database using sqlcmd utility.
     - For DACPAC deployment or database creation it is now possible to specify the location of the data and log files.

     2.3.0
     - Add the support to compare the seed and increment for the IDENTITY columns

     2.2.0
     - Add SqlServerDatabase.ClearDataAsync() method.
     - Add SqlServer.CreateDatabase() method to create database from an Entity Framework DbContext.
     - Add SqlServer.CreateEmptyDatabaseAsync() method.
     - Add SqlServer.DeleteDatabaseAsync() method.
     - Add SqlServerDatabase.ExecuteScriptAsync() method.
     - Add SqlServerDatabase.InsertIntoAsync() method.

     2.1.0
     - PosInformatique.Testing.Databases.SqlServer target the .NET Standard 2.0 platform.
     - PosInformatique.Testing.Databases.SqlServer.Dac target the .NET Core 6.0 and .NET Framework 4.6.2
     - PosInformatique.Testing.Databases.SqlServer.EntityFramework target the .NET Core 6.0
     - Reduce the dependencies to Entity Framework 6.0
     - Reduce the dependencies of DACfx to a more earlier version.
     - Add new method SqlServerDatabase.ExecuteScript() to execute T-SQL scripts.

     2.0.0
     - Add SqlServerDatabaseComparer class to perform comparison between two databases.
     - Add new PosInformatique.Testing.Databases.SqlServer.Dac NuGet package which contains DAC package tools.
     - Add new SqlServer.CreateDatabaseAsync() extension method to create a database from a DbContext.
     - Reduce dependencies version of the Entity Framework Core and SQL Server Client NuGet packages.

     1.0.1
     - Fix the documentation

     1.0.0
     - Initial version