From 2b536b6c970efa932298c72a9b07b3f852418d28 Mon Sep 17 00:00:00 2001
From: catch <6915-catch@users.noreply.drupalcode.org>
Date: Thu, 19 Sep 2024 12:08:17 +0100
Subject: [PATCH] Revert "Issue #3438769 by vinmayiswamy, antonnavi, michelle,
 amateescu: Sub workspace does not clear"

This reverts commit c1f7b85decd7b1281b00d891c72963551b57d622.
---
 .../workspaces/src/WorkspaceAssociation.php   | 12 ------
 .../src/Kernel/WorkspaceAssociationTest.php   | 37 -------------------
 2 files changed, 49 deletions(-)

diff --git a/core/modules/workspaces/src/WorkspaceAssociation.php b/core/modules/workspaces/src/WorkspaceAssociation.php
index 579aee87699c..02d6924c4e4b 100644
--- a/core/modules/workspaces/src/WorkspaceAssociation.php
+++ b/core/modules/workspaces/src/WorkspaceAssociation.php
@@ -392,18 +392,6 @@ public static function getSubscribedEvents(): array {
    */
   public function onPostPublish(WorkspacePublishEvent $event): void {
     $this->deleteAssociations($event->getWorkspace()->id());
-
-    // Cleanup sub-workspaces on deploy to Live (no parent) workspace.
-    if (!$event->getWorkspace()->hasParent()) {
-      foreach ($event->getPublishedRevisionIds() as $target_entity_type_id => $target_entity_ids) {
-        // Extract target entity IDs and revision IDs.
-        $target_entity_ids_list = array_keys($target_entity_ids);
-        $target_entity_revision_ids = array_keys($target_entity_ids);
-
-        $this->deleteAssociations(NULL, $target_entity_type_id, $target_entity_ids_list, $target_entity_revision_ids);
-      }
-    }
-
   }
 
 }
diff --git a/core/modules/workspaces/tests/src/Kernel/WorkspaceAssociationTest.php b/core/modules/workspaces/tests/src/Kernel/WorkspaceAssociationTest.php
index 7dae5f4c3375..4d7e8d80e628 100644
--- a/core/modules/workspaces/tests/src/Kernel/WorkspaceAssociationTest.php
+++ b/core/modules/workspaces/tests/src/Kernel/WorkspaceAssociationTest.php
@@ -158,43 +158,6 @@ public function testWorkspaceAssociation(): void {
     $this->assertWorkspaceAssociations('node', $expected_latest_revisions, $expected_all_revisions, $expected_initial_revisions);
   }
 
-  /**
-   * Tests cleanup of sub-workspaces on publishing to Live.
-   */
-  public function testSubWorkspaceCleanupOnPublishToLive(): void {
-    $workspaceName = 'stage';
-    $this->switchToWorkspace($workspaceName);
-
-    // Create and save a node in the 'stage' workspace.
-    $node = $this->createNode([
-      'title' => 'Test article - stage - unpublished',
-      'type' => 'article',
-      'status' => 0,
-    ]);
-    $node->save();
-
-    // Simulate the publishing operation.
-    $node->set('status', 1);
-    $node->save();
-
-    // Manually perform cleanup if no service is available.
-    $database = \Drupal::database();
-    $database->delete('workspace_association')
-      ->condition('workspace', $workspaceName)
-      ->execute();
-
-    // Query database to ensure that the workspace associations were cleaned up.
-    $queryAfter = $database->select('workspace_association', 'wa')
-      ->fields('wa')
-      ->condition('workspace', $workspaceName)
-      ->execute();
-    $resultsAfter = $queryAfter->fetchAll();
-
-    // Assert that the workspace association table is empty for
-    // the 'stage' workspace.
-    $this->assertEmpty($resultsAfter, 'Workspace associations were not cleaned up properly for the stage workspace.');
-  }
-
   /**
    * Checks the workspace associations for a test scenario.
    *
-- 
GitLab