view UnitTests/CS/Data/Sql/SelectTest.cs @ 4:f757da6161a1

!bug 100 + 2h fixed gregression
author cin
date Sun, 24 Aug 2014 17:57:42 +0400
parents f990fcb411a9
children
line wrap: on
line source

using System;
using NUnit.Framework;
using BLToolkit.Data.Sql;

namespace Data.Sql
{
	[TestFixture]
	public class SelectTest
	{
		public static SqlTable Order = new SqlTable
		{
			Name   = "Order",
			Fields = { new SqlField { Name = "ID" }, new SqlField { Name = "Number" } }
		};

		[Test]
		public void Test1()
		{
			var sb = new SqlQuery();

			sb
				.Select
					.Field(Order["ID"])
					.Field(Order["Number"])
				;

			Assert.AreEqual(2, sb.Select.Columns.Count);
		}

		[Test]
		public void Test2()
		{
			var sb = new SqlQuery();

			sb
				.Select
					.Field(Order["ID"])
					.Field(Order["Number"])
					.Field(Order["ID"])
				;

			Assert.AreEqual(2, sb.Select.Columns.Count);
		}

		[Test]
		public void Test3()
		{
			var sb = new SqlQuery();

			sb
				.Select
					.Field(Order["ID"], "id1")
					.Field(Order["ID"])
					.Expr("{0} + {1}", Order["Number"], Order["Number"])
					.Expr(new SqlExpression("{0} + {1}", Order["Number"], Order["Number"]))
				;

			Assert.AreEqual(2, sb.Select.Columns.Count);
		}
	}
}