forked from nhibernate/nhibernate-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFixture.cs
100 lines (90 loc) · 2.56 KB
/
Fixture.cs
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
91
92
93
94
95
96
97
98
99
100
//------------------------------------------------------------------------------
// <auto-generated>
// This code was generated by AsyncGenerator.
//
// Changes to this file may cause incorrect behavior and will be lost if
// the code is regenerated.
// </auto-generated>
//------------------------------------------------------------------------------
using System.Linq;
using NUnit.Framework;
using NHibernate.Linq;
namespace NHibernate.Test.NHSpecificTest.GH2465
{
using System.Threading.Tasks;
[TestFixture]
public class FixtureAsync : BugTestCase
{
protected override bool AppliesTo(Dialect.Dialect dialect)
{
return dialect.SupportsScalarSubSelects;
}
protected override void OnSetUp()
{
using (var session = OpenSession())
using (var transaction = session.BeginTransaction())
{
var applicant = new Entity {IdentityNames = {"name1", "name2"}};
session.Save(applicant);
transaction.Commit();
}
}
protected override void OnTearDown()
{
using (var session = OpenSession())
using (var transaction = session.BeginTransaction())
{
session.Delete("from System.Object");
transaction.Commit();
}
}
[Test]
public async Task ContainsInsideValueCollectionAsync()
{
using (var session = OpenSession())
using (var transaction = session.BeginTransaction())
{
var identityNames = new[] {"name1", "x"};
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.Any(n => identityNames.Contains(n)))
.ToListAsync());
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.All(n => identityNames.Contains(n)))
.ToListAsync());
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.FirstOrDefault(n => identityNames.Contains(n)) == "test")
.ToListAsync());
await (transaction.CommitAsync());
}
}
[Test]
public async Task EqualsInsideValueCollectionAsync()
{
using (var session = OpenSession())
using (var transaction = session.BeginTransaction())
{
var value = "test";
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.Any(n => n == value))
.ToListAsync());
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.Any(n => (string) n == value))
.ToListAsync());
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.All(n => n == value))
.ToListAsync());
await (session
.Query<Entity>()
.Where(a => a.IdentityNames.FirstOrDefault(n => n == "test") == "test")
.ToListAsync());
await (transaction.CommitAsync());
}
}
}
}