Skip to content
Snippets Groups Projects
Verified Commit cdd8b052 authored by Alex Pott's avatar Alex Pott
Browse files

Issue #3083106 by mfb, dogamboar, alexpott, smustgrave: Method...

Issue #3083106 by mfb, dogamboar, alexpott, smustgrave: Method _batch_current_set is called without include core/includes/batch.inc
parent 8759754d
No related branches found
No related tags found
28 merge requests!54479.5.x SF update,!5014Issue #3071143: Table Render Array Example Is Incorrect,!4868Issue #1428520: Improve menu parent link selection,!4289Issue #1344552 by marcingy, Niklas Fiekas, Ravi.J, aleevas, Eduardo Morales...,!4114Issue #2707291: Disable body-level scrolling when a dialog is open as a modal,!4100Issue #3249600: Add support for PHP 8.1 Enums as allowed values for list_* data types,!3630Issue #2815301 by Chi, DanielVeza, kostyashupenko, smustgrave: Allow to create...,!3600Issue #3344629: Passing null to parameter #1 ($haystack) of type string is deprecated,!2378Issue #2875033: Optimize joins and table selection in SQL entity query implementation,!2334Issue #3228209: Add hasRole() method to AccountInterface,!2062Issue #3246454: Add weekly granularity to views date sort,!1591Issue #3199697: Add JSON:API Translation experimental module,!1484Exposed filters get values from URL when Ajax is on,!1255Issue #3238922: Refactor (if feasible) uses of the jQuery serialize function to use vanillaJS,!1162Issue #3100350: Unable to save '/' root path alias,!1105Issue #3025039: New non translatable field on translatable content throws error,!1073issue #3191727: Focus states on mobile second level navigation items fixed,!10223132456: Fix issue where views instances are emptied before an ajax request is complete,!925Issue #2339235: Remove taxonomy hard dependency on node module,!877Issue #2708101: Default value for link text is not saved,!872Draft: Issue #3221319: Race condition when creating menu links and editing content deletes menu links,!844Resolve #3036010 "Updaters",!617Issue #3043725: Provide a Entity Handler for user cancelation,!579Issue #2230909: Simple decimals fail to pass validation,!560Move callback classRemove outside of the loop,!555Issue #3202493,!485Sets the autocomplete attribute for username/password input field on login form.,!30Issue #3182188: Updates composer usage to point at ./vendor/bin/composer
......@@ -2,6 +2,7 @@
namespace Drupal\system\Controller;
use Drupal\Core\Batch\BatchStorageInterface;
use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpFoundation\Request;
......@@ -13,21 +14,14 @@
*/
class BatchController implements ContainerInjectionInterface {
/**
* The app root.
*
* @var string
*/
protected $root;
/**
* Constructs a new BatchController.
*
* @param string $root
* The app root.
*/
public function __construct($root) {
$this->root = $root;
public function __construct(
protected string $root,
protected BatchStorageInterface $batchStorage
) {
require_once $this->root . '/core/includes/batch.inc';
}
/**
......@@ -35,7 +29,8 @@ public function __construct($root) {
*/
public static function create(ContainerInterface $container) {
return new static(
$container->getParameter('app.root')
$container->getParameter('app.root'),
$container->get('batch.storage'),
);
}
......@@ -51,7 +46,6 @@ public static function create(ContainerInterface $container) {
* @throws \Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException
*/
public function batchPage(Request $request) {
require_once $this->root . '/core/includes/batch.inc';
$output = _batch_page($request);
if ($output === FALSE) {
......@@ -87,7 +81,22 @@ public function batchPage(Request $request) {
* @return string
* The page title.
*/
public function batchPageTitle() {
public function batchPageTitle(Request $request) {
$batch = &batch_get();
if (!($request_id = $request->query->get('id'))) {
return '';
}
// Retrieve the current state of the batch.
if (!$batch) {
$batch = $this->batchStorage->load($request_id);
}
if (!$batch) {
return '';
}
$current_set = _batch_current_set();
return !empty($current_set['title']) ? $current_set['title'] : '';
}
......
<?php
namespace Drupal\Tests\system\Unit\Batch;
use Drupal\Core\Batch\BatchStorageInterface;
use Drupal\system\Controller\BatchController;
use Drupal\Tests\UnitTestCase;
use Symfony\Component\HttpFoundation\Request;
/**
* Tests for the batch controller class.
*
* @coversDefaultClass \Drupal\system\Controller\BatchController
* @runTestsInSeparateProcesses
* @group system
*/
class BatchControllerTest extends UnitTestCase {
/**
* Tests title callback.
*
* @covers ::batchPageTitle
*/
public function testBatchPageTitle() {
$batch_storage = $this->createMock(BatchStorageInterface::class);
$controller = new BatchController($this->root, $batch_storage);
require_once $this->root . '/core/includes/form.inc';
$this->assertSame('', $controller->batchPageTitle(new Request()));
// Test no batch loaded from storage and batch loaded from storage cases.
$batch = ['sets' => [['title' => 'foobar']], 'current_set' => 0];
$batch_storage->method('load')->will($this->onConsecutiveCalls(FALSE, $batch));
$this->assertSame('', $controller->batchPageTitle(new Request(['id' => 1234])));
$this->assertSame('foobar', $controller->batchPageTitle(new Request(['id' => 1234])));
// Test batch returned by &batch_get() call.
$batch = &batch_get();
$batch['sets']['0']['title'] = 'Updated title';
$this->assertSame('Updated title', $controller->batchPageTitle(new Request(['id' => 1234])));
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment