diff --git a/core/modules/workspaces/src/Form/WorkspaceMergeForm.php b/core/modules/workspaces/src/Form/WorkspaceMergeForm.php
index fb1e769594d2474a11b66df7cf9f5163c5927f48..e447abcaf916edd7e0321133694b10e6592cdef6 100644
--- a/core/modules/workspaces/src/Form/WorkspaceMergeForm.php
+++ b/core/modules/workspaces/src/Form/WorkspaceMergeForm.php
@@ -6,7 +6,6 @@
 use Drupal\Core\Entity\EntityTypeManagerInterface;
 use Drupal\Core\Form\ConfirmFormBase;
 use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Routing\RedirectDestinationInterface;
 use Drupal\Core\Url;
 use Drupal\workspaces\WorkspaceInterface;
 use Drupal\workspaces\WorkspaceOperationFactory;
@@ -52,16 +51,10 @@ class WorkspaceMergeForm extends ConfirmFormBase implements WorkspaceFormInterfa
    *   The workspace operation factory service.
    * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
    *   The entity type manager.
-   * @param \Drupal\Core\Routing\RedirectDestinationInterface|null $redirectDestination
-   *   The redirect destination service.
    */
-  public function __construct(WorkspaceOperationFactory $workspace_operation_factory, EntityTypeManagerInterface $entity_type_manager, ?RedirectDestinationInterface $redirectDestination = NULL) {
+  public function __construct(WorkspaceOperationFactory $workspace_operation_factory, EntityTypeManagerInterface $entity_type_manager) {
     $this->workspaceOperationFactory = $workspace_operation_factory;
     $this->entityTypeManager = $entity_type_manager;
-    if ($redirectDestination === NULL) {
-      $this->redirectDestination = \Drupal::service('redirect.destination');
-      @trigger_error('Calling' . __METHOD__ . '() without the $redirectDestination argument is deprecated in drupal:10.1.0 and is required in drupal:11.0.0. See https://www.drupal.org/node/3343983', E_USER_DEPRECATED);
-    }
   }
 
   /**
@@ -70,8 +63,7 @@ public function __construct(WorkspaceOperationFactory $workspace_operation_facto
   public static function create(ContainerInterface $container) {
     return new static(
       $container->get('workspaces.operation_factory'),
-      $container->get('entity_type.manager'),
-      $container->get('redirect.destination')
+      $container->get('entity_type.manager')
     );
   }
 
@@ -144,7 +136,7 @@ public function getDescription() {
    * {@inheritdoc}
    */
   public function getCancelUrl() {
-    return Url::fromRoute('entity.workspace.collection', [], ['query' => $this->redirectDestination->getAsArray()]);
+    return Url::fromRoute('entity.workspace.collection', [], ['query' => $this->getDestinationArray()]);
   }
 
   /**
diff --git a/core/modules/workspaces/src/Form/WorkspacePublishForm.php b/core/modules/workspaces/src/Form/WorkspacePublishForm.php
index 1ec9b90a3118f6291c8daf94889667f5766ae840..6d0b82bd0e880abd164bcab63a5562ffbcfa0ce8 100644
--- a/core/modules/workspaces/src/Form/WorkspacePublishForm.php
+++ b/core/modules/workspaces/src/Form/WorkspacePublishForm.php
@@ -6,7 +6,6 @@
 use Drupal\Core\Entity\EntityTypeManagerInterface;
 use Drupal\Core\Form\ConfirmFormBase;
 use Drupal\Core\Form\FormStateInterface;
-use Drupal\Core\Routing\RedirectDestinationInterface;
 use Drupal\Core\Url;
 use Drupal\workspaces\WorkspaceAccessException;
 use Drupal\workspaces\WorkspaceInterface;
@@ -46,16 +45,10 @@ class WorkspacePublishForm extends ConfirmFormBase implements WorkspaceFormInter
    *   The workspace operation factory service.
    * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
    *   The entity type manager.
-   * @param \Drupal\Core\Routing\RedirectDestinationInterface|null $redirectDestination
-   *   The redirect destination service.
    */
-  public function __construct(WorkspaceOperationFactory $workspace_operation_factory, EntityTypeManagerInterface $entity_type_manager, ?RedirectDestinationInterface $redirectDestination = NULL) {
+  public function __construct(WorkspaceOperationFactory $workspace_operation_factory, EntityTypeManagerInterface $entity_type_manager) {
     $this->workspaceOperationFactory = $workspace_operation_factory;
     $this->entityTypeManager = $entity_type_manager;
-    if ($redirectDestination === NULL) {
-      $this->redirectDestination = \Drupal::service('redirect.destination');
-      @trigger_error('Calling' . __METHOD__ . '() without the $redirectDestination argument is deprecated in drupal:10.1.0 and is required in drupal:11.0.0. See https://www.drupal.org/node/3343983', E_USER_DEPRECATED);
-    }
   }
 
   /**
@@ -64,8 +57,7 @@ public function __construct(WorkspaceOperationFactory $workspace_operation_facto
   public static function create(ContainerInterface $container) {
     return new static(
       $container->get('workspaces.operation_factory'),
-      $container->get('entity_type.manager'),
-      $container->get('redirect.destination')
+      $container->get('entity_type.manager')
     );
   }
 
@@ -141,7 +133,7 @@ public function getDescription() {
    * {@inheritdoc}
    */
   public function getCancelUrl() {
-    return Url::fromRoute('entity.workspace.collection', [], ['query' => $this->redirectDestination->getAsArray()]);
+    return Url::fromRoute('entity.workspace.collection', [], ['query' => $this->getDestinationArray()]);
   }
 
   /**
diff --git a/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php b/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php
index 3f90caca371e93719cd565ce07107d892469b043..65e800c83de661e8780062a1b4e417bc26bb5290 100644
--- a/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php
+++ b/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php
@@ -305,4 +305,36 @@ public function testWorkspaceList() {
     $assert_session->linkExists('Switch to Live');
   }
 
+  /**
+   * Verifies that a workspace can be published.
+   */
+  public function testPublishWorkspace() {
+    $this->createContentType(['type' => 'test', 'label' => 'Test']);
+    $this->drupalLogin($this->rootUser);
+
+    $this->drupalGet('/admin/config/workflow/workspaces/add');
+    $this->submitForm([
+      'id' => 'test_workspace',
+      'label' => 'Test workspace',
+    ], 'Save');
+
+    // Activate the test workspace.
+    $this->drupalGet('/admin/config/workflow/workspaces/manage/test_workspace/activate');
+    $this->submitForm([], 'Confirm');
+
+    $this->drupalGet('/admin/config/workflow/workspaces/manage/test_workspace/publish');
+    $this->assertSession()->statusCodeEquals(200);
+    $this->assertSession()->pageTextContains('There are no changes that can be published from Test workspace to Live.');
+
+    // Create a node in the workspace.
+    $node = $this->createNodeThroughUi('Test node', 'test');
+
+    $this->drupalGet('/admin/config/workflow/workspaces/manage/test_workspace/publish');
+    $this->assertSession()->statusCodeEquals(200);
+    $this->assertSession()->pageTextContains('There is 1 item that can be published from Test workspace to Live');
+
+    $this->getSession()->getPage()->pressButton('Publish 1 item to Live');
+    $this->assertSession()->pageTextContains('Successful publication.');
+  }
+
 }