view UnitTests/CS/Data/Sql/DefinitionTest.cs @ 1:8f65451dc28f

Исправлена проблема с фабрикой и выборкой нескольких объектов в linq выражении
author cin
date Fri, 28 Mar 2014 01:04:56 +0400
parents f990fcb411a9
children
line wrap: on
line source

using System;

using NUnit.Framework;

using BLToolkit.Data.Sql;
using BLToolkit.Mapping;
using BLToolkit.Reflection.Extension;

namespace Data.Sql
{
	[TestFixture]
	public class DefinitionTest
	{
		#region Table definition

		static class Tables
		{
			public static readonly SqlTable Order = new SqlTable
			{
				Name         = "Order",
				PhysicalName = "Order",
				Fields       =
				{
					new SqlField { Name = "ID", PhysicalName = "OrderID" }
				},
				Joins  =
				{
					new Join
					{
						TableName = "OrderItem",
						JoinOns   = { new JoinOn { Field = "ID", OtherField = "OrderID" } }
					}
				}
			};

			public static readonly SqlTable OrderItem = new SqlTable
			{
				Name         = "OrderItem",
				PhysicalName = "OrderItem",
				Alias        = "oi",
				Fields       =
				{
					new SqlField { Name = "OrderID" },
					new SqlField { Name = "ID", PhysicalName = "OrderItemID" }
				}
			};
		}

		static class Xml
		{
			static readonly ExtensionList _ext = TypeExtension.GetExtensions("DefinitionData.xml");

			public static readonly SqlTable Order     = new SqlTable(_ext, "Order");
			public static readonly SqlTable Order2    = new SqlTable(_ext, "Order2") { Name = "Order", PhysicalName = "Order" };
			public static readonly SqlTable Order3    = new SqlTable(_ext, "Order3") { Name = "Order", PhysicalName = "Order" };
			public static readonly SqlTable OrderItem = new SqlTable(_ext, "OrderItem");
		}

		public class Types
		{
			public class Order
			{
				[MapField("OrderID")] public int ID;
			}

			public class OrderItem
			{
				                          public int OrderID;
				[MapField("OrderItemID")] public int ID;
			}

			public static SqlTable OrderTable = new SqlTable<Order>
			{
				Joins =
				{
					new Join
					{
						TableName = "OrderItem",
						JoinOns   = { new JoinOn { Field = "ID", OtherField = "OrderID" } }
					}
				}
			};
			public static SqlTable OrderItemTable = new SqlTable<OrderItem> { Alias = "oi" };
		}

		#endregion

		static void CompareTables(SqlTable t1, SqlTable t2)
		{
			Assert.AreEqual(t1.Name,         t2.Name);
			Assert.AreEqual(t1.PhysicalName, t2.PhysicalName);
			Assert.AreEqual(t1.Alias,        t2.Alias);
			Assert.AreEqual(t1.Database,     t2.Database);
			Assert.AreEqual(t1.Fields.Count, t2.Fields.Count);
			Assert.AreEqual(t1.Joins. Count, t2.Joins. Count);

			foreach (var field in t1.Fields.Values)
			{
				Assert.AreEqual(field.PhysicalName, t2[field.Name].PhysicalName);
			}

			for (var i = 0; i < t1.Joins.Count; i++)
			{
				var j1 = t1.Joins[i];
				var j2 = t2.Joins[i];

				Assert.AreEqual(j1.TableName,     j2.TableName);
				Assert.AreEqual(j1.Alias,         j2.Alias);
				Assert.AreEqual(j1.JoinOns.Count, j2.JoinOns.Count);

				for (var j = 0; j < j1.JoinOns.Count; j++)
				{
					Assert.AreEqual(j1.JoinOns[j].Field,      j2.JoinOns[j].Field);
					Assert.AreEqual(j1.JoinOns[j].OtherField, j2.JoinOns[j].OtherField);
					Assert.AreEqual(j1.JoinOns[j].Expression, j2.JoinOns[j].Expression);
				}
			}
		}

		[Test]
		public void Test()
		{
			CompareTables(Tables.Order,     Xml.Order);
			CompareTables(Tables.Order,     Xml.Order2);
			CompareTables(Tables.Order,     Xml.Order3);
			CompareTables(Tables.OrderItem, Xml.OrderItem);
			CompareTables(Tables.Order,     Types.OrderTable);
			CompareTables(Tables.OrderItem, Types.OrderItemTable);
		}
	}
}