annotate UnitTests/Linq/TestDbManager.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.Linq;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3 using System.Linq.Expressions;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4 using System.Reflection;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5 using System.Text;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
6
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
7 using BLToolkit.Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
8 using BLToolkit.Data.DataProvider;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
9 using BLToolkit.Data.Linq;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 using BLToolkit.Data.Sql;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12 namespace Data.Linq
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 using Model;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16 public class TestDbManager : DbManager, ITestDataContext
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18 public TestDbManager(string configString)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19 : base(configString)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 public TestDbManager()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 : base(ProviderName.Access)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28 public Table<Person> Person { get { return GetTable<Person>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29 public Table<Patient> Patient { get { return GetTable<Patient>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 public Table<Doctor> Doctor { get { return GetTable<Doctor>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31 public Table<Parent> Parent { get { return GetTable<Parent>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 public Table<Parent1> Parent1 { get { return GetTable<Parent1>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 public Table<IParent> Parent2 { get { return GetTable<IParent>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34 public Table<Parent4> Parent4 { get { return GetTable<Parent4>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35 public Table<Parent5> Parent5 { get { return GetTable<Parent5>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 public Table<ParentInheritanceBase> ParentInheritance { get { return GetTable<ParentInheritanceBase>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37 public Table<ParentInheritanceBase2> ParentInheritance2 { get { return GetTable<ParentInheritanceBase2>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38 public Table<ParentInheritanceBase3> ParentInheritance3 { get { return GetTable<ParentInheritanceBase3>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39 public Table<ParentInheritanceBase4> ParentInheritance4 { get { return GetTable<ParentInheritanceBase4>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40 public Table<ParentInheritance1> ParentInheritance1 { get { return GetTable<ParentInheritance1>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41 public Table<ParentInheritanceValue> ParentInheritanceValue { get { return GetTable<ParentInheritanceValue>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 public Table<Child> Child { get { return GetTable<Child>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43 public Table<GrandChild> GrandChild { get { return GetTable<GrandChild>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 public Table<GrandChild1> GrandChild1 { get { return GetTable<GrandChild1>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 public Table<LinqDataTypes> Types { get { return GetTable<LinqDataTypes>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 public Table<LinqDataTypes2> Types2 { get { return GetTable<LinqDataTypes2>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 public Table<TestIdentity> TestIdentity { get { return GetTable<TestIdentity>(); } }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49 [TableFunction(Name="GetParentByID")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50 public Table<Parent> GetParentByID(int? id)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52 return GetTable<Parent>(this, (MethodInfo)MethodBase.GetCurrentMethod(), id);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55 public string GetSqlText(SqlQuery sql)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57 var provider = ((IDataContext)this).CreateSqlProvider();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59 //provider.SqlQuery = sql;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61 sql = provider.Finalize(sql);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63 var cc = provider.CommandCount(sql);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64 var sb = new StringBuilder();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66 var commands = new string[cc];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68 for (var i = 0; i < cc; i++)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70 sb.Length = 0;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
71
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
72 provider.BuildSql(i, sql, sb, 0, 0, false);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
73 commands[i] = sb.ToString();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
74 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
75
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
76 return string.Join("\n\n", commands);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
77 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
78
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
79 #if !MONO
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
80 [MethodExpression("Expression9")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
81 static public IQueryable<Parent> GetParent9(ITestDataContext db, Child ch)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
82 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
83 throw new InvalidOperationException();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
84 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
85
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
86 [MethodExpression("Expression9")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
87 public IQueryable<Parent> GetParent10(Child ch)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
88 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
89 throw new InvalidOperationException();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
90 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
91
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
92 static Expression<Func<ITestDataContext,Child,IQueryable<Parent>>> Expression9()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
93 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
94 return (db,ch) =>
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
95 from p in db.Parent
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
96 where p.ParentID == (int)Math.Floor(ch.ChildID / 10.0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
97 select p;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
98 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
99 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
100 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
101 }