* Only prevent the unpublish or delete of a related item when configured to do so if it is related as a child, not as a parent (#18886) * Only prevent the unpubkish or delete of a related item when configured to do so if it is related as a child, not as a parent. * Fixed incorect parameter names. * Fixed failing integration tests. * Use using variable instead to reduce nesting * Applied suggestions from code review. * Used simple using statement throughout RelationService for consistency. * Applied XML header comments consistently. --------- Co-authored-by: mole <nikolajlauridsen@protonmail.ch> * Feature: highlight invariant doc with variant blocks is unsupported (#18806) * mark variant blocks in invariant docs as invalid * implement RTE Blocks * Fix pagination for users restricted by start nodes (#18907) * Fix pagination for users restricted by start nodes * Default implementation to avoid breakage * Review comments * Fix failing test * Add media start node tests * Fix issue preventing blueprint derived values from being scaffolded (#18917) * Fix issue preventing blueprint derived values from being scaffolded. * fix manipulating frooen array * compare with variantId as well --------- Co-authored-by: Niels Lyngsø <niels.lyngso@gmail.com> * ci: add Azure Static Web Apps workflow file on-behalf-of: @Azure opensource@microsoft.com * ci: add Azure Static Web Apps workflow file on-behalf-of: @Azure opensource@microsoft.com * ci: add Azure Static Web Apps workflow file on-behalf-of: @Azure opensource@microsoft.com * Remove admin permission on user configuration, allowing users with user section access only to manaage users and groups. (#18848) * Tiptap RTE: Style Menu extension kind (#18918) * Adds 'styleMenu' Tiptap toolbar extension kind * Adds icons for `<h4>` and `<p>` tags * Adds commands to HTML Global Attributes extension for setting the `class` and `id` attributes. * Renamed "default-tiptap-toolbar-element.api.ts" file The "element" part was confusing. * Toolbar Menu: uses correct `item` value * Cascading Menu: adds localization for the label * Adds `label` attribute to UUI components for accessibility. * Toolbar Menu: uses correct `appearance` value * Removed unrequired `api` from Style Select * Destructs the `item.data` object * Ensure has children reflects only items with folder children when folders only are queried. (#18790) * Ensure has children reflects only items with folder children when folders only are queried. * Added supression for change to integration test public code. --------- Co-authored-by: Migaroez <geusens@gmail.com> * Only apply validation on content update to variant cultures where the editor has permission for the culture (#18778) * Only apply validation on content update to variant cultures where the editor has permission for the culture. * Remove inadvertent comment updates. * Fixed failing integration test. * Adds ancestor ID details on document tree and collection responses (#18909) * Populate ancestor keys on document tree response items. * Populate ancestor keys on document collection response items. * Update OpenApi.json * Use array of objects rather than Ids for the ancestor collection. * Update OpenApi.json. * Move publish with descendants to a background task with polling (#18497) * Use background queue for database cache rebuild and track rebuilding status. * Updated OpenApi.json and client-side types. * Updated client to poll for completion of database rebuild. * Move IBackgroundTaskQueue to core and prepare publish branch to run as background task. * Endpoints for retrieval of status and result from branch publish operations. * Poll and retrieve result for publish with descendants. * Handled issues from testing. * Rework to single controller for status and result. * Updated client side sdk. * OpenApi post dev merge gen --------- Co-authored-by: Migaroez <geusens@gmail.com> * Clear roots before rebuilding navigation dictionary (#18766) * Clear roots before rebuilding navigation dictionary. * Added tests to verify fix. * Correct test implementation. * Convert integration tests with method overloads into test cases. * Integration test compatibility supressions. * Fixes save of empty, invariant block list on variant content. (#18932) * remove unnecessary code (#18927) * V15/bugfix/fix route issue from 18859 (#18931) * unique check * unique for workspace empty path * more unique routes * Bump vite from 6.2.3 to 6.2.4 in /src/Umbraco.Web.UI.Client Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 6.2.3 to 6.2.4. - [Release notes](https://github.com/vitejs/vite/releases) - [Changelog](https://github.com/vitejs/vite/blob/v6.2.4/packages/vite/CHANGELOG.md) - [Commits](https://github.com/vitejs/vite/commits/v6.2.4/packages/vite) --- updated-dependencies: - dependency-name: vite dependency-version: 6.2.4 dependency-type: direct:development ... Signed-off-by: dependabot[bot] <support@github.com> * removes autogenerated workflows * make getHasUnpersistedChanges public (#18929) * Added management API endpoint, service and repository for retrieval of references from the recycle bin (#18882) * Added management API endpoint, service and repository for retrieval of references from the recycle bin. * Update src/Umbraco.Cms.Api.Management/Controllers/Document/RecycleBin/ReferencedByDocumentRecycleBinController.cs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Removed unused code. --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Updated management API endpoint and model for data type references to align with that used for documents, media etc. (#18905) * Updated management API endpoint and model for data type references to align with that used for documents, media etc. * Refactoring. * Update src/Umbraco.Core/Constants-ReferenceTypes.cs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Fixed typos. * Added id to tracked reference content type response. * Updated OpenApi.json. * Added missing updates. * Renamed model and constants from code review feedback. * Fix typo * Fix multiple enumeration --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: mole <nikolajlauridsen@protonmail.ch> * Skip lock tests * Look-up redirect in content finder for multi-lingual sites using path and legacy route prefixed with the integer ID of the node with domains defined (#18763) * Look-up redirect in content finder for multi-lingual sites using path and legacy route prefixed with the integer ID of the node with domains defined. * Added tests to verify functionality. * Added reference to previous PR. * Referenced second PR. * Assemble URLs for all cultures, not just the default. * Revert previous update. * Display an original URL if we have one. * Bump vite from 6.2.4 to 6.2.5 in /src/Umbraco.Web.UI.Client Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 6.2.4 to 6.2.5. - [Release notes](https://github.com/vitejs/vite/releases) - [Changelog](https://github.com/vitejs/vite/blob/v6.2.5/packages/vite/CHANGELOG.md) - [Commits](https://github.com/vitejs/vite/commits/v6.2.5/packages/vite) --- updated-dependencies: - dependency-name: vite dependency-version: 6.2.5 dependency-type: direct:development ... Signed-off-by: dependabot[bot] <support@github.com> * Add raw value validation to multiple text strings property editor (#18936) * Add raw value validation to multiple text strings property editor * Added additional assert on unit test and comment on validation logic. * Don't remove items to obtain a valid value --------- Co-authored-by: Andy Butland <abutland73@gmail.com> * Integration tests for content publishing with ancestor unpublished (#18941) * Resolved warnings in test class. * Refactor regions into partial classes. * Aligned test names. * Variable name refactoring. * Added tests for unpublished paths. * Adjust tests to verify current behaviour. * Cleaned up project file. * fix circular icon import (#18952) * remove segment toggle for elements (#18949) * Fix modal route registration circular import (#18953) * fix modal route registration circular import * Update modal-route-registration.controller.ts * V15/fix/18595 (#18925) * fix for #18595 * updates the en.ts * Avoid unneeded Dictionary operations (#18890) * Avoid some heap allocations * Remove unneeded double seek * Avoid allocating new empty arrays, reuse existing empty array * Avoid allocating strings for parsing comma separated int values (#18199) * Data type References UI: Workspace + Delete (#18914) * Updated management API endpoint and model for data type references to align with that used for documents, media etc. * Refactoring. * Update src/Umbraco.Core/Constants-ReferenceTypes.cs Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Fixed typos. * generate server models * add extension slot * register data type reference info app * add reference data mappers * Added id to tracked reference content type response. * Updated OpenApi.json. * Added missing updates. * generate new models * update models * register ref item * remove debugger * render types * register member type property type ref * register media type property type ref * Renamed model and constants from code review feedback. * register reference workspace info app kind * use kind for document references * use kind for media references * use kind for member references * use deleteWithRelation kind when deleting data types * fix manifest types * fix types * Update types.gen.ts * update code to fit new server models --------- Co-authored-by: Andy Butland <abutland73@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Feature: discard changes for block workspace (#18930) * make getHasUnpersistedChanges public * Discard changes impl for Block Workspace * fix 18367 (#18956) * Merge commit from fork * Prevent path traveral vulnerability with upload of temporary files. * Used BadRequest instead of NotFound for invalid file name response. * V15 QA Fixing the failing media acceptance tests (#18881) * Fixed the function name due to test helper changes * Updated assertion steps due to UI changes * Added more waits * Bumped version * Increase timeout * Reverted --------- Co-authored-by: Andreas Zerbst <73799582+andr317c@users.noreply.github.com> * V15 QA added clipboard test for not being able to copy to root when block is not allowed at root (#18937) * Added clipboard test * Bumped version * Updated to use the name * Run all tests on the pipeline * Reverted command * build: adjusts circular ref number to 4 --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: Andy Butland <abutland73@gmail.com> Co-authored-by: mole <nikolajlauridsen@protonmail.ch> Co-authored-by: Niels Lyngsø <nsl@umbraco.dk> Co-authored-by: Niels Lyngsø <niels.lyngso@gmail.com> Co-authored-by: Jacob Overgaard <752371+iOvergaard@users.noreply.github.com> Co-authored-by: Lee Kelleher <leekelleher@users.noreply.github.com> Co-authored-by: Migaroez <geusens@gmail.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Nikolaj Geisle <70372949+Zeegaan@users.noreply.github.com> Co-authored-by: Mads Rasmussen <madsr@hey.com> Co-authored-by: Jacob Welander Jensen <64834767+Welander1994@users.noreply.github.com> Co-authored-by: Henrik <hg@impact.dk> Co-authored-by: Sebastiaan Janssen <sebastiaan@umbraco.com> Co-authored-by: Nhu Dinh <150406148+nhudinh0309@users.noreply.github.com> Co-authored-by: Andreas Zerbst <73799582+andr317c@users.noreply.github.com>
1041 lines
37 KiB
C#
1041 lines
37 KiB
C#
// Copyright (c) Umbraco.
|
|
// See LICENSE for more details.
|
|
|
|
using NUnit.Framework;
|
|
using Umbraco.Cms.Core;
|
|
using Umbraco.Cms.Core.Models;
|
|
using Umbraco.Cms.Core.Models.Entities;
|
|
using Umbraco.Cms.Core.Services;
|
|
using Umbraco.Cms.Core.Services.ContentTypeEditing;
|
|
using Umbraco.Cms.Infrastructure.Persistence;
|
|
using Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement;
|
|
using Umbraco.Cms.Tests.Common.Attributes;
|
|
using Umbraco.Cms.Tests.Common.Builders;
|
|
using Umbraco.Cms.Tests.Common.Testing;
|
|
using Umbraco.Cms.Tests.Integration.Testing;
|
|
|
|
namespace Umbraco.Cms.Tests.Integration.Umbraco.Infrastructure.Services;
|
|
|
|
/// <summary>
|
|
/// Tests covering the EntityService
|
|
/// </summary>
|
|
[TestFixture]
|
|
[UmbracoTest(Database = UmbracoTestOptions.Database.NewSchemaPerFixture)]
|
|
internal sealed class EntityServiceTests : UmbracoIntegrationTest
|
|
{
|
|
[SetUp]
|
|
public async Task SetupTestData()
|
|
{
|
|
if (_langFr == null && _langEs == null)
|
|
{
|
|
_langFr = new Language("fr-FR", "French (France)");
|
|
_langEs = new Language("es-ES", "Spanish (Spain)");
|
|
await LanguageService.CreateAsync(_langFr, Constants.Security.SuperUserKey);
|
|
await LanguageService.CreateAsync(_langEs, Constants.Security.SuperUserKey);
|
|
}
|
|
|
|
await CreateTestData();
|
|
}
|
|
|
|
private Language? _langFr;
|
|
private Language? _langEs;
|
|
|
|
private ILanguageService LanguageService => GetRequiredService<ILanguageService>();
|
|
|
|
private IContentTypeService ContentTypeService => GetRequiredService<IContentTypeService>();
|
|
|
|
private IContentService ContentService => GetRequiredService<IContentService>();
|
|
|
|
private IEntityService EntityService => GetRequiredService<IEntityService>();
|
|
|
|
private ISqlContext SqlContext => GetRequiredService<ISqlContext>();
|
|
|
|
private IMediaTypeService MediaTypeService => GetRequiredService<IMediaTypeService>();
|
|
|
|
private IMediaService MediaService => GetRequiredService<IMediaService>();
|
|
|
|
private IFileService FileService => GetRequiredService<IFileService>();
|
|
|
|
private IContentTypeContainerService ContentTypeContainerService => GetRequiredService<IContentTypeContainerService>();
|
|
|
|
public IContentTypeEditingService ContentTypeEditingService => GetRequiredService<IContentTypeEditingService>();
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Paged_Descendants_Ordering_Path()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
var rootId = root.Id;
|
|
var ids = new List<int>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(c1);
|
|
ids.Add(c1.Id);
|
|
root = c1; // make a hierarchy
|
|
}
|
|
|
|
var entities = EntityService.GetPagedDescendants(rootId, UmbracoObjectTypes.Document, 0, 6, out var total)
|
|
.ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(6));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[0], entities[0].Id);
|
|
|
|
entities = EntityService.GetPagedDescendants(rootId, UmbracoObjectTypes.Document, 1, 6, out total).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[6], entities[0].Id);
|
|
|
|
// Test ordering direction
|
|
entities = EntityService.GetPagedDescendants(
|
|
rootId,
|
|
UmbracoObjectTypes.Document,
|
|
0,
|
|
6,
|
|
out total,
|
|
ordering: Ordering.By("Path", Direction.Descending)).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(6));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[^1], entities[0].Id);
|
|
|
|
entities = EntityService.GetPagedDescendants(
|
|
rootId,
|
|
UmbracoObjectTypes.Document,
|
|
1,
|
|
6,
|
|
out total,
|
|
ordering: Ordering.By("Path", Direction.Descending)).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[ids.Count - 1 - 6], entities[0].Id);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Paged_Content_Children()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
var ids = new List<int>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(c1);
|
|
ids.Add(c1.Id);
|
|
}
|
|
|
|
var entities = EntityService.GetPagedChildren(root.Id, UmbracoObjectTypes.Document, 0, 6, out var total)
|
|
.ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(6));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[0], entities[0].Id);
|
|
|
|
entities = EntityService.GetPagedChildren(root.Id, UmbracoObjectTypes.Document, 1, 6, out total).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[6], entities[0].Id);
|
|
|
|
// Test ordering direction
|
|
entities = EntityService.GetPagedChildren(
|
|
root.Id,
|
|
UmbracoObjectTypes.Document,
|
|
0,
|
|
6,
|
|
out total,
|
|
ordering: Ordering.By("SortOrder", Direction.Descending)).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(6));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[^1], entities[0].Id);
|
|
|
|
entities = EntityService.GetPagedChildren(
|
|
root.Id,
|
|
UmbracoObjectTypes.Document,
|
|
1,
|
|
6,
|
|
out total,
|
|
ordering: Ordering.By("SortOrder", Direction.Descending)).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
Assert.AreEqual(ids[ids.Count - 1 - 6], entities[0].Id);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Paged_Content_Descendants()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
var count = 0;
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(c1);
|
|
count++;
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), c1);
|
|
ContentService.Save(c2);
|
|
count++;
|
|
}
|
|
}
|
|
|
|
var entities = EntityService.GetPagedDescendants(root.Id, UmbracoObjectTypes.Document, 0, 31, out var total)
|
|
.ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(31));
|
|
Assert.That(total, Is.EqualTo(60));
|
|
entities = EntityService.GetPagedDescendants(root.Id, UmbracoObjectTypes.Document, 1, 31, out total).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(29));
|
|
Assert.That(total, Is.EqualTo(60));
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Content_Descendants_Including_Recycled()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
var toDelete = new List<IContent>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(c1);
|
|
|
|
if (i % 2 == 0)
|
|
{
|
|
toDelete.Add(c1);
|
|
}
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), c1);
|
|
ContentService.Save(c2);
|
|
}
|
|
}
|
|
|
|
foreach (var content in toDelete)
|
|
{
|
|
ContentService.MoveToRecycleBin(content);
|
|
}
|
|
|
|
// search at root to see if it returns recycled
|
|
var entities = EntityService.GetPagedDescendants(-1, UmbracoObjectTypes.Document, 0, 1000, out var total)
|
|
.Select(x => x.Id)
|
|
.ToArray();
|
|
|
|
foreach (var c in toDelete)
|
|
{
|
|
Assert.True(entities.Contains(c.Id));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Content_Descendants_Without_Recycled()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
var toDelete = new List<IContent>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(c1);
|
|
|
|
if (i % 2 == 0)
|
|
{
|
|
toDelete.Add(c1);
|
|
}
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), c1);
|
|
ContentService.Save(c2);
|
|
}
|
|
}
|
|
|
|
foreach (var content in toDelete)
|
|
{
|
|
ContentService.MoveToRecycleBin(content);
|
|
}
|
|
|
|
// search at root to see if it returns recycled
|
|
var entities = EntityService
|
|
.GetPagedDescendants(UmbracoObjectTypes.Document, 0, 1000, out var total, includeTrashed: false)
|
|
.Select(x => x.Id)
|
|
.ToArray();
|
|
|
|
foreach (var c in toDelete)
|
|
{
|
|
Assert.IsFalse(entities.Contains(c.Id));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Trashed_Content_Children()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
var toDelete = new List<IContent>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(c1);
|
|
|
|
if (i % 2 == 0)
|
|
{
|
|
toDelete.Add(c1);
|
|
}
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), c1);
|
|
ContentService.Save(c2);
|
|
}
|
|
}
|
|
|
|
foreach (var content in toDelete)
|
|
{
|
|
ContentService.MoveToRecycleBin(content);
|
|
}
|
|
|
|
// get paged entities at recycle bin root
|
|
var entities = EntityService
|
|
.GetPagedTrashedChildren(Constants.System.RecycleBinContent, UmbracoObjectTypes.Document, 0, 1000, out var total)
|
|
.Select(x => x.Id)
|
|
.ToArray();
|
|
|
|
Assert.True(total > 0);
|
|
foreach (var c in toDelete)
|
|
{
|
|
Assert.IsTrue(entities.Contains(c.Id));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Paged_Content_Descendants_With_Search()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, "ssss" + Guid.NewGuid(), root);
|
|
ContentService.Save(c1);
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = ContentBuilder.CreateSimpleContent(contentType, "tttt" + Guid.NewGuid(), c1);
|
|
ContentService.Save(c2);
|
|
}
|
|
}
|
|
|
|
var entities = EntityService.GetPagedDescendants(
|
|
root.Id,
|
|
UmbracoObjectTypes.Document,
|
|
0,
|
|
10,
|
|
out var total,
|
|
SqlContext.Query<IUmbracoEntity>().Where(x => x.Name.Contains("ssss"))).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(10));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
entities = EntityService.GetPagedDescendants(
|
|
root.Id,
|
|
UmbracoObjectTypes.Document,
|
|
0,
|
|
50,
|
|
out total,
|
|
SqlContext.Query<IUmbracoEntity>().Where(x => x.Name.Contains("tttt"))).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(50));
|
|
Assert.That(total, Is.EqualTo(50));
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Paged_Media_Children()
|
|
{
|
|
var folderType = MediaTypeService.Get(1031);
|
|
var imageMediaType = MediaTypeService.Get(1032);
|
|
|
|
var root = MediaBuilder.CreateMediaFolder(folderType, -1);
|
|
MediaService.Save(root);
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = MediaBuilder.CreateMediaImage(imageMediaType, root.Id);
|
|
MediaService.Save(c1);
|
|
}
|
|
|
|
var entities = EntityService.GetPagedChildren(root.Id, UmbracoObjectTypes.Media, 0, 6, out var total).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(6));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
entities = EntityService.GetPagedChildren(root.Id, UmbracoObjectTypes.Media, 1, 6, out total).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
}
|
|
|
|
[Test]
|
|
public async Task EntityService_Can_Get_Paged_Document_Type_Children()
|
|
{
|
|
IEnumerable<IEntitySlim> children = EntityService.GetPagedChildren(
|
|
_documentTypeRootContainerKey,
|
|
[UmbracoObjectTypes.DocumentTypeContainer],
|
|
[UmbracoObjectTypes.DocumentTypeContainer, UmbracoObjectTypes.DocumentType],
|
|
0,
|
|
10,
|
|
false,
|
|
out long totalRecords);
|
|
|
|
Assert.AreEqual(3, totalRecords);
|
|
Assert.AreEqual(3, children.Count());
|
|
Assert.IsTrue(children.Single(x => x.Key == _documentTypeSubContainer1Key).HasChildren); // Has a single folder as a child.
|
|
Assert.IsTrue(children.Single(x => x.Key == _documentTypeSubContainer2Key).HasChildren); // Has a single document type as a child.
|
|
Assert.IsFalse(children.Single(x => x.Key == _documentType1Key).HasChildren); // Is a document type (has no children).
|
|
}
|
|
|
|
[Test]
|
|
public async Task EntityService_Can_Get_Paged_Document_Type_Children_For_Folders_Only()
|
|
{
|
|
IEnumerable<IEntitySlim> children = EntityService.GetPagedChildren(
|
|
_documentTypeRootContainerKey,
|
|
[UmbracoObjectTypes.DocumentTypeContainer],
|
|
[UmbracoObjectTypes.DocumentTypeContainer],
|
|
0,
|
|
10,
|
|
false,
|
|
out long totalRecords);
|
|
|
|
Assert.AreEqual(2, totalRecords);
|
|
Assert.AreEqual(2, children.Count());
|
|
Assert.IsTrue(children.Single(x => x.Key == _documentTypeSubContainer1Key).HasChildren); // Has a single folder as a child.
|
|
Assert.IsFalse(children.Single(x => x.Key == _documentTypeSubContainer2Key).HasChildren); // Has a single document type as a child.
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Media_Descendants()
|
|
{
|
|
var folderType = MediaTypeService.Get(1031);
|
|
var imageMediaType = MediaTypeService.Get(1032);
|
|
|
|
var root = MediaBuilder.CreateMediaFolder(folderType, -1);
|
|
MediaService.Save(root);
|
|
var count = 0;
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = MediaBuilder.CreateMediaImage(imageMediaType, root.Id);
|
|
MediaService.Save(c1);
|
|
count++;
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = MediaBuilder.CreateMediaImage(imageMediaType, c1.Id);
|
|
MediaService.Save(c2);
|
|
count++;
|
|
}
|
|
}
|
|
|
|
var entities = EntityService.GetPagedDescendants(root.Id, UmbracoObjectTypes.Media, 0, 31, out var total)
|
|
.ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(31));
|
|
Assert.That(total, Is.EqualTo(60));
|
|
entities = EntityService.GetPagedDescendants(root.Id, UmbracoObjectTypes.Media, 1, 31, out total).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(29));
|
|
Assert.That(total, Is.EqualTo(60));
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Media_Descendants_Including_Recycled()
|
|
{
|
|
var folderType = MediaTypeService.Get(1031);
|
|
var imageMediaType = MediaTypeService.Get(1032);
|
|
|
|
var root = MediaBuilder.CreateMediaFolder(folderType, -1);
|
|
MediaService.Save(root);
|
|
var toDelete = new List<IMedia>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = MediaBuilder.CreateMediaImage(imageMediaType, root.Id);
|
|
MediaService.Save(c1);
|
|
|
|
if (i % 2 == 0)
|
|
{
|
|
toDelete.Add(c1);
|
|
}
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = MediaBuilder.CreateMediaImage(imageMediaType, c1.Id);
|
|
MediaService.Save(c2);
|
|
}
|
|
}
|
|
|
|
foreach (var content in toDelete)
|
|
{
|
|
MediaService.MoveToRecycleBin(content);
|
|
}
|
|
|
|
// search at root to see if it returns recycled
|
|
var entities = EntityService.GetPagedDescendants(-1, UmbracoObjectTypes.Media, 0, 1000, out var total)
|
|
.Select(x => x.Id)
|
|
.ToArray();
|
|
|
|
foreach (var media in toDelete)
|
|
{
|
|
Assert.IsTrue(entities.Contains(media.Id));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Media_Descendants_Without_Recycled()
|
|
{
|
|
var folderType = MediaTypeService.Get(1031);
|
|
var imageMediaType = MediaTypeService.Get(1032);
|
|
|
|
var root = MediaBuilder.CreateMediaFolder(folderType, -1);
|
|
MediaService.Save(root);
|
|
var toDelete = new List<IMedia>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = MediaBuilder.CreateMediaImage(imageMediaType, root.Id);
|
|
MediaService.Save(c1);
|
|
|
|
if (i % 2 == 0)
|
|
{
|
|
toDelete.Add(c1);
|
|
}
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = MediaBuilder.CreateMediaImage(imageMediaType, c1.Id);
|
|
MediaService.Save(c2);
|
|
}
|
|
}
|
|
|
|
foreach (var content in toDelete)
|
|
{
|
|
MediaService.MoveToRecycleBin(content);
|
|
}
|
|
|
|
// search at root to see if it returns recycled
|
|
var entities = EntityService
|
|
.GetPagedDescendants(UmbracoObjectTypes.Media, 0, 1000, out var total, includeTrashed: false)
|
|
.Select(x => x.Id)
|
|
.ToArray();
|
|
|
|
foreach (var media in toDelete)
|
|
{
|
|
Assert.IsFalse(entities.Contains(media.Id));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Trashed_Media_Children()
|
|
{
|
|
var folderType = MediaTypeService.Get(1031);
|
|
var imageMediaType = MediaTypeService.Get(1032);
|
|
|
|
var root = MediaBuilder.CreateMediaFolder(folderType, -1);
|
|
MediaService.Save(root);
|
|
var toDelete = new List<IMedia>();
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = MediaBuilder.CreateMediaImage(imageMediaType, root.Id);
|
|
MediaService.Save(c1);
|
|
|
|
if (i % 2 == 0)
|
|
{
|
|
toDelete.Add(c1);
|
|
}
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = MediaBuilder.CreateMediaImage(imageMediaType, c1.Id);
|
|
MediaService.Save(c2);
|
|
}
|
|
}
|
|
|
|
foreach (var content in toDelete)
|
|
{
|
|
MediaService.MoveToRecycleBin(content);
|
|
}
|
|
|
|
// get paged entities at recycle bin root
|
|
var entities = EntityService
|
|
.GetPagedTrashedChildren(Constants.System.RecycleBinMedia, UmbracoObjectTypes.Media, 0, 1000, out var total)
|
|
.Select(x => x.Id)
|
|
.ToArray();
|
|
|
|
Assert.True(total > 0);
|
|
foreach (var media in toDelete)
|
|
{
|
|
Assert.IsTrue(entities.Contains(media.Id));
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
[LongRunning]
|
|
public void EntityService_Can_Get_Paged_Media_Descendants_With_Search()
|
|
{
|
|
var folderType = MediaTypeService.Get(1031);
|
|
var imageMediaType = MediaTypeService.Get(1032);
|
|
|
|
var root = MediaBuilder.CreateMediaFolder(folderType, -1);
|
|
MediaService.Save(root);
|
|
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = MediaBuilder.CreateMediaImage(imageMediaType, root.Id);
|
|
c1.Name = "ssss" + Guid.NewGuid();
|
|
MediaService.Save(c1);
|
|
|
|
for (var j = 0; j < 5; j++)
|
|
{
|
|
var c2 = MediaBuilder.CreateMediaImage(imageMediaType, c1.Id);
|
|
c2.Name = "tttt" + Guid.NewGuid();
|
|
MediaService.Save(c2);
|
|
}
|
|
}
|
|
|
|
var entities = EntityService.GetPagedDescendants(
|
|
root.Id,
|
|
UmbracoObjectTypes.Media,
|
|
0,
|
|
10,
|
|
out var total,
|
|
SqlContext.Query<IUmbracoEntity>().Where(x => x.Name.Contains("ssss"))).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(10));
|
|
Assert.That(total, Is.EqualTo(10));
|
|
entities = EntityService.GetPagedDescendants(
|
|
root.Id,
|
|
UmbracoObjectTypes.Media,
|
|
0,
|
|
50,
|
|
out total,
|
|
SqlContext.Query<IUmbracoEntity>().Where(x => x.Name.Contains("tttt"))).ToArray();
|
|
Assert.That(entities.Length, Is.EqualTo(50));
|
|
Assert.That(total, Is.EqualTo(50));
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_Content_By_UmbracoObjectTypes()
|
|
{
|
|
var entities = EntityService.GetAll(UmbracoObjectTypes.Document).ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(entities.Any(x => x.Trashed), Is.True);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_Content_By_UmbracoObjectType_Id()
|
|
{
|
|
var objectTypeId = Constants.ObjectTypes.Document;
|
|
var entities = EntityService.GetAll(objectTypeId).ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(entities.Any(x => x.Trashed), Is.True);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_Content_By_Type()
|
|
{
|
|
var entities = EntityService.GetAll<IContent>().ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Length, Is.EqualTo(4));
|
|
Assert.That(entities.Any(x => x.Trashed), Is.True);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Child_Content_By_ParentId_And_UmbracoObjectType()
|
|
{
|
|
var entities = EntityService.GetChildren(-1, UmbracoObjectTypes.Document).ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Length, Is.EqualTo(1));
|
|
Assert.That(entities.Any(x => x.Trashed), Is.False);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Content_By_UmbracoObjectType_With_Variant_Names()
|
|
{
|
|
var alias = "test" + Guid.NewGuid();
|
|
var template = TemplateBuilder.CreateTextPageTemplate(alias);
|
|
FileService.SaveTemplate(template);
|
|
var contentType = ContentTypeBuilder.CreateSimpleContentType("test2", "Test2", defaultTemplateId: template.Id);
|
|
contentType.Variations = ContentVariation.Culture;
|
|
ContentTypeService.Save(contentType);
|
|
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, "Test");
|
|
c1.SetCultureName("Test - FR", _langFr.IsoCode);
|
|
c1.SetCultureName("Test - ES", _langEs.IsoCode);
|
|
ContentService.Save(c1);
|
|
|
|
var result = EntityService.Get(c1.Id, UmbracoObjectTypes.Document);
|
|
Assert.AreEqual("Test - FR", result.Name); // got name from default culture
|
|
Assert.IsNotNull(result as IDocumentEntitySlim);
|
|
var doc = (IDocumentEntitySlim)result;
|
|
var cultureNames = doc.CultureNames;
|
|
Assert.AreEqual("Test - FR", cultureNames[_langFr.IsoCode]);
|
|
Assert.AreEqual("Test - ES", cultureNames[_langEs.IsoCode]);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Child_Content_By_ParentId_And_UmbracoObjectType_With_Variant_Names()
|
|
{
|
|
var template = TemplateBuilder.CreateTextPageTemplate();
|
|
FileService.SaveTemplate(template);
|
|
var contentType = ContentTypeBuilder.CreateSimpleContentType("test1", "Test1", defaultTemplateId: template.Id);
|
|
contentType.Variations = ContentVariation.Culture;
|
|
ContentTypeService.Save(contentType);
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
root.SetCultureName("Root", _langFr.IsoCode); // else cannot save
|
|
ContentService.Save(root);
|
|
|
|
for (var i = 0; i < 10; i++)
|
|
{
|
|
var c1 = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
if (i % 2 == 0)
|
|
{
|
|
c1.SetCultureName("Test " + i + " - FR", _langFr.IsoCode);
|
|
c1.SetCultureName("Test " + i + " - ES", _langEs.IsoCode);
|
|
}
|
|
else
|
|
{
|
|
c1.SetCultureName("Test", _langFr.IsoCode); // else cannot save
|
|
}
|
|
|
|
ContentService.Save(c1);
|
|
}
|
|
|
|
var entities = EntityService.GetChildren(root.Id, UmbracoObjectTypes.Document).ToArray();
|
|
|
|
Assert.AreEqual(10, entities.Length);
|
|
|
|
for (var i = 0; i < entities.Length; i++)
|
|
{
|
|
if (i % 2 == 0)
|
|
{
|
|
var doc = (IDocumentEntitySlim)entities[i];
|
|
var keys = doc.CultureNames.Keys.ToList();
|
|
var vals = doc.CultureNames.Values.ToList();
|
|
Assert.AreEqual(_langFr.IsoCode.ToLowerInvariant(), keys[0].ToLowerInvariant());
|
|
Assert.AreEqual("Test " + i + " - FR", vals[0]);
|
|
Assert.AreEqual(_langEs.IsoCode.ToLowerInvariant(), keys[1].ToLowerInvariant());
|
|
Assert.AreEqual("Test " + i + " - ES", vals[1]);
|
|
}
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Children_By_ParentId()
|
|
{
|
|
var entities = EntityService.GetChildren(_folderId);
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Count(), Is.EqualTo(3));
|
|
Assert.That(entities.Any(x => x.Trashed), Is.False);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Descendants_By_ParentId()
|
|
{
|
|
var entities = EntityService.GetDescendants(_folderId);
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Count(), Is.EqualTo(4));
|
|
Assert.That(entities.Any(x => x.Trashed), Is.False);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Throws_When_Getting_All_With_Invalid_Type()
|
|
{
|
|
var objectTypeId = Constants.ObjectTypes.ContentItem;
|
|
|
|
Assert.Throws<NotSupportedException>(() => EntityService.GetAll<IContentBase>());
|
|
Assert.Throws<NotSupportedException>(() => EntityService.GetAll(objectTypeId));
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_ContentTypes_By_UmbracoObjectTypes()
|
|
{
|
|
var entities = EntityService.GetAll(UmbracoObjectTypes.DocumentType).ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Count(), Is.EqualTo(3));
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_ContentTypes_By_UmbracoObjectType_Id()
|
|
{
|
|
var objectTypeId = Constants.ObjectTypes.DocumentType;
|
|
var entities = EntityService.GetAll(objectTypeId).ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Count(), Is.EqualTo(3));
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_ContentTypes_By_Type()
|
|
{
|
|
var entities = EntityService.GetAll<IContentType>().ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Count(), Is.EqualTo(3));
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Find_All_Media_By_UmbracoObjectTypes()
|
|
{
|
|
var entities = EntityService.GetAll(UmbracoObjectTypes.Media).ToArray();
|
|
|
|
Assert.That(entities.Any(), Is.True);
|
|
Assert.That(entities.Length, Is.EqualTo(5));
|
|
|
|
foreach (var entity in entities)
|
|
{
|
|
Assert.IsTrue(entity.GetType().Implements<IMediaEntitySlim>());
|
|
Console.WriteLine(((IMediaEntitySlim)entity).MediaPath);
|
|
Assert.IsNotEmpty(((IMediaEntitySlim)entity).MediaPath);
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_ObjectType()
|
|
{
|
|
var mediaObjectType = EntityService.GetObjectType(1031);
|
|
|
|
Assert.NotNull(mediaObjectType);
|
|
Assert.AreEqual(mediaObjectType, UmbracoObjectTypes.MediaType);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Key_For_Id_With_Unknown_Type()
|
|
{
|
|
var result = EntityService.GetKey(_contentType.Id, UmbracoObjectTypes.Unknown);
|
|
|
|
Assert.IsTrue(result.Success);
|
|
Assert.AreEqual(Guid.Parse("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522"), result.Result);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Key_For_Id()
|
|
{
|
|
var result = EntityService.GetKey(_contentType.Id, UmbracoObjectTypes.DocumentType);
|
|
|
|
Assert.IsTrue(result.Success);
|
|
Assert.AreEqual(Guid.Parse("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522"), result.Result);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Cannot_Get_Key_For_Id_With_Incorrect_Object_Type()
|
|
{
|
|
var result1 = EntityService.GetKey(_contentType.Id, UmbracoObjectTypes.DocumentType);
|
|
var result2 = EntityService.GetKey(_contentType.Id, UmbracoObjectTypes.MediaType);
|
|
|
|
Assert.IsTrue(result1.Success);
|
|
Assert.IsFalse(result2.Success);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Id_For_Key_With_Unknown_Type()
|
|
{
|
|
var result =
|
|
EntityService.GetId(Guid.Parse("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522"), UmbracoObjectTypes.Unknown);
|
|
|
|
Assert.IsTrue(result.Success);
|
|
Assert.AreEqual(_contentType.Id, result.Result);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Can_Get_Id_For_Key()
|
|
{
|
|
var result = EntityService.GetId(Guid.Parse("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522"),
|
|
UmbracoObjectTypes.DocumentType);
|
|
|
|
Assert.IsTrue(result.Success);
|
|
Assert.AreEqual(_contentType.Id, result.Result);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_Cannot_Get_Id_For_Key_With_Incorrect_Object_Type()
|
|
{
|
|
var result1 = EntityService.GetId(
|
|
Guid.Parse("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522"),
|
|
UmbracoObjectTypes.DocumentType);
|
|
var result2 = EntityService.GetId(
|
|
Guid.Parse("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522"),
|
|
UmbracoObjectTypes.MediaType);
|
|
|
|
Assert.IsTrue(result1.Success);
|
|
Assert.IsFalse(result2.Success);
|
|
}
|
|
|
|
[Test]
|
|
public void ReserveId()
|
|
{
|
|
var guid = Guid.NewGuid();
|
|
|
|
// can reserve
|
|
var reservedId = EntityService.ReserveId(guid);
|
|
Assert.IsTrue(reservedId > 0);
|
|
|
|
// can get it back
|
|
var id = EntityService.GetId(guid, UmbracoObjectTypes.DocumentType);
|
|
Assert.IsTrue(id.Success);
|
|
Assert.AreEqual(reservedId, id.Result);
|
|
|
|
// anything goes
|
|
id = EntityService.GetId(guid, UmbracoObjectTypes.Media);
|
|
Assert.IsTrue(id.Success);
|
|
Assert.AreEqual(reservedId, id.Result);
|
|
|
|
// a random guid won't work
|
|
Assert.IsFalse(EntityService.GetId(Guid.NewGuid(), UmbracoObjectTypes.DocumentType).Success);
|
|
}
|
|
|
|
[Test]
|
|
public void EntityService_GetPathKeys_ReturnsExpectedKeys()
|
|
{
|
|
var contentType = ContentTypeService.Get("umbTextpage");
|
|
|
|
var root = ContentBuilder.CreateSimpleContent(contentType);
|
|
ContentService.Save(root);
|
|
|
|
var child = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), root);
|
|
ContentService.Save(child);
|
|
var grandChild = ContentBuilder.CreateSimpleContent(contentType, Guid.NewGuid().ToString(), child);
|
|
ContentService.Save(grandChild);
|
|
|
|
var result = EntityService.GetPathKeys(grandChild);
|
|
Assert.AreEqual($"{root.Key},{child.Key},{grandChild.Key}", string.Join(",", result));
|
|
|
|
var result2 = EntityService.GetPathKeys(grandChild, omitSelf: true);
|
|
Assert.AreEqual($"{root.Key},{child.Key}", string.Join(",", result2));
|
|
|
|
}
|
|
|
|
private static bool _isSetup;
|
|
|
|
private int _folderId;
|
|
private ContentType _contentType;
|
|
private Content _textpage;
|
|
private Content _subpage;
|
|
private Content _subpage2;
|
|
private Content _trashed;
|
|
private IMediaType _folderMediaType;
|
|
private Media _folder;
|
|
private IMediaType _imageMediaType;
|
|
private Media _image;
|
|
private Media _subfolder;
|
|
private Media _subfolder2;
|
|
|
|
public async Task CreateTestData()
|
|
{
|
|
if (_isSetup == false)
|
|
{
|
|
_isSetup = true;
|
|
|
|
var template = TemplateBuilder.CreateTextPageTemplate("defaultTemplate");
|
|
FileService.SaveTemplate(template); // else, FK violation on contentType!
|
|
|
|
// Create and Save ContentType "umbTextpage" -> _contentType.Id
|
|
_contentType =
|
|
ContentTypeBuilder.CreateSimpleContentType("umbTextpage", "Textpage", defaultTemplateId: template.Id);
|
|
_contentType.Key = new Guid("1D3A8E6E-2EA9-4CC1-B229-1AEE19821522");
|
|
ContentTypeService.Save(_contentType);
|
|
|
|
// Create and Save Content "Homepage" based on "umbTextpage" -> 1053
|
|
_textpage = ContentBuilder.CreateSimpleContent(_contentType);
|
|
_textpage.Key = new Guid("B58B3AD4-62C2-4E27-B1BE-837BD7C533E0");
|
|
ContentService.Save(_textpage, -1);
|
|
|
|
// Create and Save Content "Text Page 1" based on "umbTextpage" -> 1054
|
|
_subpage = ContentBuilder.CreateSimpleContent(_contentType, "Text Page 1", _textpage.Id);
|
|
var contentSchedule = ContentScheduleCollection.CreateWithEntry(DateTime.Now.AddMinutes(-5), null);
|
|
ContentService.Save(_subpage, -1, contentSchedule);
|
|
|
|
// Create and Save Content "Text Page 2" based on "umbTextpage" -> 1055
|
|
_subpage2 = ContentBuilder.CreateSimpleContent(_contentType, "Text Page 2", _textpage.Id);
|
|
ContentService.Save(_subpage2, -1);
|
|
|
|
// Create and Save Content "Text Page Deleted" based on "umbTextpage" -> 1056
|
|
_trashed = ContentBuilder.CreateSimpleContent(_contentType, "Text Page Deleted", -20);
|
|
_trashed.Trashed = true;
|
|
ContentService.Save(_trashed, -1);
|
|
|
|
// Create and Save folder-Media -> 1057
|
|
_folderMediaType = MediaTypeService.Get(1031);
|
|
_folder = MediaBuilder.CreateMediaFolder(_folderMediaType, -1);
|
|
MediaService.Save(_folder, -1);
|
|
_folderId = _folder.Id;
|
|
|
|
// Create and Save image-Media -> 1058
|
|
_imageMediaType = MediaTypeService.Get(1032);
|
|
_image = MediaBuilder.CreateMediaImage(_imageMediaType, _folder.Id);
|
|
MediaService.Save(_image, -1);
|
|
|
|
// Create and Save file-Media -> 1059
|
|
var fileMediaType = MediaTypeService.Get(1033);
|
|
var file = MediaBuilder.CreateMediaFile(fileMediaType, _folder.Id);
|
|
MediaService.Save(file, -1);
|
|
|
|
// Create and save sub folder -> 1060
|
|
_subfolder = MediaBuilder.CreateMediaFolder(_folderMediaType, _folder.Id);
|
|
MediaService.Save(_subfolder, -1);
|
|
|
|
// Create and save sub folder -> 1061
|
|
_subfolder2 = MediaBuilder.CreateMediaFolder(_folderMediaType, _subfolder.Id);
|
|
MediaService.Save(_subfolder2, -1);
|
|
|
|
// Setup document type folder structure for tests on paged children with or without folders
|
|
await CreateStructureForPagedDocumentTypeChildrenTest();
|
|
}
|
|
}
|
|
|
|
private static readonly Guid _documentTypeRootContainerKey = Guid.NewGuid();
|
|
private static readonly Guid _documentTypeSubContainer1Key = Guid.NewGuid();
|
|
private static readonly Guid _documentTypeSubContainer2Key = Guid.NewGuid();
|
|
private static readonly Guid _documentType1Key = Guid.NewGuid();
|
|
|
|
private async Task CreateStructureForPagedDocumentTypeChildrenTest()
|
|
{
|
|
// Structure created:
|
|
// - root container
|
|
// - sub container 1
|
|
// - sub container 1b
|
|
// - sub container 2
|
|
// - doc type 2
|
|
// - doc type 1
|
|
await ContentTypeContainerService.CreateAsync(_documentTypeRootContainerKey, "Root Container", null, Constants.Security.SuperUserKey);
|
|
await ContentTypeContainerService.CreateAsync(_documentTypeSubContainer1Key, "Sub Container 1", _documentTypeRootContainerKey, Constants.Security.SuperUserKey);
|
|
await ContentTypeContainerService.CreateAsync(_documentTypeSubContainer2Key, "Sub Container 2", _documentTypeRootContainerKey, Constants.Security.SuperUserKey);
|
|
await ContentTypeContainerService.CreateAsync(Guid.NewGuid(), "Sub Container 1b", _documentTypeSubContainer1Key, Constants.Security.SuperUserKey);
|
|
|
|
var docType1Model = ContentTypeEditingBuilder.CreateBasicContentType("umbDocType1", "Doc Type 1");
|
|
docType1Model.ContainerKey = _documentTypeRootContainerKey;
|
|
docType1Model.Key = _documentType1Key;
|
|
await ContentTypeEditingService.CreateAsync(docType1Model, Constants.Security.SuperUserKey);
|
|
|
|
var docType2Model = ContentTypeEditingBuilder.CreateBasicContentType("umbDocType2", "Doc Type 2");
|
|
docType2Model.ContainerKey = _documentTypeSubContainer2Key;
|
|
await ContentTypeEditingService.CreateAsync(docType2Model, Constants.Security.SuperUserKey);
|
|
}
|
|
}
|