-
Notifications
You must be signed in to change notification settings - Fork 27
Expand file tree
/
Copy pathContainsTest.cs
More file actions
111 lines (99 loc) · 3.69 KB
/
ContainsTest.cs
File metadata and controls
111 lines (99 loc) · 3.69 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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// Copyright (C) 2020-2021 Xtensive LLC.
// This code is distributed under MIT license terms.
// See the License.txt file in the project root for more information.
using NUnit.Framework;
using Xtensive.Orm.BulkOperations.ContainsTestModel;
using Xtensive.Orm.Configuration;
namespace Xtensive.Orm.BulkOperations.ContainsTestModel
{
[HierarchyRoot]
[KeyGenerator(KeyGeneratorKind.None)]
public class TagType : Entity
{
[Field, Key]
public long Id { get; private set; }
[Field]
public int ProjectedValueAdjustment { get; set; }
public TagType(Session session, long id)
:base(session, id)
{
}
}
}
namespace Xtensive.Orm.BulkOperations.Tests
{
public class ContainsTest : BulkOperationBaseTest
{
private long[] tagIds;
protected override DomainConfiguration BuildConfiguration()
{
var configuration = base.BuildConfiguration();
configuration.Types.Register(typeof(TagType).Assembly, typeof(TagType).Namespace);
return configuration;
}
protected override void PopulateData()
{
tagIds = Enumerable.Range(0, 100).Select(i => (long) i).ToArray();
using (var session = Domain.OpenSession())
using (var transaction = session.OpenTransaction()) {
foreach (var id in tagIds.Concat(Enumerable.Repeat(1000, 1).Select(i => (long) i))) {
_ = new TagType(session, id) { ProjectedValueAdjustment = -1 };
}
transaction.Complete();
}
}
[Test]
public void Test1()
{
using (var session = Domain.OpenSession())
using (var tx = session.OpenTransaction()) {
var updatedRows = session.Query.All<TagType>()
.Where(t => t.Id.In(tagIds))
.Set(t => t.ProjectedValueAdjustment, 2)
.Update();
Assert.That(updatedRows, Is.EqualTo(100));
Assert.That(session.Query.All<TagType>().Count(t => t.ProjectedValueAdjustment == 2 && t.Id <= 200), Is.EqualTo(100));
Assert.That(session.Query.All<TagType>().Count(t => t.ProjectedValueAdjustment == -1 && t.Id > 700), Is.EqualTo(1));
}
}
[Test]
public void Test2()
{
using (var session = Domain.OpenSession())
using (var tx = session.OpenTransaction()) {
var updatedRows = session.Query.All<TagType>()
.Where(t => t.Id.In(IncludeAlgorithm.ComplexCondition, tagIds))
.Set(t => t.ProjectedValueAdjustment, 2)
.Update();
Assert.That(updatedRows, Is.EqualTo(100));
Assert.That(session.Query.All<TagType>().Count(t => t.ProjectedValueAdjustment == 2 && t.Id <= 200), Is.EqualTo(100));
Assert.That(session.Query.All<TagType>().Count(t => t.ProjectedValueAdjustment == -1 && t.Id > 700), Is.EqualTo(1));
}
}
[Test]
public void Test3()
{
using (var session = Domain.OpenSession())
using (var tx = session.OpenTransaction()) {
_ = Assert.Throws<NotSupportedException>(() => session.Query.All<TagType>()
.Where(t => t.Id.In(IncludeAlgorithm.TemporaryTable, tagIds))
.Set(t => t.ProjectedValueAdjustment, 2)
.Update());
}
}
[Test]
public void Test4()
{
using (var session = Domain.OpenSession())
using (var tx = session.OpenTransaction()) {
var updatedRows = session.Query.All<TagType>()
.Where(t => tagIds.Contains(t.Id))
.Set(t => t.ProjectedValueAdjustment, 2)
.Update();
Assert.That(updatedRows, Is.EqualTo(100));
Assert.That(session.Query.All<TagType>().Count(t => t.ProjectedValueAdjustment == 2 && t.Id <= 200), Is.EqualTo(100));
Assert.That(session.Query.All<TagType>().Count(t => t.ProjectedValueAdjustment == -1 && t.Id > 700), Is.EqualTo(1));
}
}
}
}