annotate UnitTests/CS/DataAccess/DataAccessorTest.cs @ 5:f7d63a092920

Исправлено условие Where в тех случаях, когда репозитарий не является генериком
author cin
date Tue, 10 Mar 2015 16:02:11 +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;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3 using System.Collections.Generic;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4 using System.ComponentModel;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5 using System.Data;
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 using BLToolkit.Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 using BLToolkit.DataAccess;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11 using BLToolkit.EditableObjects;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12 using BLToolkit.Mapping;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13 using BLToolkit.Reflection;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 using BLToolkit.TypeBuilder;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15 using BLToolkit.Validation;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 using PersonDataSet = DataAccessTest.PersonDataSet2;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19 namespace DataAccess
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 namespace Other
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 public abstract class Person : DataAccessorTest.Person
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25 [MaxLength(256), Required]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26 public abstract string Diagnosis { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 [TestFixture]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31 public class DataAccessorTest
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 public enum Gender
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35 [MapValue("F")] Female,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 [MapValue("M")] Male,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37 [MapValue("U")] Unknown,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38 [MapValue("O")] Other
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41 public interface IPerson
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43 int ID { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 string LastName { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 string FirstName { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 string MiddleName { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 IList Territories { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50 [TableName("Person")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 public abstract class Person : EditableObject, IPerson
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 [PrimaryKey, NonUpdatable]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54 [MapField("PersonID")] public abstract int ID { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55 [MaxLength(50), Required] public abstract string FirstName { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 [MaxLength(50), NullValue("")] public abstract string MiddleName { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57 [MaxLength(50), Required] public abstract string LastName { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58 [Required] public abstract Gender Gender { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60 public abstract IList Territories { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63 public abstract class PersonAccessor : DataAccessor
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65 public abstract int Person_SelectAll();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66 public abstract void Person_SelectAll(DbManager db);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67 public abstract Person SelectByName(string firstName, string lastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69 [SprocName("Person_SelectByName"), DiscoverParameters]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70 public abstract Person AnySprocName(string anyParameterName, string otherParameterName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
71
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
72 [ActionName("SelectByName")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
73 public abstract Person AnyActionName(string firstName, string lastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
74
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
75 [ActionName("SelectByName")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
76 public abstract Person AnyParamName(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
77 [ParamName("FirstName")] string name1,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
78 #if ORACLE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
79 [ParamName("LastName")] string name2
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
80 #else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
81 [ParamName("@LastName")] string name2
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
82 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
83 );
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
84
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
85 [ActionName("SelectByName"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
86 public abstract IPerson SelectByNameReturnInterface(string firstName, string lastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
87
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
88 [ActionName("SelectByName"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
89 public abstract void SelectByNameReturnVoid(string firstName, string lastName, [Destination] object p);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
90
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
91 public abstract IPerson SelectByName(string firstName, string lastName, [Destination] Person p);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
92
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
93 public abstract Person Insert([Destination(NoMap = false)] Person e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
94
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
95 [SprocName("Person_Insert_OutputParameter")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
96 public abstract void Insert_OutputParameter([Direction.Output("PERSONID")] Person e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
97
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
98 [SprocName("Scalar_ReturnParameter")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
99 public abstract void Insert_ReturnParameter([Direction.ReturnValue("@PersonID"),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
100 Direction.Ignore("PersonID", "FirstName", "LastName", "MiddleName", "Gender")] Person e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
101
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
102 [SprocName("Scalar_ReturnParameter")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
103 public abstract void Insert_ReturnParameter2([Direction.ReturnValue("ID"),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
104 Direction.Ignore("PersonID", "FirstName", "LastName", "MiddleName", "Gender")] Person e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
105
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
106 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
107 public abstract ArrayList SameTypeName();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
108
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
109 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
110 public abstract IList SelectAllAsIList();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
111
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
112 [ActionName("SelectByName")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
113 public abstract Person SameTypeName(string firstName, string lastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
114
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
115 [ActionName("SelectByKey")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
116 public abstract Person ParamNullID ([ParamNullValue(1)] int id);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
117
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
118 [NoInstance]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
119 public abstract Person this[DbManager db, int id]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
120 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
121 [ActionName("SelectByKey")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
122 get;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
123 [ActionName("Update")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
124 [ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
125 set;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
126 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
127
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
128 [ActionName("SelectByKey")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
129 public abstract Person ParamNullableID([ParamNullValue(1)] int? id);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
130
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
131 [ActionName("SelectByKey")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
132 public abstract Person ParamNullableID2([ParamNullValue("1")] int? id);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
133
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
134 [ActionName("SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
135 public abstract IList<Person> SelectAllAsIListT();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
136
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
137 [ActionName("SelectByName")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
138 public abstract Person ParamNullString([ParamNullValue("John")] string firstName, string lastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
139
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
140 public abstract Person ParamNullGuid ([ParamNullValue("49F74716-C6DE-4b3e-A753-E40CFE6C6EA0")] Guid guid);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
141 public abstract Person ParamNullEnum ([ParamNullValue(Gender.Unknown)] Gender gender);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
142
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
143 #region IDataReader
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
144
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
145 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
146 public abstract IDataReader SelectAllIDataReader(DbManager db);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
147
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
148 [SprocName("Person_SelectAll"), CommandBehavior(CommandBehavior.SchemaOnly)]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
149 public abstract IDataReader SelectAllIDataReaderSchemaOnly(DbManager db);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
150
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
151 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
152
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
153 #region DataSet
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
154
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
155 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
156 public abstract DataSet SelectAllDataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
157
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
158 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
159 public abstract IListSource SelectAllDataSetWithDestination([Destination] DataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
160
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
161 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
162 public abstract void SelectAllDataSetReturnVoid ([Destination] DataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
163
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
164 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
165 public abstract PersonDataSet SelectAllTypedDataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
166
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
167 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
168 public abstract object SelectAllTypedDataSetWithDestination([Destination] PersonDataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
169
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
170 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
171 public abstract void SelectAllTypedDataSetReturnVoid ([Destination] PersonDataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
172
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
173 [ObjectType(typeof(Person)), ActionName("SelectAll"), DataSetTable("First")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
174 public abstract void SelectFirstTable ([Destination] DataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
175
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
176 [SprocName("Person_SelectAll"), DataSetTable("Second")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
177 public abstract void SelectSecondTable ([Destination] DataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
178
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
179 [ObjectType(typeof(Person)), ActionName("SelectAll"), DataSetTable(0)]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
180 public abstract void SelectFirstTable2 ([Destination] PersonDataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
181
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
182 [SprocName("Person_SelectAll"), DataSetTable("Second")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
183 public abstract void SelectSecondTable2([Destination] PersonDataSet ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
184
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
185 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
186
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
187 #region DataTable
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
188
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
189 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
190 public abstract DataTable SelectAllDataTable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
191
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
192 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
193 public abstract DataTable SelectAllDataTableWithDestination([Destination] DataTable dt);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
194
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
195 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
196 public abstract void SelectAllDataTableReturnVoid ([Destination] DataTable dt);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
197
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
198 [SprocName("Person_SelectAll"), DataSetTable("Person")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
199 public abstract DataTable SelectAllToTablePerson();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
200
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
201 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
202 public abstract PersonDataSet.PersonDataTable SelectAllTypedDataTable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
203
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
204 [SprocName("Person_SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
205 public abstract void SelectAllTypedDataTableReturnVoid ([Destination] PersonDataSet.PersonDataTable dt);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
206
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
207 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
208
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
209 #region List
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
210
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
211 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
212 public abstract ArrayList SelectAllList();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
213
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
214 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
215 public abstract IList SelectAllListWithDestination([Destination] IList list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
216
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
217 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
218 public abstract void SelectAllListReturnVoid ([Destination] IList list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
219
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
220 [ActionName("SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
221 public abstract List<Person> SelectAllListT();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
222
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
223 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
224 public abstract List<IPerson> SelectAllListTWithObjectType();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
225
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
226 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
227 public abstract List<IPerson> SelectAllListTWithDestination([Destination] IList list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
228
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
229 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
230 public abstract void SelectAllListTWithObjectTypeReturnVoid([Destination] IList list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
231
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
232 [ActionName("SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
233 public abstract void SelectAllListTReturnVoid ([Destination] IList<Person> list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
234
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
235 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
236
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
237 #region IEnumerable
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
238
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
239 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
240 public abstract IEnumerable SelectAllEnumerable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
241
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
242 [ActionName("SelectAll")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
243 public abstract IEnumerable<Person> SelectAllEnumerableT();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
244
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
245 [ActionName("SelectAll"), ObjectType(typeof(Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
246 public abstract IEnumerable<IPerson> SelectAllEnumerableTWithObjectType();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
247
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
248 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
249 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
250
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
251 public abstract class PersonDataAccessor1 : PersonAccessor
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
252 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
253 public DataSet SelectByName()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
254 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
255 using (DbManager db = GetDbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
256 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
257 DataSet ds = new DataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
258
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
259 db.SetSpCommand("Person_SelectAll");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
260
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
261 if (ds.Tables.Count > 0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
262 db.ExecuteDataSet(ds, ds.Tables[0].TableName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
263 else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
264 db.ExecuteDataSet(ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
265
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
266 return ds;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
267 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
268 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
269
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
270 [ActionName("SelectAll"), ObjectType(typeof(Other.Person))]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
271 public abstract ArrayList SameTypeName1();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
272
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
273 [ActionName("SelectByName")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
274 public abstract Other.Person SameTypeName1(string firstName, string lastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
275
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
276 protected override string GetDefaultSpName(string typeName, string actionName)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
277 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
278 return "Patient_" + actionName;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
279 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
280 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
281
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
282 public class PersonList : ArrayList
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
283 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
284 public new Person this[int idx]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
285 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
286 get { return (Person)base[idx]; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
287 set { base[idx] = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
288 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
289 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
290
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
291 private PersonAccessor _da;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
292 private SprocQuery _sproc = new SprocQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
293 private SqlQuery _sql = new SqlQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
294
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
295 public DataAccessorTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
296 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
297 object o = TypeAccessor.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
298 Assert.IsInstanceOf(typeof(Person), o);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
299
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
300 _da = (PersonAccessor)DataAccessor.CreateInstance(typeof(PersonAccessor));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
301 Assert.IsInstanceOf(typeof(PersonAccessor), _da);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
302 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
303
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
304 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
305 public void Sql_Select()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
306 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
307 Person e = (Person)_sql.SelectByKey(typeof(Person), 1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
308
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
309 Assert.IsNotNull(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
310 Assert.AreEqual(1, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
311 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
312
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
313 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
314 public void Sql_SelectAll()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
315 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
316 ArrayList list = _sql.SelectAll(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
317
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
318 Console.WriteLine(list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
319 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
320
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
321 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
322 public void Sql_Insert()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
323 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
324 ArrayList list = _sql.SelectAll(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
325 Hashtable tbl = new Hashtable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
326
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
327 foreach (Person e in list)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
328 tbl[e.ID] = e;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
329
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
330 Person em = (Person)Map.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
331
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
332 em.FirstName = "1";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
333 em.LastName = "2";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
334
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
335 _sql.Insert(em);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
336
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
337 list = _sql.SelectAll(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
338
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
339 foreach (Person e in list)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
340 if (tbl.ContainsKey(e.ID) == false)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
341 _sql.Delete(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
342 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
343
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
344 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
345 public void Sql_Update()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
346 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
347 Person e = (Person)_sql.SelectByKey(typeof(Person), 1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
348
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
349 int n = _sql.Update(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
350
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
351 Assert.AreEqual(1, n);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
352 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
353
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
354 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
355 public void Sql_DeleteByKey()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
356 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
357 ArrayList list = _sql.SelectAll(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
358 Hashtable tbl = new Hashtable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
359
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
360 foreach (Person e in list)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
361 tbl[e.ID] = e;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
362
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
363 Person em = (Person)Map.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
364
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
365 em.FirstName = "1";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
366 em.LastName = "2";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
367
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
368 _sql.Insert(em);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
369
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
370 list = _sql.SelectAll(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
371
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
372 foreach (Person e in list)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
373 if (tbl.ContainsKey(e.ID) == false)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
374 _sql.DeleteByKey(typeof(Person), e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
375 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
376
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
377 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
378 public void Sproc_SelectAll()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
379 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
380 ArrayList list = _sproc.SelectAll(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
381 Console.WriteLine(list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
382 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
383
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
384 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
385 public void Gen_Person_SelectAll()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
386 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
387 int n = _da.Person_SelectAll();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
388 Console.WriteLine(n);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
389 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
390
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
391 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
392 public void Gen_Person_SelectAll_DbManager()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
393 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
394 using (DbManager db = _da.GetDbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
395 _da.Person_SelectAll(db);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
396 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
397
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
398 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
399 public void Gen_SelectByName()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
400 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
401 Person e = _da.SelectByName("John", "Pupkin");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
402 Assert.AreEqual(1, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
403 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
404
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
405 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
406 public void Gen_SelectByNameReturnInterface()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
407 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
408 IPerson i = _da.SelectByNameReturnInterface("John", "Pupkin");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
409
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
410 Assert.IsNotNull(i);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
411 Assert.AreEqual (1, i.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
412 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
413
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
414 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
415 public void Gen_SelectByNameReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
416 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
417 Person e = (Person)TypeAccessor.CreateInstance(typeof (Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
418 Assert.IsNotNull(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
419
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
420 _da.SelectByNameReturnVoid("John", "Pupkin", e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
421 Assert.AreEqual (1, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
422 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
423
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
424 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
425 public void Gen_SelectByNameWithDestination()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
426 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
427 Person e = (Person)TypeAccessor.CreateInstance(typeof (Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
428 IPerson i = _da.SelectByName("John", "Pupkin", e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
429
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
430 Assert.AreSame (i, e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
431 Assert.AreEqual(1, i.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
432 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
433
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
434 #if !ACCESS
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
435 #if !FIREBIRD
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
436 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
437 public void Gen_InsertGetID()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
438 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
439 Person e = (Person)TypeAccessor.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
440 e.FirstName = "Crazy";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
441 e.LastName = "Frog";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
442 e.Gender = Gender.Other;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
443
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
444 _da.Insert(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
445
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
446 // If you got an assertion here, make sure your Person_Insert sproc looks like
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
447 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
448 // INSERT INTO Person( LastName, FirstName, MiddleName, Gender)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
449 // VALUES (@LastName, @FirstName, @MiddleName, @Gender)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
450 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
451 // SELECT Cast(SCOPE_IDENTITY() as int) PersonID
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
452 // ^==important ^==important
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
453 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
454 Assert.IsTrue(e.ID > 0);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
455 _sproc.Delete(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
456 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
457 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
458 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
459 public void Gen_InsertGetIDReturnParameter()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
460 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
461 Person e = (Person)TypeAccessor.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
462
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
463 _da.Insert_ReturnParameter(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
464
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
465 Assert.AreEqual(12345, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
466 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
467
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
468
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
469 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
470 public void Gen_InsertGetIDReturnParameter2()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
471 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
472 Person e = (Person)TypeAccessor.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
473
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
474 _da.Insert_ReturnParameter2(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
475
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
476 Assert.AreEqual(12345, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
477 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
478
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
479 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
480 public void Gen_InsertGetIDOutputParameter()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
481 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
482 Person e = (Person)TypeAccessor.CreateInstance(typeof(Person));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
483 e.FirstName = "Crazy";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
484 e.LastName = "Frog";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
485 e.Gender = Gender.Other;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
486
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
487 _da.Insert_OutputParameter(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
488
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
489 Assert.IsTrue(e.ID > 0);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
490 _sproc.Delete(e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
491 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
492 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
493
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
494 #if !FIREBIRD
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
495 // Firebird is incomatible with DiscoverParameters due to In/Out parameters emulation.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
496 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
497 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
498 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
499 public void Gen_SprocName()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
500 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
501 Person e = _da.AnySprocName("John", "Pupkin");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
502 Assert.AreEqual(1, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
503 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
504
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
505 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
506 public void Gen_ActionName()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
507 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
508 Person e = _da.AnyActionName("John", "Pupkin");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
509 Assert.AreEqual(1, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
510 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
511
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
512 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
513 public void Gen_ParamName()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
514 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
515 Person e = _da.AnyParamName("John", "Pupkin");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
516 Assert.AreEqual(1, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
517 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
518
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
519 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
520 public void Gen_SameTypeName()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
521 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
522 Person e = _da.SameTypeName("Tester", "Testerson");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
523 Assert.IsInstanceOf(typeof(Person), e);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
524 Assert.AreEqual(2, e.ID);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
525
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
526 ArrayList list = _da.SameTypeName();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
527 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
528 Assert.IsInstanceOf(typeof(Person), list[0]);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
529
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
530 PersonDataAccessor1 da1 = (PersonDataAccessor1)DataAccessor.CreateInstance(typeof(PersonDataAccessor1));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
531 Other.Person e1 = da1.SameTypeName1("Tester", "Testerson");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
532
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
533 Assert.IsInstanceOf(typeof(Other.Person), e1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
534 Assert.IsNotEmpty(e1.Diagnosis);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
535
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
536 list = da1.SameTypeName1();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
537 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
538 Assert.IsInstanceOf(typeof(Other.Person), list[0]);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
539 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
540
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
541 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
542 public void ParamNullValueIDTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
543 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
544 // Parameter id == 1 will be replaced with NULL
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
545 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
546 Person e1 = _da.ParamNullID(1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
547 Assert.IsNull(e1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
548
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
549 // Parameter id == 2 will be send as is
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
550 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
551 Person e2 = _da.ParamNullID(2);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
552 Assert.IsNotNull(e2);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
553 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
554
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
555 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
556 public void ParamNullValueNullableIDTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
557 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
558 // Parameter id == 1 will be replaced with NULL
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
559 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
560 Person e1 = _da.ParamNullableID(1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
561 Assert.IsNull(e1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
562 e1 = _da.ParamNullableID2(1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
563 Assert.IsNull(e1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
564
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
565 // Parameter id == 2 will be send as is
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
566 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
567 Person e2 = _da.ParamNullableID(2);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
568 Assert.IsNotNull(e2);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
569 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
570
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
571 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
572 public void ParamNullValueStrTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
573 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
574 // Parameter firstName == 'John' will be replaced with NULL
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
575 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
576 Person e1 = _da.ParamNullString("John", "Pupkin");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
577 Assert.IsNull(e1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
578
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
579 // Parameter firstName == 'Tester' will be send as is
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
580 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
581 Person e2 = _da.ParamNullString("Tester", "Testerson");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
582 Assert.IsNotNull(e2);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
583 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
584
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
585 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
586 public void AbstractIndexerTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
587 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
588 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
589 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
590 Person p = _da[db, 1];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
591 Assert.AreEqual("John", p.FirstName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
592
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
593 p.FirstName = "Frog";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
594 _da[db, 1] = p;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
595
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
596 p = _da[db, 1];
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
597 Assert.AreEqual("Frog", p.FirstName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
598
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
599 p.FirstName = "John";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
600 _da[db, 1] = p;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
601 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
602 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
603
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
604
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
605 #region IDataReader
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
606
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
607 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
608 public void Gen_SelectAllIDataReader()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
609 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
610 // Keep connection open for IDataReader
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
611 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
612 using (DbManager db = _da.GetDbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
613 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
614 IDataReader dr = _da.SelectAllIDataReader(db);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
615
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
616 Assert.IsNotNull(dr);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
617 Assert.AreNotEqual(0, dr.FieldCount);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
618 Assert.IsTrue(dr.Read());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
619 #if ORACLE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
620 Assert.AreNotEqual(0, dr.GetDecimal(dr.GetOrdinal("PersonID")));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
621 #else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
622 Assert.AreNotEqual(0, dr.GetInt32(dr.GetOrdinal("PersonID")));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
623 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
624 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
625 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
626
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
627 #if !ACCESS
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
628 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
629 public void Gen_SelectAllIDataReaderSchemaOnly()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
630 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
631 // Keep connection open for IDataReader
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
632 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
633 using (DbManager db = _da.GetDbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
634 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
635 IDataReader dr = _da.SelectAllIDataReaderSchemaOnly(db);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
636
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
637 Assert.IsNotNull(dr);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
638 Assert.AreNotEqual(0, dr.FieldCount);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
639 Assert.IsFalse(dr.Read());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
640 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
641 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
642 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
643
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
644 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
645
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
646 #region DataSet
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
647
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
648 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
649 public void Gen_SelectAllDataSet()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
650 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
651 DataSet ds = _da.SelectAllDataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
652 Assert.AreNotEqual(0, ds.Tables[0].Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
653 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
654
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
655 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
656 public void Gen_SelectAllDataSetWithDestination()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
657 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
658 IListSource ls = _da.SelectAllDataSetWithDestination(new DataSet());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
659 Assert.AreNotEqual(0, ls.GetList().Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
660 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
661
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
662 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
663 public void Gen_SelectAllDataSetReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
664 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
665 DataSet ds = new DataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
666 _da.SelectAllDataSetReturnVoid(ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
667 Assert.AreNotEqual(0, ds.Tables[0].Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
668 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
669
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
670 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
671 public void Gen_SelectAllTypedDataSet()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
672 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
673 PersonDataSet ds = _da.SelectAllTypedDataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
674 Assert.AreNotEqual(0, ds.Person.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
675 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
676
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
677 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
678 public void Gen_SelectAllTypedDataSetWithObjectType()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
679 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
680 object o = _da.SelectAllTypedDataSetWithDestination(new PersonDataSet());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
681 Assert.IsInstanceOf(typeof(PersonDataSet), o);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
682
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
683 PersonDataSet ds = (PersonDataSet)o;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
684 Assert.AreNotEqual(0, ds.Person.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
685 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
686
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
687 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
688 public void Gen_SelectAllTypedDataSetReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
689 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
690 PersonDataSet ds = new PersonDataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
691 _da.SelectAllTypedDataSetReturnVoid(ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
692
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
693 Assert.AreNotEqual(0, ds.Person.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
694 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
695
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
696 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
697 public void DataSetTableAttributeTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
698 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
699 DataSet ds = new DataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
700
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
701 _da.SelectFirstTable (ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
702 _da.SelectSecondTable(ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
703
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
704 Assert.IsTrue (ds.Tables.Contains("First"), "Table 'First' not found");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
705 Assert.IsTrue (ds.Tables.Contains("Second"), "Table 'Second' not found");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
706 Assert.IsFalse(ds.Tables.Contains("Table"), "Table 'Table' was found");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
707 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
708
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
709 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
710 public void DataSetTableAttributeTest2()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
711 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
712 PersonDataSet ds = new PersonDataSet();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
713
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
714 _da.SelectFirstTable2 (ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
715 _da.SelectSecondTable2(ds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
716
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
717 // Table 'Person' is dataset own table.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
718 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
719 Assert.IsTrue (ds.Tables.Contains("Person"), "Table 'Person' not found");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
720 Assert.IsTrue (ds.Tables.Contains("Second"), "Table 'Second' not found");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
721 Assert.IsFalse(ds.Tables.Contains("Table"), "Table 'Table' was found");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
722 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
723
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
724 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
725
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
726 #region DataTable
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
727
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
728 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
729 public void Gen_SelectAllDataTable()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
730 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
731 DataTable dt = _da.SelectAllDataTable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
732 Assert.AreNotEqual(0, dt.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
733 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
734
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
735 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
736 public void Gen_SelectAllDataTableWithDestination()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
737 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
738 DataTable dt = _da.SelectAllDataTableWithDestination(new DataTable());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
739 Assert.AreNotEqual(0, dt.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
740 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
741
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
742 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
743 public void Gen_SelectAllDataTableReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
744 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
745 DataTable dt = new DataTable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
746 _da.SelectAllDataTableReturnVoid(dt);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
747 Assert.AreNotEqual(0, dt.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
748 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
749
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
750 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
751 public void DataSetTableAttributeTest3()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
752 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
753 DataTable dt = _da.SelectAllToTablePerson();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
754
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
755 Assert.AreEqual("Person", dt.TableName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
756 Assert.AreNotEqual(0, dt.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
757 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
758
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
759 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
760 public void Gen_SelectAllTypedDataTable()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
761 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
762 PersonDataSet.PersonDataTable dt = _da.SelectAllTypedDataTable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
763 Assert.AreNotEqual(0, dt.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
764 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
765
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
766 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
767 public void Gen_SelectAllTypedDataTableReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
768 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
769 PersonDataSet.PersonDataTable dt = new PersonDataSet.PersonDataTable();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
770
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
771 _da.SelectAllTypedDataTableReturnVoid(dt);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
772 Assert.AreNotEqual(0, dt.Rows.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
773 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
774
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
775 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
776
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
777 #region List
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
778
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
779 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
780 public void Gen_SelectAllList()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
781 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
782 ArrayList list = _da.SelectAllList();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
783 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
784 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
785
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
786 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
787 public void Gen_SelectAllListWithDestination()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
788 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
789 IList list = _da.SelectAllListWithDestination(new ArrayList());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
790 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
791 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
792
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
793 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
794 public void Gen_SelectAllListReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
795 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
796 ArrayList list = new ArrayList();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
797 _da.SelectAllListReturnVoid(list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
798 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
799 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
800
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
801 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
802 public void Gen_SelectAllIList()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
803 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
804 IList list = _da.SelectAllAsIList();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
805 Assert.IsNotEmpty(list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
806 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
807
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
808 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
809 public void Gen_SelectAllListT()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
810 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
811 List<Person> list = _da.SelectAllListT();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
812 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
813 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
814
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
815 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
816 public void Gen_SelectAllListTWithObjectType()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
817 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
818 List<IPerson> list = _da.SelectAllListTWithObjectType();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
819 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
820 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
821
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
822 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
823 public void Gen_SelectAllListTReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
824 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
825 List<Person> list = new List<Person>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
826 _da.SelectAllListTReturnVoid(list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
827 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
828 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
829
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
830 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
831 public void Gen_SelectAllListTWithObjectTypeReturnVoid()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
832 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
833 List<IPerson> list = new List<IPerson>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
834 _da.SelectAllListTWithObjectTypeReturnVoid(list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
835 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
836 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
837
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
838 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
839 public void Gen_SelectAllListTWithDestination()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
840 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
841 List<IPerson> list = _da.SelectAllListTWithDestination(new List<IPerson>());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
842 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
843 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
844
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
845 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
846 public void Gen_SelectAllIListT()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
847 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
848 IList<Person> list = _da.SelectAllAsIListT();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
849 Assert.IsNotEmpty((ICollection)list);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
850 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
851
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
852 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
853
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
854 #region PrepareParameters
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
855
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
856 public abstract class MyAssessorBase : DataAccessor
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
857 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
858 // This method will inject an additional parameter into each sproc call
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
859 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
860 protected override IDbDataParameter[] PrepareParameters(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
861 DbManager db,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
862 object[] parameters)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
863 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
864 ArrayList retParams;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
865 if (parameters != null && parameters.Length != 0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
866 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
867 parameters = base.PrepareParameters(db, parameters);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
868 retParams = new ArrayList(parameters.Length + 1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
869 retParams.AddRange(parameters);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
870 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
871 else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
872 retParams = new ArrayList(1);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
873
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
874 retParams.Add(db.Parameter((string)db.DataProvider.Convert("ID", db.GetConvertTypeToParameter()), 1));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
875
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
876 return (IDbDataParameter[]) retParams.ToArray(typeof(IDbDataParameter));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
877 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
878 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
879
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
880 public abstract class MyAssessor : MyAssessorBase
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
881 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
882 public abstract Person SelectByKey();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
883 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
884
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
885 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
886 public void PrepareParametersTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
887 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
888 IPerson i = ((MyAssessor)TypeAccessor
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
889 .CreateInstance(typeof (MyAssessor)))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
890 .SelectByKey();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
891
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
892 Assert.IsNotNull(i);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
893 Assert.AreEqual("John", i.FirstName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
894 Assert.AreEqual("Pupkin", i.LastName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
895 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
896 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
897
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
898 #region IEnumerable
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
899
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
900 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
901 public void Gen_SelectAllEnumerable()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
902 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
903 List<Person> list = new List<Person>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
904
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
905 foreach (Person p in _da.SelectAllEnumerable())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
906 list.Add(p);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
907
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
908 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
909 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
910
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
911 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
912 public void Gen_SelectAllEnumerableT()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
913 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
914 List<Person> list = new List<Person>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
915
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
916 foreach (Person p in _da.SelectAllEnumerableT())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
917 list.Add(p);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
918
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
919 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
920 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
921
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
922 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
923 public void Gen_SelectAllEnumerableTWithObjectType()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
924 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
925 List<Person> list = new List<Person>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
926
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
927 foreach (Person p in _da.SelectAllEnumerableTWithObjectType())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
928 list.Add(p);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
929
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
930 Assert.AreNotEqual(0, list.Count);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
931 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
932
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
933 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
934
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
935 #region Pull Request 121
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
936
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
937 public class Whatever
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
938 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
939 public string Name { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
940 public int Age { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
941 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
942
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
943 public class Whatever2
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
944 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
945 public bool IsFoo { get; set; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
946 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
947
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
948 public abstract class SomeDA : DataAccessor<Whatever2>
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
949 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
950 [SqlQuery("select 'Gogi' as Name, 10 as Age")]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
951 public abstract Whatever GetWhatever();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
952 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
953
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
954 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
955 public void TestIssue121()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
956 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
957 using (var dbm = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
958 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
959 var da = DataAccessor.CreateInstance<SomeDA>(dbm);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
960 var foo = da.GetWhatever();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
961
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
962 Assert.That(foo, Is.InstanceOf<Whatever>());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
963 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
964 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
965
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
966 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
967 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
968 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
969