CreateIndexBuilder_SqlServer_NonClustered_CreatesNonClusteredIndex() fails expecting NONCLUSTERED but getting CLUSTERED. CreateIndexBuilder_SqlServer_Unique_CreatesUniqueNonClusteredIndex() fails expecting UNIQUE NONCLUSTERED but getting CLUSTERED.
117 lines
4.6 KiB
C#
117 lines
4.6 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using NUnit.Framework;
|
|
using Umbraco.Core.Models.Rdbms;
|
|
using Umbraco.Core.Persistence.DatabaseAnnotations;
|
|
using Umbraco.Core.Persistence.DatabaseModelDefinitions;
|
|
using Umbraco.Core.Persistence.Migrations.Syntax.Create.Index;
|
|
using Umbraco.Core.Persistence.Migrations.Syntax.Expressions;
|
|
using Umbraco.Core.Persistence.SqlSyntax;
|
|
|
|
namespace Umbraco.Tests.Persistence.SyntaxProvider
|
|
{
|
|
[TestFixture]
|
|
public class SqlSyntaxProviderTests
|
|
{
|
|
[SetUp]
|
|
public void SetUp()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlCeSyntax.Provider;
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Generate_Create_Table_Statement()
|
|
{
|
|
var type = typeof (NodeDto);
|
|
var definition = DefinitionFactory.GetTableDefinition(type);
|
|
|
|
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);
|
|
|
|
Console.WriteLine(create);
|
|
Console.WriteLine(primaryKey);
|
|
foreach (var sql in keys)
|
|
{
|
|
Console.WriteLine(sql);
|
|
}
|
|
|
|
foreach (var sql in indexes)
|
|
{
|
|
Console.WriteLine(sql);
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Format_SqlServer_NonClusteredIndexDefinition_AddsNonClusteredDirective()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlServerSyntax.Provider;
|
|
|
|
var indexDefinition = CreateIndexDefinition();
|
|
indexDefinition.IndexType = IndexTypes.NonClustered;
|
|
|
|
var actual = SqlSyntaxContext.SqlSyntaxProvider.Format(indexDefinition);
|
|
Assert.AreEqual("CREATE NONCLUSTERED INDEX [IX_A] ON [TheTable] ([A])", actual);
|
|
}
|
|
|
|
[Test]
|
|
public void Format_SqlServer_NonClusteredIndexDefinition_UsingIsClusteredFalse_AddsClusteredDirective()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlServerSyntax.Provider;
|
|
|
|
var indexDefinition = CreateIndexDefinition();
|
|
indexDefinition.IsClustered = false;
|
|
|
|
var actual = SqlSyntaxContext.SqlSyntaxProvider.Format(indexDefinition);
|
|
Assert.AreEqual("CREATE CLUSTERED INDEX [IX_A] ON [TheTable] ([A])", actual);
|
|
}
|
|
|
|
[Test]
|
|
public void CreateIndexBuilder_SqlServer_NonClustered_CreatesNonClusteredIndex()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlServerSyntax.Provider;
|
|
var createExpression = new CreateIndexExpression { Index = { Name = "IX_A" } };
|
|
var builder = new CreateIndexBuilder(createExpression);
|
|
builder.OnTable("TheTable").OnColumn("A").Ascending().WithOptions().NonClustered();
|
|
Assert.AreEqual("CREATE NONCLUSTERED INDEX [IX_A] ON [TheTable] ([A])", createExpression.ToString());
|
|
}
|
|
|
|
[Test]
|
|
public void CreateIndexBuilder_SqlServer_Unique_CreatesUniqueNonClusteredIndex()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlServerSyntax.Provider;
|
|
var createExpression = new CreateIndexExpression { Index = { Name = "IX_A" } };
|
|
var builder = new CreateIndexBuilder(createExpression);
|
|
builder.OnTable("TheTable").OnColumn("A").Ascending().WithOptions().Unique();
|
|
Assert.AreEqual("CREATE UNIQUE NONCLUSTERED INDEX [IX_A] ON [TheTable] ([A])", createExpression.ToString());
|
|
}
|
|
|
|
[Test]
|
|
public void CreateIndexBuilder_SqlServer_Clustered_CreatesClusteredIndex()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = SqlServerSyntax.Provider;
|
|
var createExpression = new CreateIndexExpression { Index = { Name = "IX_A" } };
|
|
var builder = new CreateIndexBuilder(createExpression);
|
|
builder.OnTable("TheTable").OnColumn("A").Ascending().WithOptions().Clustered();
|
|
Assert.AreEqual("CREATE CLUSTERED INDEX [IX_A] ON [TheTable] ([A])", createExpression.ToString());
|
|
}
|
|
|
|
private static IndexDefinition CreateIndexDefinition()
|
|
{
|
|
return new IndexDefinition
|
|
{
|
|
ColumnName = "A",
|
|
Name = "IX_A",
|
|
TableName = "TheTable",
|
|
SchemaName = "dbo"
|
|
};
|
|
}
|
|
|
|
[TearDown]
|
|
public void TearDown()
|
|
{
|
|
SqlSyntaxContext.SqlSyntaxProvider = null;
|
|
}
|
|
}
|
|
} |