view UnitTests/DataProvider/FireBird/CreateDatabase.cs @ 0:f990fcb411a9

Копия текущей версии из github
author cin
date Thu, 27 Mar 2014 21:46:09 +0400
parents
children
line wrap: on
line source

using System;
using System.Configuration;
using System.IO;
using BLToolkit.Data;
using FirebirdSql.Data.FirebirdClient;
using NUnit.Framework;

namespace UnitTests.CS
{
	[TestFixture, Explicit, Category("DB setup")]
	public class CreateDatabase
	{
		[Test]
		public void Test()
		{
			FbConnection.CreateDatabase(ConfigurationManager.AppSettings.Get("ConnectionString.Fdp"), true);

			const string path = @"..\..\..\..\Data\Create Scripts\Firebird2.sql";

			using (DbManager db = new DbManager())
			{
				string cmd = string.Empty;
				string term = ";";

				foreach (string s in File.ReadAllLines(path))
				{
					string line = s.TrimEnd();
					if (!line.EndsWith(term))
					{
						cmd += line + Environment.NewLine;
						continue;
					}

					line = line.Substring(0, line.Length - term.Length).Trim();

					if (line.ToUpperInvariant().StartsWith("SET TERM "))
					{
						term = line.Substring("SET TERM ".Length).Trim();
						continue;
					}
					
					if (line.ToUpperInvariant().StartsWith("COMMIT"))
					{
						continue;
					}

					Console.WriteLine("Executing script:");
					Console.WriteLine(cmd + line);

					db
						.SetCommand(cmd + line)
						.ExecuteNonQuery()
						;

					Console.WriteLine("Succeeded.");

					cmd = string.Empty;
				}
	
			}
		}
	}
}