• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

loresoft / MediatR.CommandQuery / 8911801772

01 May 2024 04:09PM CUT coverage: 57.379% (-1.8%) from 59.163%
8911801772

push

github

pwelter34
tweak build

342 of 700 branches covered (48.86%)

Branch coverage included in aggregate %.

1011 of 1658 relevant lines covered (60.98%)

18.48 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

85.71
/src/MediatR.CommandQuery.EntityFrameworkCore/Handlers/EntityPagedQueryHandler.cs
1
using System.Linq.Dynamic.Core;
2

3
using AutoMapper;
4
using AutoMapper.QueryableExtensions;
5

6
using MediatR.CommandQuery.Extensions;
7
using MediatR.CommandQuery.Queries;
8

9
using Microsoft.EntityFrameworkCore;
10
using Microsoft.Extensions.Logging;
11

12
namespace MediatR.CommandQuery.EntityFrameworkCore.Handlers;
13

14
public class EntityPagedQueryHandler<TContext, TEntity, TReadModel>
15
    : DataContextHandlerBase<TContext, EntityPagedQuery<TReadModel>, EntityPagedResult<TReadModel>>
16
    where TContext : DbContext
17
    where TEntity : class
18
{
19

20
    public EntityPagedQueryHandler(ILoggerFactory loggerFactory, TContext dataContext, IMapper mapper)
21
        : base(loggerFactory, dataContext, mapper)
4✔
22
    {
23
    }
4✔
24

25

26
    protected override async Task<EntityPagedResult<TReadModel>> Process(EntityPagedQuery<TReadModel> request, CancellationToken cancellationToken)
27
    {
28
        if (request is null)
4!
29
            throw new ArgumentNullException(nameof(request));
×
30

31
        var query = DataContext
4✔
32
            .Set<TEntity>()
4✔
33
            .AsNoTracking();
4✔
34

35
        // build query from filter
36
        query = BuildQuery(request, query);
4✔
37

38
        // get total for query
39
        int total = await QueryTotal(request, query, cancellationToken)
4✔
40
            .ConfigureAwait(false);
4✔
41

42
        // short circuit if total is zero
43
        if (total == 0)
4!
44
            return new EntityPagedResult<TReadModel> { Data = new List<TReadModel>() };
×
45

46
        // page the query and convert to read model
47
        var result = await QueryPaged(request, query, cancellationToken)
4✔
48
            .ConfigureAwait(false);
4✔
49

50
        return new EntityPagedResult<TReadModel>
4✔
51
        {
4✔
52
            Total = total,
4✔
53
            Data = result
4✔
54
        };
4✔
55
    }
4✔
56

57

58
    protected virtual IQueryable<TEntity> BuildQuery(EntityPagedQuery<TReadModel> request, IQueryable<TEntity> query)
59
    {
60
        var entityQuery = request.Query;
4✔
61

62
        // build query from filter
63
        if (entityQuery?.Filter != null)
4!
64
            query = query.Filter(entityQuery.Filter);
4✔
65

66
        // add raw query
67
        if (!string.IsNullOrEmpty(entityQuery?.Query))
4!
68
            query = query.Where(entityQuery.Query);
×
69

70

71
        return query;
4✔
72
    }
73

74
    protected virtual async Task<int> QueryTotal(EntityPagedQuery<TReadModel> request, IQueryable<TEntity> query, CancellationToken cancellationToken)
75
    {
76
        return await query
4✔
77
            .CountAsync(cancellationToken)
4✔
78
            .ConfigureAwait(false);
4✔
79
    }
4✔
80

81
    protected virtual async Task<IReadOnlyCollection<TReadModel>> QueryPaged(EntityPagedQuery<TReadModel> request, IQueryable<TEntity> query, CancellationToken cancellationToken)
82
    {
83
        var entityQuery = request.Query;
4✔
84

85
        var queryable = query
4✔
86
            .Sort(entityQuery.Sort);
4✔
87

88
        if (entityQuery.Page > 0 && entityQuery.PageSize > 0)
4✔
89
            queryable = queryable.Page(entityQuery.Page, entityQuery.PageSize);
4✔
90

91
        return await queryable
4✔
92
            .ProjectTo<TReadModel>(Mapper.ConfigurationProvider)
4✔
93
            .ToListAsync(cancellationToken)
4✔
94
            .ConfigureAwait(false);
4✔
95
    }
4✔
96
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc