2012-12-19 15:23:05 -01:00
|
|
|
|
using System;
|
|
|
|
|
|
using NUnit.Framework;
|
|
|
|
|
|
using Umbraco.Core.Models.Rdbms;
|
|
|
|
|
|
using Umbraco.Core.Persistence.DatabaseModelDefinitions;
|
|
|
|
|
|
using Umbraco.Core.Persistence.SqlSyntax;
|
|
|
|
|
|
|
|
|
|
|
|
namespace Umbraco.Tests.Persistence.SyntaxProvider
|
|
|
|
|
|
{
|
|
|
|
|
|
[TestFixture]
|
|
|
|
|
|
public class SqlSyntaxProviderTests
|
|
|
|
|
|
{
|
|
|
|
|
|
[SetUp]
|
|
|
|
|
|
public void SetUp()
|
|
|
|
|
|
{
|
2013-03-09 10:43:34 -01:00
|
|
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlCeSyntax.Provider;
|
2012-12-19 15:23:05 -01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
|
|
public void Can_Generate_Create_Table_Statement()
|
|
|
|
|
|
{
|
|
|
|
|
|
var type = typeof (NodeDto);
|
|
|
|
|
|
var definition = DefinitionFactory.GetTableDefinition(type);
|
|
|
|
|
|
|
2013-03-09 10:43:34 -01:00
|
|
|
|
string create = SqlSyntaxContext.SqlSyntaxProvider.Format(definition);
|
|
|
|
|
|
string primaryKey = SqlSyntaxContext.SqlSyntaxProvider.FormatPrimaryKey(definition);
|
|
|
|
|
|
var indexes = SqlSyntaxContext.SqlSyntaxProvider.Format(definition.Indexes);
|
|
|
|
|
|
var keys = SqlSyntaxContext.SqlSyntaxProvider.Format(definition.ForeignKeys);
|
2012-12-19 15:23:05 -01:00
|
|
|
|
|
|
|
|
|
|
Console.WriteLine(create);
|
|
|
|
|
|
Console.WriteLine(primaryKey);
|
|
|
|
|
|
foreach (var sql in keys)
|
|
|
|
|
|
{
|
|
|
|
|
|
Console.WriteLine(sql);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var sql in indexes)
|
|
|
|
|
|
{
|
|
|
|
|
|
Console.WriteLine(sql);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
[TearDown]
|
|
|
|
|
|
public void TearDown()
|
2012-12-27 18:52:47 -01:00
|
|
|
|
{
|
2013-03-09 10:43:34 -01:00
|
|
|
|
SqlSyntaxContext.SqlSyntaxProvider = null;
|
2012-12-27 18:52:47 -01:00
|
|
|
|
}
|
2012-12-19 15:23:05 -01:00
|
|
|
|
}
|
|
|
|
|
|
}
|