Files
Umbraco-CMS/tests/Umbraco.Tests.Common/Published/PublishedContentXmlAdapter.cs

150 lines
6.4 KiB
C#
Raw Normal View History

V15: Remove Nucache (#17166) * Remove nucache reference from Web.Common * Get tests building-ish * Move ReservedFieldNamesService to the right project * Remove IPublishedSnapshotStatus * Added functionality to the INavigationQueryService to get root keys * Fixed issue with navigation * Remove IPublishedSnapshot from UmbracoContext * Begin removing usage of IPublishedSnapshot from PublishedContentExtensions * Fix PublishedContentExtensions.cs * Don't use snapshots in delivery media api * Use IPublishedMediaCache in QueryMediaApiController * Remove more usages of IPublishedSnapshotAccessor * Comment out tests * Remove more usages of PublishedSnapshotAccessor * Remove PublishedSnapshot from property * Fixed test build * Fix errors * Fix some tests * Delete NuCache 🎉 * Implement DatabaseCacheRebuilder * Remove usage of IPublishedSnapshotService * Remove IPublishedSnapshotService * Remove TestPublishedSnapshotAccessor and make tests build * Don't test Snapshot cachelevel It's no longer supported * Fix BlockEditorConverter Element != Element document type * Remember to set cachemanager * Fix RichTextParserTests * Implement TryGetLevel on INavigationQueryService * Fake level and obsolete it in PublishedContent * Remove ChildrenForAllCultures * Hack Path property on PublishedContent * Remove usages of IPublishedSnapshot in tests * More ConvertersTests * Add hybrid cache to integration tests We can actually do this now because we no longer save files on disk * Rename IPublishedSnapshotRebuilder to ICacheRebuilder * Comment out tests * V15: Replacing the usages of Parent (navigation data) from IPublishedContent (#17125) * Fix .Parent references in PublishedContentExtensions * Add missing methods to FriendlyPublishedContentExtensions (ones that you were able to call on the content directly as they now require extra params) * Fix references from the extension methods * Fix dependencies in tests * Replace IPublishedSnapshotAccessor with the content cache in tests * Resolving more .Parent references * Fix unit tests * Obsolete and use extension methods * Remove private method and use extension instead * Moving code around * Fix tests * Fix more references * Cleanup * Fix more usages * Resolve merge conflict * Fix tests * Cleanup * Fix more tests * Fixed unit tests * Cleanup * Replace last usages --------- Co-authored-by: Bjarke Berg <mail@bergmania.dk> * Remove usage of IPublishedSnapshotAccessor from IRequestItemProvider * Post merge fixup * Remo IPublishedSnapshot * Add HasAny to IDocumentUrlService * Fix TextBuilder * Fix modelsbuilder tests * Use explicit types * Implement GetByContentType * Support element types in PublishedContentTypeCache * Run enlistments before publishing notifications * Fix elements cache refreshing * Implement GetByUdi * Implement GetAtRoot * Implement GetByRoute * Reimplement GetRouteById * Fix blocks unit tests * Initialize domain cache on boot * Only return routes with domains on non default lanauges * V15: Replacing the usages of `Children` (navigation data) from `IPublishedContent` (#17159) * Update params in PublishedContentExtensions to the general interfaces for the published cache and navigation service, so that we can use the extension methods on both documents and media * Introduce GetParent() which uses the right services * Fix obsolete message on .Parent * Obsolete .Children * Fix usages of Children for ApiMediaQueryService * Fix usage in internal * Fix usages in views * Fix indentation * Fix issue with delete language * Update nuget pacakges * Clear elements cache when content is deleted instead of trying to update it * Reset publishedModelFactory * Fixed publishing --------- Co-authored-by: Bjarke Berg <mail@bergmania.dk> Co-authored-by: Elitsa Marinovska <21998037+elit0451@users.noreply.github.com> Co-authored-by: kjac <kja@umbraco.dk>
2024-10-01 15:03:02 +02:00
// // Copyright (c) Umbraco.
// // See LICENSE for more details.
//
// using System;
// using System.Collections.Generic;
// using System.Linq;
// using System.Xml.Linq;
// using System.Xml.XPath;
// using Moq;
// using Umbraco.Cms.Core.Models;
// using Umbraco.Cms.Core.PropertyEditors;
// using Umbraco.Cms.Core.Strings;
// using Umbraco.Cms.Infrastructure.PublishedCache;
// using Umbraco.Cms.Infrastructure.PublishedCache.DataSource;
// using Umbraco.Cms.Infrastructure.PublishedCache.Persistence;
// using Umbraco.Cms.Infrastructure.Serialization;
// using Umbraco.Cms.Tests.Common.Builders;
// using Umbraco.Cms.Tests.Common.Builders.Extensions;
// using Umbraco.Extensions;
//
// namespace Umbraco.Cms.Tests.Common.Published;
// FIXME: Reintroduce if relevant
//
// /// <summary>
// /// Converts legacy Umbraco XML structures to NuCache <see cref="ContentNodeKit" /> collections
// /// to populate a test implementation of <see cref="INuCacheContentService" />
// /// </summary>
// /// <remarks>
// /// This does not support variant data because the XML structure doesn't support variant data.
// /// </remarks>
// public static class PublishedContentXmlAdapter
// {
// /// <summary>
// /// Generate a collection of <see cref="ContentNodeKit" /> based on legacy umbraco XML
// /// </summary>
// /// <param name="xml">The legacy umbraco XML</param>
// /// <param name="shortStringHelper"></param>
// /// <param name="contentTypes">Dynamically generates a list of <see cref="ContentType" />s based on the XML data</param>
// /// <param name="dataTypes">Dynamically generates a list of <see cref="DataType" /> for tests</param>
// /// <returns></returns>
// public static IEnumerable<ContentNodeKit> GetContentNodeKits(
// string xml,
// IShortStringHelper shortStringHelper,
// out ContentType[] contentTypes,
// out DataType[] dataTypes)
// {
// // use the label data type for all data for these tests except in the case
// // where a property is named 'content', in which case use the RTE.
// var serializer = new SystemTextConfigurationEditorJsonSerializer();
// var labelDataType =
// new DataType(new VoidEditor("Label", Mock.Of<IDataValueEditorFactory>()), serializer) { Id = 3 };
// var rteDataType = new DataType(new VoidEditor("RTE", Mock.Of<IDataValueEditorFactory>()), serializer) { Id = 4 };
// dataTypes = new[] { labelDataType, rteDataType };
//
// var kitsAndXml = new List<(ContentNodeKit kit, XElement node)>();
//
// var xDoc = XDocument.Parse(xml);
// var nodes = xDoc.XPathSelectElements("//*[@isDoc]");
// foreach (var node in nodes)
// {
// var id = node.AttributeValue<int>("id");
// var key = node.AttributeValue<Guid?>("key") ?? id.ToGuid();
//
// var propertyElements = node.Elements().Where(x => x.Attribute("id") == null);
// var properties = new Dictionary<string, PropertyData[]>();
// foreach (var propertyElement in propertyElements)
// {
// properties[propertyElement.Name.LocalName] = new[]
// {
// // TODO: builder?
// new PropertyData {Culture = string.Empty, Segment = string.Empty, Value = propertyElement.Value}
// };
// }
//
// var contentData = new ContentDataBuilder()
// .WithName(node.AttributeValue<string>("nodeName"))
// .WithProperties(properties)
// .WithPublished(true)
// .WithTemplateId(node.AttributeValue<int>("template"))
// .WithUrlSegment(node.AttributeValue<string>("urlName"))
// .WithVersionDate(node.AttributeValue<DateTime>("updateDate"))
// .WithWriterId(node.AttributeValue<int>("writerID"))
// .Build();
//
// var kit = ContentNodeKitBuilder.CreateWithContent(
// node.AttributeValue<int>("nodeType"),
// id,
// node.AttributeValue<string>("path"),
// node.AttributeValue<int>("sortOrder"),
// node.AttributeValue<int>("level"),
// node.AttributeValue<int>("parentID"),
// node.AttributeValue<int>("creatorID"),
// key,
// node.AttributeValue<DateTime>("createDate"),
// contentData,
// contentData);
//
// kitsAndXml.Add((kit, node));
// }
//
// // put together the unique content types
// var contentTypesIdToType = new Dictionary<int, ContentType>();
// foreach ((var kit, var node) in kitsAndXml)
// {
// if (!contentTypesIdToType.TryGetValue(kit.ContentTypeId, out var contentType))
// {
// contentType = new ContentType(shortStringHelper, -1)
// {
// Id = kit.ContentTypeId,
// Alias = node.Name.LocalName
// };
// SetContentTypeProperties(shortStringHelper, labelDataType, rteDataType, kit, contentType);
// contentTypesIdToType[kit.ContentTypeId] = contentType;
// }
// else
// {
// // we've already created it but might need to add properties
// SetContentTypeProperties(shortStringHelper, labelDataType, rteDataType, kit, contentType);
// }
// }
//
// contentTypes = contentTypesIdToType.Values.ToArray();
//
// return kitsAndXml.Select(x => x.kit);
// }
//
// private static void SetContentTypeProperties(
// IShortStringHelper shortStringHelper,
// DataType labelDataType,
// DataType rteDataType,
// ContentNodeKit kit,
// ContentType contentType)
// {
// foreach (var property in kit.DraftData.Properties)
// {
// var propertyType = new PropertyType(shortStringHelper, labelDataType, property.Key);
//
// if (!contentType.PropertyTypeExists(propertyType.Alias))
// {
// if (propertyType.Alias == "content")
// {
// propertyType.DataTypeId = rteDataType.Id;
// }
//
// contentType.AddPropertyType(propertyType);
// }
// }
// }
// }