Files
Umbraco-CMS/tests/Umbraco.Tests.UnitTests/Umbraco.Infrastructure/Persistence/Querying/QueryBuilderTests.cs
Paul Johnson 00133e880d Move test projects from src/ to tests/ (#11357)
* Update gitignore

* Move csproj

* Update project references

* Update solutions

* Update build scripts

* Tests used to share editorconfig with projects in src

* Fix broken tests.

* Stop copying around .editorconfig

merged root one with linting

* csharp_style_expression_bodied -> suggestion

* Move StyleCop rulesets to matching directories and update shared build properties

* Remove legacy build files, update NuGet.cofig and solution files

* Restore myget source

* Clean up .gitignore

* Update .gitignore

* Move new test classes to tests after merge

* Gitignore + nuget config

* Move new test

Co-authored-by: Ronald Barendse <ronald@barend.se>
2021-10-18 08:14:04 +01:00

122 lines
4.2 KiB
C#

// Copyright (c) Umbraco.
// See LICENSE for more details.
using System.Diagnostics;
using NPoco;
using NUnit.Framework;
using Umbraco.Cms.Core.Models;
using Umbraco.Cms.Core.Persistence.Querying;
using Umbraco.Cms.Infrastructure.Persistence;
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
Sql<ISqlContext> sql = Sql();
sql.SelectAll();
sql.From("umbracoNode");
IQuery<IContent> query = new Query<IContent>(SqlContext).Where(x => x.Path.StartsWith("-1"));
// Act
var translator = new SqlTranslator<IContent>(sql, query);
Sql<ISqlContext> result = translator.Translate();
string strResult = result.SQL;
string 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
Sql<ISqlContext> sql = Sql();
sql.SelectAll();
sql.From("umbracoNode");
IQuery<IContent> query = new Query<IContent>(SqlContext).Where(x => x.ParentId == -1);
// Act
var translator = new SqlTranslator<IContent>(sql, query);
Sql<ISqlContext> result = translator.Translate();
string strResult = result.SQL;
string 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
Sql<ISqlContext> sql = Sql();
sql.SelectAll();
sql.From("umbracoNode");
IQuery<IContentType> query = new Query<IContentType>(SqlContext).Where(x => x.Alias == "umbTextpage");
// Act
var translator = new SqlTranslator<IContentType>(sql, query);
Sql<ISqlContext> result = translator.Translate();
string strResult = result.SQL;
string 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;
Sql<ISqlContext> sql = Sql();
sql.SelectAll()
.From<DocumentDto>(); // the actual SELECT really does not matter
IQuery<IContent> 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);
Sql<ISqlContext> 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]);
}
}
}