MockQueryable.Moq
9.0.0
dotnet add package MockQueryable.Moq --version 9.0.0
NuGet\Install-Package MockQueryable.Moq -Version 9.0.0
<PackageReference Include="MockQueryable.Moq" Version="9.0.0" />
<PackageVersion Include="MockQueryable.Moq" Version="9.0.0" />
<PackageReference Include="MockQueryable.Moq" />
paket add MockQueryable.Moq --version 9.0.0
#r "nuget: MockQueryable.Moq, 9.0.0"
#:package MockQueryable.Moq@9.0.0
#addin nuget:?package=MockQueryable.Moq&version=9.0.0
#tool nuget:?package=MockQueryable.Moq&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)
- Moq (>= 4.20.72)
NuGet packages (11)
Showing the top 5 NuGet packages that depend on MockQueryable.Moq:
Package | Downloads |
---|---|
Reo.Core.Testing
Package Description |
|
Reo.Core.IntegrationTesting
Package Description |
|
Reo.Core.CodeGeneratorTesting
Package Description |
|
Zeesfam.NetLib
Package Description |
|
Franz.Common.Testing
Shared utility library for the Franz Framework. |
GitHub repositories (11)
Showing the top 11 popular GitHub repositories that depend on MockQueryable.Moq:
Repository | Stars |
---|---|
simplcommerce/SimplCommerce
A simple, cross platform, modulith ecommerce system built on .NET
|
|
Ombi-app/Ombi
Want a Movie or TV Show on Plex/Emby/Jellyfin? Use Ombi!
|
|
VirtoCommerce/vc-platform
Virto Commerce B2B Innovation Platform
|
|
CodeMazeBlog/CodeMazeGuides
The main repository for all the Code Maze guides
|
|
lkurzyniec/netcore-boilerplate
Boilerplate of API in .NET 9
|
|
Librum-Reader/Librum-Server
The Librum server
|
|
carlreid/StreamMaster
A powerful M3U proxy and stream management platform for Plex DVR, Emby, Jellyfin Live TV (and more)
|
|
Letterbook/Letterbook
Sustainable federated social media built for open correspondence
|
|
matt-bentley/CleanArchitecture
An opinionated ASP.NET Core solution setup for creating web applications using Clean Architecture and Domain-Driven Design principles.
|
|
SapiensAnatis/Dawnshard
Server emulator for Dragalia Lost
|
|
microsoftgraph/group-membership-management
Group Membership Management (GMM) is a service that dynamically manages the membership of AAD Groups. Groups managed by GMM can have their membership defined using existing AAD Groups and/or custom membership sources.
|
Version | Downloads | Last Updated |
---|---|---|
9.0.0 | 11,970 | 10/6/2025 |
8.0.1 | 5,800 | 10/6/2025 |
8.0.0 | 175,894 | 7/27/2025 |
7.0.4-beta | 86,311 | 9/24/2024 |
7.0.3 | 4,114,313 | 9/2/2024 |
7.0.2 | 156,991 | 8/20/2024 |
7.0.1 | 2,185,510 | 3/7/2024 |
7.0.0 | 4,037,627 | 11/21/2022 |
6.0.1 | 4,521,203 | 3/28/2022 |
6.0.0 | 227,278 | 3/24/2022 |
5.0.2 | 301,208 | 3/24/2022 |
5.0.1 | 2,618,104 | 5/25/2021 |
5.0.0 | 1,242,864 | 11/12/2020 |
5.0.0-preview.7 | 33,210 | 7/28/2020 |
3.1.3 | 2,113,306 | 5/19/2020 |
3.1.2 | 142,788 | 4/17/2020 |
3.1.1 | 401,857 | 1/25/2020 |
3.0.2 | 44,919 | 12/20/2019 |
3.0.1 | 46,804 | 10/11/2019 |
3.0.0 | 15,127 | 9/30/2019 |
1.1.0 | 688,102 | 2/28/2019 |
1.0.4 | 48,718 | 1/29/2019 |
1.0.3 | 309,229 | 8/30/2018 |
1.0.2 | 90,902 | 1/17/2018 |
1.0.1 | 9,606 | 12/26/2017 |
1.0.0 | 20,225 | 12/26/2017 |
Upgrade to .Net 9 and EntityFrameworkCore 9