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