diff UnitTests/CS/Data/ExecuteListT.cs @ 0:f990fcb411a9

Копия текущей версии из github
author cin
date Thu, 27 Mar 2014 21:46:09 +0400 (2014-03-27)
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/UnitTests/CS/Data/ExecuteListT.cs	Thu Mar 27 21:46:09 2014 +0400
@@ -0,0 +1,85 @@
+using System.Collections.Generic;
+using BLToolkit.Reflection;
+using NUnit.Framework;
+
+using BLToolkit.Data;
+
+namespace Data
+{
+	[TestFixture]
+	public class ExecuteListT
+	{
+		public class SimpleObject
+		{
+			public SimpleObject()
+			{
+			}
+
+			public SimpleObject(InitContext context)
+			{
+				if (context.Parameters != null)
+				{
+					Assert.AreEqual(2, context.Parameters.Length);
+					Assert.AreEqual("123", context.Parameters[0]);
+					Assert.AreEqual("456", context.Parameters[1]);
+				}
+			}
+
+			private int    _key;   public int    Key   { get { return _key;   } set { _key   = value; } }
+			private string _value; public string Value { get { return _value; } set { _value = value; } }
+		}
+
+		[Test]
+		public void Test()
+		{
+			using (DbManager db = new DbManager())
+			{
+				List<SimpleObject> list = new List<SimpleObject>();
+
+				db
+#if MSSQL || SQLCE
+					.SetCommand(@"
+						SELECT 0 as [Key], 'value0' as Value UNION
+						SELECT 1 as [Key], 'value1' as Value UNION
+						SELECT 2 as [Key], 'value2' as Value")
+
+#else // ORACLE || FIREBIRD || ACCESS
+
+					.SetCommand(@"
+						SELECT 0 as ""Key"", 'value0' as ""Value"" FROM Dual UNION
+						SELECT 1 as ""Key"", 'value1' as ""Value"" FROM Dual UNION
+						SELECT 2 as ""Key"", 'value2' as ""Value"" FROM Dual")
+#endif
+					.ExecuteList<SimpleObject>(list);
+
+				Assert.IsTrue(list.Count > 0);
+			}
+		}
+
+		[Test]
+		public void ParamsTest()
+		{
+			using (DbManager db = new DbManager())
+			{
+				List<SimpleObject> list = db
+#if MSSQL || SQLCE
+					.SetCommand(@"
+						SELECT 0 as [Key], 'value0' as Value UNION
+						SELECT 1 as [Key], 'value1' as Value UNION
+						SELECT 2 as [Key], 'value2' as Value")
+
+#else // ORACLE || FIREBIRD || ACCESS
+
+					.SetCommand(@"
+						SELECT 0 as ""Key"", 'value0' as ""Value"" FROM Dual UNION
+						SELECT 1 as ""Key"", 'value1' as ""Value"" FROM Dual UNION
+						SELECT 2 as ""Key"", 'value2' as ""Value"" FROM Dual")
+#endif
+					.ExecuteList<SimpleObject>("123", "456");
+
+				Assert.IsNotEmpty(list);
+				Assert.IsInstanceOf(typeof(SimpleObject), list[0]);
+			}
+		}
+	}
+}