V14 QA added navigation integration tests (#16973)
* Tests * Remove props and use local vars * Adding preliminary navigation service and content implementation * Adding preliminary unit tests * Change from async methods * Refactor GetParentKey to TryGetParentKey * Refactor GetChildrenKeys to TryGetChildrenKeys * Refactor GetDescendantsKeys to TryGetDescendantsKeys * Refactor GetAncestorsKeys to TryGetAncestorsKeys * Refactor GetSiblingsKeys to TryGetSiblingsKeys * Refactor TryGetChildrenKeys * Initial integration tests * Use ContentEditingService instead of ContentService * Remove INavigationService.Copy implementation and unit tests * Rename var * Adding clarification * Initial ContentNavigationRepository * Initial NavigationFactory * Remove filtering from factory * NavigationRepository and implementation * InitializationService responsible for seeding the in-memory structure * Register repository and service * Adding NavigationDto and NavigationNode * Adding INavigationService dependency and Enlist updating navigation structure actions * Documentation * Adding tests for removing descendants as well * Changed to ConcurrentDictionary * Remove keys comments for tests * Adding documentation * Forgotten ConcurrentDictionary change * Isolating the operations on the model * Splitting the INavigationService to separate the querying from the managing functionality * Introducing specific navigation services for document, document recycle bin, media and media recycle bin * Making ContentNavigationService into a base as the functionality will be shared between the document, document recycle bin, media and media recycle bin services * Adding the implementations of document, document recycle bin, media and media recycle bin navigation services * Fixing comments * Initializing all 4 collections * Adapting the navigation unit tests to the base now * Adapting integration tests to specific navigation service * Adding test for rebuilding the structure * Adding implementation for Adding and Getting a node - needed for moving to and restoring from the recycle bin + tests * Updating the document navigation structure from the ContentService * Fix typo * Adding trashed items implementation in base - currently managing 2 structures * Removing no longer relevant GetNavigationNode and AddNavigationNode * Fix removing parent when child is removed supporting methods * Added restoring functionality * Adding Bin functionality to DocumentNavigationService * Removing Move signature from IDocumentNavigationService * Adding RecycleBin query and management services * Re-adding Move and removing GetNavigationNode and AddNavigationNode signatures from interface * Rebuilding bin structure using _documentNavigationService, instead of _documentRecycleBinNavigationService * Fixing test name * Adding more tests for remove * Adding tests for restore and removing ones for GetNavigationNode and AddNavigationNode * Remove comments * Removing document and media RecycleBinNavigationService and their interfaces * Adding media rebuild bin * Fixing initialization with correct interfaces * Removing RecycleBinNavigationServices' registration * Remove IDocumentRecycleBinNavigationService dependency * Updating in-memory nav structure when content updates happen * Adding the rest of the integration tests * Clean up IMediaNavigationService * Fix comments * Remove CustomTestSetup in integration tests as the structure is updated when content updates happen * Adding and fixing comments * Making RebuildBinAsync abstract as well * Adding DocumentNavigationServiceTestsBase * Splitting DocumentNavigationServiceTests into partial test classes * Cleaning up DocumentNavigationServiceTests since tests have been moved to specific partial classes * Reuse a method for creating content in tests * Change type in test base * Adding navigation structure updates in media service * Adding MediaNavigationServiceTestsBase * Adding integration tests for media nav str * Remove services as we will have more concrete ones * Add document and media IXNavigationQueryService and IXNavigationManagementService * Inject ManagementService in ContentService.cs and MediaService.cs * Change implementation to implement the new services + registration * Make classes sealed * Inject correct services in InitializationService * Using the right services in integration tests * Adding comments * Removing bin interfaces from main navigation ones * Rename Remove to MoveToBin * Added tests for Copy * Added additional tests * Split test * Added Media tests * Updated and added content tests * Cleaned up naming * Cleaned up * Rename initialization service to initialization hosted service * Refactor repository to return a collection * Add interface for the NavigationDto * Add constants to bind property names between DTOs * Move factory and fix input type * Use constants for column names * Use factory from base * Fixed indentation * Fix bug when rebuilding the recycle bin structure * Fix comments * Fix merged in code * Fix bug again after merge * Minor things --------- Co-authored-by: Elitsa <elm@umbraco.dk> Co-authored-by: Bjarke Berg <mail@bergmania.dk>
This commit is contained in:
@@ -7,12 +7,17 @@ public partial class DocumentNavigationServiceTests
|
||||
{
|
||||
[Test]
|
||||
[TestCase("E856AC03-C23E-4F63-9AA9-681B42A58573", "60E0E5C4-084E-4144-A560-7393BEAD2E96")] // Grandchild 1 to Child 2
|
||||
[TestCase("B606E3FF-E070-4D46-8CB9-D31352029FDF", null)] // Child 3 to content root
|
||||
[TestCase("60E0E5C4-084E-4144-A560-7393BEAD2E96", "C6173927-0C59-4778-825D-D7B9F45D8DDE")] // Child 2 to Child 1
|
||||
public async Task Structure_Updates_When_Moving_Content(Guid nodeToMove, Guid? targetParentKey)
|
||||
public async Task Structure_Updates_When_Moving_Content(Guid nodeToMove, Guid targetParentKey)
|
||||
{
|
||||
// Arrange
|
||||
DocumentNavigationQueryService.TryGetParentKey(nodeToMove, out Guid? originalParentKey);
|
||||
DocumentNavigationQueryService.TryGetDescendantsKeys(nodeToMove, out IEnumerable<Guid> initialDescendantsKeys);
|
||||
var beforeMoveDescendants = initialDescendantsKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetChildrenKeys(originalParentKey.Value, out IEnumerable<Guid> beforeMoveInitialParentChildrenKeys);
|
||||
var beforeMoveInitialParentChildren = beforeMoveInitialParentChildrenKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetChildrenKeys(targetParentKey, out IEnumerable<Guid> beforeMoveTargetParentChildrenKeys);
|
||||
var beforeMoveTargetParentChildren = beforeMoveTargetParentChildrenKeys.ToList();
|
||||
|
||||
// Act
|
||||
var moveAttempt = await ContentEditingService.MoveAsync(nodeToMove, targetParentKey, Constants.Security.SuperUserKey);
|
||||
@@ -21,19 +26,72 @@ public partial class DocumentNavigationServiceTests
|
||||
DocumentNavigationQueryService.TryGetParentKey(moveAttempt.Result!.Key, out Guid? updatedParentKey);
|
||||
|
||||
// Assert
|
||||
DocumentNavigationQueryService.TryGetDescendantsKeys(nodeToMove, out IEnumerable<Guid> afterMoveDescendantsKeys);
|
||||
var afterMoveDescendants = afterMoveDescendantsKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetChildrenKeys(originalParentKey.Value, out IEnumerable<Guid> afterMoveInitialParentChildrenKeys);
|
||||
var afterMoveInitialParentChildren = afterMoveInitialParentChildrenKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetChildrenKeys(targetParentKey, out IEnumerable<Guid> afterMoveTargetParentChildrenKeys);
|
||||
var afterMoveTargetParentChildren = afterMoveTargetParentChildrenKeys.ToList();
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
if (targetParentKey is null)
|
||||
{
|
||||
Assert.IsNull(updatedParentKey);
|
||||
}
|
||||
else
|
||||
{
|
||||
Assert.IsNotNull(updatedParentKey);
|
||||
}
|
||||
|
||||
Assert.IsNotNull(updatedParentKey);
|
||||
Assert.AreNotEqual(originalParentKey, updatedParentKey);
|
||||
Assert.AreEqual(targetParentKey, updatedParentKey);
|
||||
|
||||
// Verifies that the parent's children have been updated
|
||||
Assert.AreEqual(beforeMoveInitialParentChildren.Count - 1, afterMoveInitialParentChildren.Count);
|
||||
Assert.AreEqual(beforeMoveTargetParentChildren.Count + 1, afterMoveTargetParentChildren.Count);
|
||||
|
||||
// Verifies that the descendants are the same before and after the move
|
||||
Assert.AreEqual(beforeMoveDescendants.Count, afterMoveDescendants.Count);
|
||||
Assert.AreEqual(beforeMoveDescendants, afterMoveDescendants);
|
||||
});
|
||||
}
|
||||
|
||||
[Test]
|
||||
public async Task Structure_Updates_When_Moving_Content_To_Root()
|
||||
{
|
||||
// Arrange
|
||||
Guid nodeToMove = Child3.Key;
|
||||
Guid? targetParentKey = Constants.System.RootKey; // Root
|
||||
DocumentNavigationQueryService.TryGetParentKey(nodeToMove, out Guid? originalParentKey);
|
||||
DocumentNavigationQueryService.TryGetDescendantsKeys(nodeToMove, out IEnumerable<Guid> initialDescendantsKeys);
|
||||
var beforeMoveDescendants = initialDescendantsKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetDescendantsKeys(originalParentKey.Value, out IEnumerable<Guid> beforeMoveInitialParentDescendantsKeys);
|
||||
var beforeMoveInitialParentDescendants = beforeMoveInitialParentDescendantsKeys.ToList();
|
||||
|
||||
// The Root node is the only node at the root
|
||||
DocumentNavigationQueryService.TryGetSiblingsKeys(Root.Key, out IEnumerable<Guid> beforeMoveSiblingsKeys);
|
||||
var beforeMoveRootSiblings = beforeMoveSiblingsKeys.ToList();
|
||||
|
||||
// Act
|
||||
var moveAttempt = await ContentEditingService.MoveAsync(nodeToMove, targetParentKey, Constants.Security.SuperUserKey);
|
||||
|
||||
// Verify the node's new parent is updated
|
||||
DocumentNavigationQueryService.TryGetParentKey(moveAttempt.Result!.Key, out Guid? updatedParentKey);
|
||||
|
||||
// Assert
|
||||
DocumentNavigationQueryService.TryGetDescendantsKeys(nodeToMove, out IEnumerable<Guid> afterMoveDescendantsKeys);
|
||||
var afterMoveDescendants = afterMoveDescendantsKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetDescendantsKeys((Guid)originalParentKey, out IEnumerable<Guid> afterMoveInitialParentDescendantsKeys);
|
||||
var afterMoveInitialParentDescendants = afterMoveInitialParentDescendantsKeys.ToList();
|
||||
DocumentNavigationQueryService.TryGetSiblingsKeys(Root.Key, out IEnumerable<Guid> afterMoveSiblingsKeys);
|
||||
var afterMoveRootSiblings = afterMoveSiblingsKeys.ToList();
|
||||
|
||||
Assert.Multiple(() =>
|
||||
{
|
||||
Assert.IsNull(updatedParentKey);
|
||||
Assert.AreNotEqual(originalParentKey, updatedParentKey);
|
||||
Assert.AreEqual(targetParentKey, updatedParentKey);
|
||||
|
||||
// Verifies that the parent's children have been updated
|
||||
Assert.AreEqual(beforeMoveInitialParentDescendants.Count - (afterMoveDescendants.Count + 1), afterMoveInitialParentDescendants.Count);
|
||||
Assert.AreEqual(beforeMoveRootSiblings.Count + 1, afterMoveRootSiblings.Count);
|
||||
|
||||
// Verifies that the descendants are the same before and after the move
|
||||
Assert.AreEqual(beforeMoveDescendants.Count, afterMoveDescendants.Count);
|
||||
Assert.AreEqual(beforeMoveDescendants, afterMoveDescendants);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user