Issue #3426624 by plopesc, smustgrave: Shortcuts Block does not include the necessary cache tags
parent
4229a611e5
commit
6ef8c1e269
|
@ -23,7 +23,12 @@ class ShortcutsBlock extends BlockBase {
|
||||||
*/
|
*/
|
||||||
public function build() {
|
public function build() {
|
||||||
return [
|
return [
|
||||||
shortcut_renderable_links(shortcut_current_displayed_set()),
|
'#lazy_builder' => ['shortcut.lazy_builders:lazyLinks', [FALSE]],
|
||||||
|
'#create_placeholder' => TRUE,
|
||||||
|
'#cache' => [
|
||||||
|
'keys' => ['shortcut_set_block_links'],
|
||||||
|
'contexts' => ['user'],
|
||||||
|
],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,16 +38,19 @@ class ShortcutLazyBuilders implements TrustedCallbackInterface {
|
||||||
/**
|
/**
|
||||||
* #lazy_builder callback; builds shortcut toolbar links.
|
* #lazy_builder callback; builds shortcut toolbar links.
|
||||||
*
|
*
|
||||||
|
* @param bool $show_configure_link
|
||||||
|
* Boolean to indicate whether to include the configure link or not.
|
||||||
|
*
|
||||||
* @return array
|
* @return array
|
||||||
* A renderable array of shortcut links.
|
* A renderable array of shortcut links.
|
||||||
*/
|
*/
|
||||||
public function lazyLinks() {
|
public function lazyLinks(bool $show_configure_link = TRUE) {
|
||||||
$shortcut_set = shortcut_current_displayed_set();
|
$shortcut_set = shortcut_current_displayed_set();
|
||||||
|
|
||||||
$links = shortcut_renderable_links();
|
$links = shortcut_renderable_links();
|
||||||
|
|
||||||
$configure_link = NULL;
|
$configure_link = NULL;
|
||||||
if (shortcut_set_edit_access($shortcut_set)->isAllowed()) {
|
if ($show_configure_link && shortcut_set_edit_access($shortcut_set)->isAllowed()) {
|
||||||
$configure_link = [
|
$configure_link = [
|
||||||
'#type' => 'link',
|
'#type' => 'link',
|
||||||
'#title' => t('Edit shortcuts'),
|
'#title' => t('Edit shortcuts'),
|
||||||
|
|
|
@ -205,4 +205,124 @@ class ShortcutCacheTagsTest extends EntityCacheTagsTestBase {
|
||||||
$this->assertSession()->linkNotExists('Alpaca');
|
$this->assertSession()->linkNotExists('Alpaca');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests visibility and cacheability of shortcuts in the block.
|
||||||
|
*/
|
||||||
|
public function testBlock(): void {
|
||||||
|
$this->drupalPlaceBlock('page_title_block', ['id' => 'title']);
|
||||||
|
$this->drupalPlaceBlock('shortcuts', [
|
||||||
|
'id' => 'shortcuts',
|
||||||
|
'label' => 'Shortcuts Block',
|
||||||
|
]);
|
||||||
|
|
||||||
|
$test_page_url = Url::fromRoute('test_page_test.test_page');
|
||||||
|
$this->verifyPageCache($test_page_url, 'MISS');
|
||||||
|
$this->verifyPageCache($test_page_url, 'HIT');
|
||||||
|
|
||||||
|
// Ensure that without enabling the shortcuts-in-page-title-link feature
|
||||||
|
// in the theme, the shortcut_list cache tag is not added to the page.
|
||||||
|
$this->drupalLogin($this->rootUser);
|
||||||
|
$this->drupalGet('admin/config/system/cron');
|
||||||
|
$expected_cache_tags = [
|
||||||
|
'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form',
|
||||||
|
'block_view',
|
||||||
|
'config:block.block.shortcuts',
|
||||||
|
'config:block.block.title',
|
||||||
|
'config:block_list',
|
||||||
|
'config:shortcut.set.default',
|
||||||
|
'config:system.menu.admin',
|
||||||
|
'config:system.theme',
|
||||||
|
'rendered',
|
||||||
|
];
|
||||||
|
$this->assertCacheTags($expected_cache_tags);
|
||||||
|
|
||||||
|
\Drupal::configFactory()
|
||||||
|
->getEditable('stark.settings')
|
||||||
|
->set('third_party_settings.shortcut.module_link', TRUE)
|
||||||
|
->save(TRUE);
|
||||||
|
|
||||||
|
// Add cron to the default shortcut set, now the shortcut list cache tag
|
||||||
|
// is expected.
|
||||||
|
$this->drupalGet('admin/config/system/cron');
|
||||||
|
$this->clickLink('Add to Default shortcuts');
|
||||||
|
$expected_cache_tags[] = 'config:shortcut_set_list';
|
||||||
|
$this->assertCacheTags($expected_cache_tags);
|
||||||
|
|
||||||
|
// Verify that users without the 'access shortcuts' permission can't see the
|
||||||
|
// shortcuts.
|
||||||
|
$this->drupalLogin($this->drupalCreateUser());
|
||||||
|
$this->assertSession()->pageTextNotContains('Shortcuts Block');
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'MISS');
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
|
||||||
|
// Verify that users without the 'administer site configuration' permission
|
||||||
|
// can't see the cron shortcut but can see the block.
|
||||||
|
$this->drupalLogin($this->drupalCreateUser([
|
||||||
|
'access shortcuts',
|
||||||
|
]));
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'MISS');
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
$this->assertSession()->pageTextContains('Shortcuts Block');
|
||||||
|
$this->assertSession()->linkNotExists('Cron');
|
||||||
|
|
||||||
|
// Create a role with access to shortcuts as well as the necessary
|
||||||
|
// permissions to see specific shortcuts.
|
||||||
|
$site_configuration_role = $this->drupalCreateRole([
|
||||||
|
'access shortcuts',
|
||||||
|
'administer site configuration',
|
||||||
|
'access administration pages',
|
||||||
|
]);
|
||||||
|
|
||||||
|
// Create two different users with the same role to assert that the second
|
||||||
|
// user has a cache hit despite the user cache context, as
|
||||||
|
// the returned cache contexts include those from lazy-builder content.
|
||||||
|
$site_configuration_user1 = $this->drupalCreateUser();
|
||||||
|
$site_configuration_user1->addRole($site_configuration_role);
|
||||||
|
$site_configuration_user1->save();
|
||||||
|
$site_configuration_user2 = $this->drupalCreateUser();
|
||||||
|
$site_configuration_user2->addRole($site_configuration_role);
|
||||||
|
$site_configuration_user2->save();
|
||||||
|
|
||||||
|
$this->drupalLogin($site_configuration_user1);
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'MISS');
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
$this->assertCacheContexts(['user', 'url.query_args:_wrapper_format']);
|
||||||
|
$this->assertSession()->pageTextContains('Shortcuts Block');
|
||||||
|
$this->assertSession()->linkExists('Cron');
|
||||||
|
|
||||||
|
$this->drupalLogin($site_configuration_user2);
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
$this->assertCacheContexts(['user', 'url.query_args:_wrapper_format']);
|
||||||
|
$this->assertSession()->pageTextContains('Shortcuts Block');
|
||||||
|
$this->assertSession()->linkExists('Cron');
|
||||||
|
|
||||||
|
// Add another shortcut.
|
||||||
|
$shortcut = Shortcut::create([
|
||||||
|
'shortcut_set' => 'default',
|
||||||
|
'title' => 'Llama',
|
||||||
|
'weight' => 0,
|
||||||
|
'link' => [['uri' => 'internal:/admin/config']],
|
||||||
|
]);
|
||||||
|
$shortcut->save();
|
||||||
|
|
||||||
|
// The shortcuts are displayed in a lazy builder, so the page is still a
|
||||||
|
// cache HIT but shows the new shortcut immediately.
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
$this->assertSession()->linkExists('Cron');
|
||||||
|
$this->assertSession()->linkExists('Llama');
|
||||||
|
|
||||||
|
// Update the shortcut title and assert that it is updated.
|
||||||
|
$shortcut->set('title', 'Alpaca');
|
||||||
|
$shortcut->save();
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
$this->assertSession()->linkExists('Cron');
|
||||||
|
$this->assertSession()->linkExists('Alpaca');
|
||||||
|
|
||||||
|
// Delete the shortcut and assert that the link is gone.
|
||||||
|
$shortcut->delete();
|
||||||
|
$this->verifyDynamicPageCache($test_page_url, 'HIT');
|
||||||
|
$this->assertSession()->linkExists('Cron');
|
||||||
|
$this->assertSession()->linkNotExists('Alpaca');
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue