Issue #2497115 by melvinlouwerse: ajax_page_state is not taken into account for normal GET requests
parent
35fa967664
commit
0dd08e66e3
|
@ -277,8 +277,7 @@ class HtmlResponseAttachmentsProcessor implements AttachmentsResponseProcessorIn
|
||||||
// Take Ajax page state into account, to allow for something like Turbolinks
|
// Take Ajax page state into account, to allow for something like Turbolinks
|
||||||
// to be implemented without altering core.
|
// to be implemented without altering core.
|
||||||
// @see https://github.com/rails/turbolinks/
|
// @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()->get('ajax_page_state');
|
||||||
$ajax_page_state = $this->requestStack->getCurrentRequest()->request->get('ajax_page_state');
|
|
||||||
$assets->setAlreadyLoadedLibraries(isset($ajax_page_state) ? explode(',', $ajax_page_state['libraries']) : []);
|
$assets->setAlreadyLoadedLibraries(isset($ajax_page_state) ? explode(',', $ajax_page_state['libraries']) : []);
|
||||||
|
|
||||||
$variables = [];
|
$variables = [];
|
||||||
|
|
|
@ -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.'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue