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:
You can also use this tools to create and run integration tests with the Integration tests in ASP.NET Core approach.
Since the version 2.0.0 this tools provide a comparer to compare the schema of two SQL databases.
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.
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.DbContext
during the development.To perform tests of a persistence layer, the approach is straightforward using the Arrange/Act/Assert pattern:
Before each test (TestMethod
or Fact
methods):
Create an empty database with the SQL schema of the application.
There are two ways to do this:
DbContext
using Entity Framework.Fill the tables with the sample data needed.
Execute the code (the method of the repository to be tested).
Assert the results of the executed code.
To write a test using this approach with the PosInformatique.Testing.Databases tools, see the Write tests to test the persistence layer page.
To perform tests of a database migration, the approach is straightforward and required only a test which perform the following actions:
Create an empty database (initial database).
Create a secondary database with the targeted schema (target database).
There are two ways to do this:
DbContext
using Entity Framework.Execute your database migration code on the initial database.
Your database migration code can be:
MigrateAsync()
method.Compare the two databases schemas (initial and target).
If the database migration code works, the initial and target must have 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.
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.
The PosInformatique.Testing.Databases tools are provided in two NuGet packages:
A complete sample solution is available in this repository inside the samples folder.
The solution contains the following sample projects:
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:
To write an test to check the migration of database, follow the Write tests to test database migration documentation page.
For Entity Framework migration: