MockQueryable.NSubstitute
9.0.0
dotnet add package MockQueryable.NSubstitute --version 9.0.0
NuGet\Install-Package MockQueryable.NSubstitute -Version 9.0.0
<PackageReference Include="MockQueryable.NSubstitute" Version="9.0.0" />
<PackageVersion Include="MockQueryable.NSubstitute" Version="9.0.0" />
<PackageReference Include="MockQueryable.NSubstitute" />
paket add MockQueryable.NSubstitute --version 9.0.0
#r "nuget: MockQueryable.NSubstitute, 9.0.0"
#:package MockQueryable.NSubstitute@9.0.0
#addin nuget:?package=MockQueryable.NSubstitute&version=9.0.0
#tool nuget:?package=MockQueryable.NSubstitute&version=9.0.0
MockQueryable
Extensions for mocking Entity Framework Core async queries like ToListAsync
, FirstOrDefaultAsync
, and more using popular mocking libraries such as Moq, NSubstitute, and FakeItEasy — all without hitting the database.
❤️ If you really like the tool, please 👉 Support the project or ☕ Buy me a coffee.
📦 NuGet Packages
Package | Downloads | Latest Version | Install via Package Manager |
---|---|---|---|
MockQueryable.Core | Install-Package MockQueryable.Core |
||
MockQueryable.EntityFrameworkCore | Install-Package MockQueryable.EntityFrameworkCore |
||
MockQueryable.Moq | Install-Package MockQueryable.Moq |
||
MockQueryable.NSubstitute | Install-Package MockQueryable.NSubstitute |
||
MockQueryable.FakeItEasy | Install-Package MockQueryable.FakeItEasy |
✅ Build & Status
⭐ GitHub Stats
💡 Why Use MockQueryable?
Avoid hitting the real database in unit tests when querying via IQueryable
:
var query = _userRepository.GetQueryable();
await query.AnyAsync(x => ...);
await query.FirstOrDefaultAsync(x => ...);
await query.ToListAsync();
// etc.
🚀 Getting Started
1. Create Test Data
var users = new List<UserEntity>
{
new UserEntity { LastName = "Smith", DateOfBirth = new DateTime(2012, 1, 20) },
// More test data...
};
2. Build the Mock
var mock = users.BuildMock(); // for IQueryable
3. Set Up in Your favorite Mocking Framework
Moq
_userRepository.Setup(x => x.GetQueryable()).Returns(mock);
NSubstitute
_userRepository.GetQueryable().Returns(mock);
FakeItEasy
A.CallTo(() => userRepository.GetQueryable()).Returns(mock);
🗃️ Mocking DbSet<T>
var mockDbSet = users.BuildMockDbSet();
// Moq
var repo = new TestDbSetRepository(mockDbSet.Object);
// NSubstitute / FakeItEasy
var repo = new TestDbSetRepository(mockDbSet);
🔧 Adding Custom Logic
Example: Custom FindAsync
mock.Setup(x => x.FindAsync(userId)).ReturnsAsync((object[] ids) =>
{
var id = (Guid)ids[0];
return users.FirstOrDefault(x => x.Id == id);
});
Example: Custom Expression Visitor
Build a mock with the custom SampleLikeExpressionVisitor for testing EF.Functions.Like
var mockDbSet = users.BuildMockDbSet<UserEntity, SampleLikeExpressionVisitor>();
🧩 Extend for Other Frameworks
You can even create your own extensions. Check the example here.
🔍 Sample Project
See the sample project for working examples.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. 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. |
-
net9.0
- MockQueryable.EntityFrameworkCore (>= 9.0.0)
- NSubstitute (>= 5.3.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on MockQueryable.NSubstitute:
Repository | Stars |
---|---|
nuyonu/N-Tier-Architecture
This is a n-layer architecture based on Common web application architectures.
|
|
alex289/CleanArchitecture
Sample .NET 9 API project including Clean Architecture principles, Onion Architecture, MediatR, and Entity Framework with unit and integration tests using xUnit
|
Version | Downloads | Last Updated |
---|---|---|
9.0.0 | 2,002 | 10/6/2025 |
8.0.1 | 660 | 10/6/2025 |
8.0.0 | 68,106 | 7/27/2025 |
7.0.4-beta | 37,604 | 9/24/2024 |
7.0.3 | 1,087,678 | 9/2/2024 |
7.0.2 | 60,431 | 8/20/2024 |
7.0.1 | 720,075 | 3/7/2024 |
7.0.0 | 888,482 | 11/21/2022 |
6.0.1 | 688,565 | 3/28/2022 |
6.0.0 | 129,600 | 3/24/2022 |
5.0.2 | 64,065 | 3/24/2022 |
5.0.1 | 467,155 | 5/25/2021 |
5.0.0 | 142,268 | 11/12/2020 |
5.0.0-preview.7 | 661 | 7/28/2020 |
3.1.3 | 160,802 | 5/19/2020 |
3.1.2 | 19,716 | 4/17/2020 |
3.1.1 | 33,086 | 1/25/2020 |
3.0.2 | 5,543 | 12/20/2019 |
3.0.1 | 29,819 | 10/11/2019 |
3.0.1-alpha | 639 | 10/6/2019 |
3.0.0 | 1,159 | 9/30/2019 |
1.1.0 | 115,417 | 2/28/2019 |
1.0.4 | 19,573 | 1/29/2019 |
1.0.3 | 14,286 | 8/30/2018 |
1.0.2 | 6,312 | 7/6/2018 |
Upgrade to .Net 9 and EntityFrameworkCore 9