Issue #2497115 by melvinlouwerse: ajax_page_state is not taken into account for normal GET requests

8.0.x
effulgentsia 2015-10-03 22:27:28 -07:00
parent 35fa967664
commit 0dd08e66e3
2 changed files with 116 additions and 2 deletions

View File

@ -277,8 +277,7 @@ class HtmlResponseAttachmentsProcessor implements AttachmentsResponseProcessorIn
// Take Ajax page state into account, to allow for something like Turbolinks
// to be implemented without altering core.
// @see https://github.com/rails/turbolinks/
// @todo https://www.drupal.org/node/2497115 - Below line is broken due to ->request.
$ajax_page_state = $this->requestStack->getCurrentRequest()->request->get('ajax_page_state');
$ajax_page_state = $this->requestStack->getCurrentRequest()->get('ajax_page_state');
$assets->setAlreadyLoadedLibraries(isset($ajax_page_state) ? explode(',', $ajax_page_state['libraries']) : []);
$variables = [];

View File

@ -0,0 +1,115 @@
<?php
/**
* @file
* Contains \Drupal\system\Tests\Render\AjaxPageStateTest.
*/
namespace Drupal\system\Tests\Render;
use Drupal\simpletest\AssertContentTrait;
use Drupal\simpletest\WebTestBase;
/**
* Performs tests for the effects of the ajax_page_state query parameter.
*
* @group Render
*/
class AjaxPageStateTest extends WebTestBase {
use AssertContentTrait;
/**
* User account with all available permissions
*
* @var \Drupal\Core\Session\AccountInterface
*/
protected $adminUser;
protected function setUp() {
parent::setUp();
// Create an administrator with all permissions.
$this->adminUser = $this->drupalCreateUser(array_keys(\Drupal::service('user.permissions')
->getPermissions()));
// Login so there are more libraries to test with otherwise only html5shiv
// is the only one in the source we can easily test for.
$this->drupalLogin($this->adminUser);
}
/**
* Default functionality without the param ajax_page_state[libraries].
*
* The libraries html5shiv and drupalSettings are loaded default from core
* and available in code as scripts. Do this as the base test.
*/
public function testLibrariesAvailable() {
$this->drupalGet('node', array());
$this->assertRaw(
'/core/assets/vendor/html5shiv/html5shiv.min.js',
'The html5shiv library from core should be loaded.'
);
$this->assertRaw(
'/core/misc/drupalSettingsLoader.js',
'The Dupalsettings library from core should be loaded.'
);
}
/**
* Give ajax_page_state[libraries]=core/html5shiv to exclude the library.
*
* When called with ajax_page_state[libraries]=core/html5shiv the library
* should be excluded as it is already loaded. This should not affect other
* libraries so test if drupalSettings is still available.
*
*/
public function testHtml5ShivIsNotLoaded() {
$this->drupalGet('node',
array(
"query" =>
array(
'ajax_page_state' => array(
'libraries' => 'core/html5shiv'
)
)
)
);
$this->assertNoRaw(
'/core/assets/vendor/html5shiv/html5shiv.min.js',
'The html5shiv library from core should be excluded from loading'
);
$this->assertRaw(
'/core/misc/drupalSettingsLoader.js',
'The Dupalsettings library from core should be loaded.'
);
}
/**
* Test if multiple libaries can be excluded.
*
* ajax_page_state[libraries] should be able to support multiple libraries
* comma separated.
*
*/
public function testMultipleLibrariesAreNotLoaded() {
$this->drupalGet('node',
array(
"query" =>
array(
'ajax_page_state' => array(
'libraries' => 'core/html5shiv,core/drupalSettings'
)
)
)
);
$this->assertNoRaw(
'/core/assets/vendor/html5shiv/html5shiv.min.js',
'The html5shiv library from core should be excluded from loading.'
);
$this->assertNoRaw(
'/core/misc/drupalSettingsLoader.js',
'The Dupalsettings library from core should be excluded from loading.'
);
}
}