forked from zzzprojects/System.Linq.Dynamic.Core
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathQueryableTests.Max.cs
More file actions
90 lines (74 loc) · 2.1 KB
/
QueryableTests.Max.cs
File metadata and controls
90 lines (74 loc) · 2.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
using System.Linq.Dynamic.Core.Tests.Helpers.Models;
using FluentAssertions;
using Xunit;
namespace System.Linq.Dynamic.Core.Tests;
public partial class QueryableTests
{
[Fact]
public void Max()
{
// Arrange
var incomes = User.GenerateSampleModels(10).Select(u => u.Income).ToArray();
// Act
var expected = incomes.Max();
var actual = incomes.AsQueryable().Max();
// Assert
Assert.Equal(expected, actual);
}
[Fact]
public void Max_Selector()
{
// Arrange
var users = User.GenerateSampleModels(10);
// Act
var expected = users.Max(u => u.Income);
var result = users.AsQueryable().Max("Income");
// Assert
Assert.Equal(expected, result);
}
[Fact]
public void Max_Where_On_Int()
{
// Arrange
var users = User.GenerateSampleModels(10);
// Act
var typed = users
.Where(u => users.Max(m => m.Income) == u.Income)
.ToList();
var dynamic = users.AsQueryable()
.Where("@0.Max(Income) == Income", users)
.ToList();
// Assert
dynamic.Should().BeEquivalentTo(typed);
}
[Fact]
public void Max_Where_On_DateTime()
{
// Arrange
var users = User.GenerateSampleModels(10);
// Act
var typed = users
.Where(u => users.Max(m => m.BirthDate) == u.BirthDate)
.ToList();
var dynamic = users.AsQueryable()
.Where("@0.Max(BirthDate) == BirthDate", users)
.ToList();
// Assert
dynamic.Should().BeEquivalentTo(typed);
}
[Fact]
public void Max_Where_On_NullableDateTime()
{
// Arrange
var users = User.GenerateSampleModels(10);
// Act
var typed = users
.Where(u => users.Max(m => m.EndDate) == u.EndDate)
.ToList();
var dynamic = users.AsQueryable()
.Where("@0.Max(EndDate) == EndDate", users)
.ToList();
// Assert
dynamic.Should().BeEquivalentTo(typed);
}
}