annotate UnitTests/Linq/UserTests/FirstOrDefaultNullReferenceExceptionTest.cs @ 6:11b6da379593

Исправлена странная ошибка при использовании OfType<...>().Where(...)
author cin
date Mon, 05 Dec 2016 05:50:52 +0300
parents f990fcb411a9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
1 using System;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
2 using System.Collections.Generic;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3 using System.Linq;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4 using BLToolkit.DataAccess;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5 using BLToolkit.Mapping;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
6
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
7 using NUnit.Framework;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
8
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
9 namespace Data.Linq.UserTests
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11 [TestFixture]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12 public class FirstOrDefaultNullReferenceExceptionTest : TestBase
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 [TableName("GrandChild")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15 class Table1
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 public int ChildID;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 [TableName("Child")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 class Table2
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 public int ChildID;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 public int ParentID;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26 [Association(ThisKey = "ChildID", OtherKey = "ChildID", CanBeNull = true)]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27 public List<Table1> GrandChildren { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 [TableName("Parent")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31 class Table3
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 public int ParentID { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35 [Association(ThisKey = "ParentID", OtherKey = "ParentID", CanBeNull = true)]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 public List<Table2> Children { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40 public void Test()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 using (var db = new TestDbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 /*
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 var query =
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 from t3 in db.Parent
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 //let t1 = t3.Children.SelectMany(x => x.GrandChildren)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48 //let t2 = t3.Table2s.SelectMany(x => x.Table1s)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49 select new
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 //c2 = t1.Count(),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52 c1 = t3.Children.SelectMany(x => x.GrandChildren),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 };
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54 */
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 var query =
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57 from t3 in db.GetTable<Table3>()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58 let t1 = t3.Children.SelectMany(x => x.GrandChildren)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59 //let t2 = t3.Table2s.SelectMany(x => x.Table1s)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60 select new
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62 c2 = t1.Count(),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63 c1 = t3.Children.SelectMany(x => x.GrandChildren).Count(),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64 };
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66 query.FirstOrDefault(p => p.c1 > 10);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70 }