diff UnitTests/CS/DataAccess/SqlQueryTest2.cs @ 0:f990fcb411a9

Копия текущей версии из github
author cin
date Thu, 27 Mar 2014 21:46:09 +0400
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/UnitTests/CS/DataAccess/SqlQueryTest2.cs	Thu Mar 27 21:46:09 2014 +0400
@@ -0,0 +1,86 @@
+using System;
+using System.Collections.Generic;
+
+using NUnit.Framework;
+
+using BLToolkit.DataAccess;
+
+namespace DataAccess
+{
+	[TestFixture]
+	public class SqlQueryTest2
+	{
+		public class Person
+		{
+			public int    ID;
+			public string LastName;
+			public string FirstName;
+			public string MiddleName;
+		}
+
+		public abstract class PersonAccessor : DataAccessor<Person>
+		{
+			[TestQuery(
+				SqlText    = "SELECT * FROM Person WHERE LastName = @lastName",
+				OracleText = "SELECT * FROM Person WHERE LastName = :lastName")]
+			public abstract List<Person> SelectByLastName(string lastName);
+
+			[TestQuery(
+				SqlText    = "SELECT * FROM Person WHERE {0} = @value",
+				OracleText = "SELECT * FROM Person WHERE {0} = :value")]
+			public abstract List<Person> SelectBy([Format] string fieldName, string value);
+
+			[TestQuery(
+				SqlText    = "SELECT TOP ({0}) * FROM Person WHERE LastName = @lastName",
+				AccessText = "SELECT TOP {0} * FROM Person WHERE LastName = @lastName",
+				OracleText = "SELECT * FROM Person WHERE LastName = :lastName AND rownum <= {0}",
+				FbText     = "SELECT FIRST {0} * FROM Person WHERE LastName = @lastName",
+				SQLiteText = "SELECT * FROM Person WHERE LastName = @lastName LIMIT {0}")]
+			public abstract List<Person> SelectByLastName(string lastName, [Format(0)] int top);
+
+			[TestQuery(
+				SqlText    = "SELECT @id as ID",
+				OracleText = "SELECT :id ID FROM Dual",
+				FbText     = "SELECT CAST(@id AS INTEGER) ID FROM Dual")]
+			public abstract List<Person> SelectID(int @id);
+		}
+
+		[Test]
+		public void Test1()
+		{
+			var da   = DataAccessor.CreateInstance<PersonAccessor>();
+			var list = da.SelectByLastName("Pupkin");
+
+			Assert.AreNotEqual(0, list.Count);
+		}
+
+		[Test]
+		public void Test2()
+		{
+			var da   = DataAccessor.CreateInstance<PersonAccessor>();
+			var list = da.SelectBy("FirstName", "John");
+
+			Assert.AreNotEqual(0, list.Count);
+		}
+
+		[Test]
+		public void Test3()
+		{
+			var da   = DataAccessor.CreateInstance<PersonAccessor>();
+			var list = da.SelectByLastName("Pupkin", 1);
+
+			Assert.AreNotEqual(0, list.Count);
+		}
+
+#if !SQLCE // Works in Query window but not here???
+		[Test]
+#endif
+		public void Test4()
+		{
+			var da   = DataAccessor.CreateInstance<PersonAccessor>();
+			var list = da.SelectID(42);
+
+			Assert.AreEqual(42, list[0].ID);
+		}
+	}
+}