* Run code cleanup * Dotnet format benchmarks project * Fix up Test.Common * Run dotnet format + manual cleanup * Run code cleanup for unit tests * Run dotnet format * Fix up errors * Manual cleanup of Unit test project * Update tests/Umbraco.Tests.Benchmarks/HexStringBenchmarks.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Integration/Testing/TestDbMeta.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Benchmarks/TypeFinderBenchmarks.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Integration/Testing/UmbracoIntegrationTest.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Update tests/Umbraco.Tests.Integration/Umbraco.Core/Events/EventAggregatorTests.cs Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> * Fix according to review * Fix after merge * Fix errors Co-authored-by: Nikolaj Geisle <niko737@edu.ucl.dk> Co-authored-by: Mole <nikolajlauridsen@protonmail.ch> Co-authored-by: Zeegaan <nge@umbraco.dk>
119 lines
3.6 KiB
C#
119 lines
3.6 KiB
C#
// Copyright (c) Umbraco.
|
|
// See LICENSE for more details.
|
|
|
|
using System.Diagnostics;
|
|
using NUnit.Framework;
|
|
using Umbraco.Cms.Core.Models;
|
|
using Umbraco.Cms.Infrastructure.Persistence.Dtos;
|
|
using Umbraco.Cms.Infrastructure.Persistence.Querying;
|
|
using Umbraco.Cms.Tests.UnitTests.TestHelpers;
|
|
using Umbraco.Extensions;
|
|
|
|
namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Persistence.Querying;
|
|
|
|
[TestFixture]
|
|
public class QueryBuilderTests : BaseUsingSqlSyntax
|
|
{
|
|
[Test]
|
|
public void Can_Build_StartsWith_Query_For_IContent()
|
|
{
|
|
// Arrange
|
|
var sql = Sql();
|
|
sql.SelectAll();
|
|
sql.From("umbracoNode");
|
|
|
|
var query = new Query<IContent>(SqlContext).Where(x => x.Path.StartsWith("-1"));
|
|
|
|
// Act
|
|
var translator = new SqlTranslator<IContent>(sql, query);
|
|
var result = translator.Translate();
|
|
var strResult = result.SQL;
|
|
|
|
var expectedResult = "SELECT *\nFROM umbracoNode\nWHERE (upper([umbracoNode].[path]) LIKE upper(@0))";
|
|
|
|
// Assert
|
|
Assert.That(strResult, Is.Not.Empty);
|
|
Assert.That(strResult, Is.EqualTo(expectedResult));
|
|
|
|
Assert.AreEqual(1, result.Arguments.Length);
|
|
Assert.AreEqual("-1%", sql.Arguments[0]);
|
|
|
|
Debug.Print(strResult);
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Build_ParentId_Query_For_IContent()
|
|
{
|
|
// Arrange
|
|
var sql = Sql();
|
|
sql.SelectAll();
|
|
sql.From("umbracoNode");
|
|
|
|
var query = new Query<IContent>(SqlContext).Where(x => x.ParentId == -1);
|
|
|
|
// Act
|
|
var translator = new SqlTranslator<IContent>(sql, query);
|
|
var result = translator.Translate();
|
|
var strResult = result.SQL;
|
|
|
|
var expectedResult = "SELECT *\nFROM umbracoNode\nWHERE (([umbracoNode].[parentId] = @0))";
|
|
|
|
// Assert
|
|
Assert.That(strResult, Is.Not.Empty);
|
|
Assert.That(strResult, Is.EqualTo(expectedResult));
|
|
|
|
Assert.AreEqual(1, result.Arguments.Length);
|
|
Assert.AreEqual(-1, sql.Arguments[0]);
|
|
|
|
Debug.Print(strResult);
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Build_ContentTypeAlias_Query_For_IContentType()
|
|
{
|
|
// Arrange
|
|
var sql = Sql();
|
|
sql.SelectAll();
|
|
sql.From("umbracoNode");
|
|
|
|
var query = new Query<IContentType>(SqlContext).Where(x => x.Alias == "umbTextpage");
|
|
|
|
// Act
|
|
var translator = new SqlTranslator<IContentType>(sql, query);
|
|
var result = translator.Translate();
|
|
var strResult = result.SQL;
|
|
|
|
var expectedResult = "SELECT *\nFROM umbracoNode\nWHERE (([cmsContentType].[alias] = @0))";
|
|
|
|
// Assert
|
|
Assert.That(strResult, Is.Not.Empty);
|
|
Assert.That(strResult, Is.EqualTo(expectedResult));
|
|
Assert.AreEqual(1, result.Arguments.Length);
|
|
Assert.AreEqual("umbTextpage", sql.Arguments[0]);
|
|
|
|
Debug.Print(strResult);
|
|
}
|
|
|
|
[Test]
|
|
public void Can_Build_PublishedDescendants_Query_For_IContent()
|
|
{
|
|
const string path = "-1,1046,1076,1089";
|
|
const int id = 1046;
|
|
|
|
var sql = Sql();
|
|
sql.SelectAll()
|
|
.From<DocumentDto>(); // the actual SELECT really does not matter
|
|
|
|
var query = SqlContext.Query<IContent>()
|
|
.Where(x => x.Path.StartsWith(path) && x.Id != id && x.Published && x.Trashed == false);
|
|
|
|
var translator = new SqlTranslator<IContent>(sql, query);
|
|
var result = translator.Translate();
|
|
|
|
Assert.AreEqual("-1,1046,1076,1089%", result.Arguments[0]);
|
|
Assert.AreEqual(1046, result.Arguments[1]);
|
|
Assert.AreEqual(true, result.Arguments[2]);
|
|
Assert.AreEqual(false, result.Arguments[3]);
|
|
}
|
|
}
|