You are here

QuickEditIntegrationTest.php in Drupal 8

File

core/modules/settings_tray/tests/src/FunctionalJavascript/QuickEditIntegrationTest.php
View source
<?php

namespace Drupal\Tests\settings_tray\FunctionalJavascript;

use Drupal\block_content\Entity\BlockContent;
use Drupal\block_content\Entity\BlockContentType;
use Drupal\user\Entity\Role;

/**
 * Test Settings Tray and Quick Edit modules integration.
 *
 * @group settings_tray
 */
class QuickEditIntegrationTest extends SettingsTrayTestBase {

  /**
   * {@inheritdoc}
   */
  public static $modules = [
    'node',
    'block_content',
    'quickedit',
  ];

  /**
   * {@inheritdoc}
   */
  protected $defaultTheme = 'stark';

  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    $user = $this
      ->createUser([
      'administer blocks',
      'access contextual links',
      'access toolbar',
      'administer nodes',
      'access in-place editing',
    ]);
    $this
      ->drupalLogin($user);
  }

  /**
   * Tests QuickEdit links behavior.
   */
  public function testQuickEditLinks() {
    $quick_edit_selector = '#quickedit-entity-toolbar';
    $node_selector = '[data-quickedit-entity-id="node/1"]';
    $body_selector = '[data-quickedit-field-id="node/1/body/en/full"]';
    $web_assert = $this
      ->assertSession();

    // Create a Content type and two test nodes.
    $this
      ->createContentType([
      'type' => 'page',
    ]);
    $auth_role = Role::load(Role::AUTHENTICATED_ID);
    $this
      ->grantPermissions($auth_role, [
      'edit any page content',
      'access content',
    ]);
    $node = $this
      ->createNode([
      'title' => 'Page One',
      'type' => 'page',
      'body' => [
        [
          'value' => 'Regular NODE body for the test.',
          'format' => 'plain_text',
        ],
      ],
    ]);
    $page = $this
      ->getSession()
      ->getPage();
    $block_plugin = 'system_powered_by_block';
    foreach ($this
      ->getTestThemes() as $theme) {
      $this
        ->enableTheme($theme);
      $block = $this
        ->placeBlock($block_plugin);
      $block_selector = $this
        ->getBlockSelector($block);

      // Load the same page twice.
      foreach ([
        1,
        2,
      ] as $page_load_times) {
        $this
          ->drupalGet('node/' . $node
          ->id());

        // The 2nd page load we should already be in edit mode.
        if ($page_load_times == 1) {
          $this
            ->enableEditMode();
        }

        // In Edit mode clicking field should open QuickEdit toolbar.
        $page
          ->find('css', $body_selector)
          ->click();
        $this
          ->assertElementVisibleAfterWait('css', $quick_edit_selector);
        $this
          ->disableEditMode();

        // Exiting Edit mode should close QuickEdit toolbar.
        $web_assert
          ->elementNotExists('css', $quick_edit_selector);

        // When not in Edit mode QuickEdit toolbar should not open.
        $page
          ->find('css', $body_selector)
          ->click();
        $web_assert
          ->elementNotExists('css', $quick_edit_selector);
        $this
          ->enableEditMode();
        $this
          ->openBlockForm($block_selector);
        $page
          ->find('css', $body_selector)
          ->click();
        $this
          ->assertElementVisibleAfterWait('css', $quick_edit_selector);

        // Off-canvas dialog should be closed when opening QuickEdit toolbar.
        $this
          ->waitForOffCanvasToClose();
        $this
          ->openBlockForm($block_selector);

        // QuickEdit toolbar should be closed when opening Off-canvas dialog.
        $web_assert
          ->elementNotExists('css', $quick_edit_selector);
      }

      // Check using contextual links to invoke QuickEdit and open the tray.
      $this
        ->drupalGet('node/' . $node
        ->id());
      $web_assert
        ->assertWaitOnAjaxRequest();
      $this
        ->disableEditMode();

      // Open QuickEdit toolbar before going into Edit mode.
      $this
        ->clickContextualLink($node_selector, "Quick edit");
      $this
        ->assertElementVisibleAfterWait('css', $quick_edit_selector);

      // Open off-canvas and enter Edit mode via contextual link.
      $this
        ->clickContextualLink($block_selector, "Quick edit");
      $this
        ->waitForOffCanvasToOpen();

      // QuickEdit toolbar should be closed when opening off-canvas dialog.
      $web_assert
        ->elementNotExists('css', $quick_edit_selector);

      // Open QuickEdit toolbar via contextual link while in Edit mode.
      $this
        ->clickContextualLink($node_selector, "Quick edit", FALSE);
      $this
        ->waitForOffCanvasToClose();
      $this
        ->assertElementVisibleAfterWait('css', $quick_edit_selector);
      $this
        ->disableEditMode();
    }
  }

  /**
   * Tests that contextual links in custom blocks are changed.
   *
   * "Quick edit" is quickedit.module link.
   * "Quick edit settings" is settings_tray.module link.
   */
  public function testCustomBlockLinks() {
    $this
      ->createBlockContentType('basic', TRUE);
    $block_content = $this
      ->createBlockContent('Custom Block', 'basic', TRUE);
    $this
      ->placeBlock('block_content:' . $block_content
      ->uuid(), [
      'id' => 'custom',
    ]);
    $this
      ->drupalGet('user');
    $page = $this
      ->getSession()
      ->getPage();
    $this
      ->toggleContextualTriggerVisibility('#block-custom');
    $page
      ->find('css', '#block-custom .contextual button')
      ->press();
    $links = $page
      ->findAll('css', "#block-custom .contextual-links li a");
    $link_labels = [];

    /** @var \Behat\Mink\Element\NodeElement $link */
    foreach ($links as $link) {
      $link_labels[$link
        ->getAttribute('href')] = $link
        ->getText();
    }
    $href = array_search('Quick edit', $link_labels);
    $this
      ->assertEquals('', $href);
    $href = array_search('Quick edit settings', $link_labels);
    $destination = (string) $this->loggedInUser
      ->toUrl()
      ->toString();
    $this
      ->assertTrue(strstr($href, "/admin/structure/block/manage/custom/settings-tray?destination={$destination}") !== FALSE);
  }

  /**
   * Creates a custom block.
   *
   * @param bool|string $title
   *   (optional) Title of block. When no value is given uses a random name.
   *   Defaults to FALSE.
   * @param string $bundle
   *   (optional) Bundle name. Defaults to 'basic'.
   * @param bool $save
   *   (optional) Whether to save the block. Defaults to TRUE.
   *
   * @return \Drupal\block_content\Entity\BlockContent
   *   Created custom block.
   */
  protected function createBlockContent($title = FALSE, $bundle = 'basic', $save = TRUE) {
    $title = $title ?: $this
      ->randomName();
    $block_content = BlockContent::create([
      'info' => $title,
      'type' => $bundle,
      'langcode' => 'en',
      'body' => [
        'value' => 'The name "llama" was adopted by European settlers from native Peruvians.',
        'format' => 'plain_text',
      ],
    ]);
    if ($block_content && $save === TRUE) {
      $block_content
        ->save();
    }
    return $block_content;
  }

  /**
   * Creates a custom block type (bundle).
   *
   * @param string $label
   *   The block type label.
   * @param bool $create_body
   *   Whether or not to create the body field.
   *
   * @return \Drupal\block_content\Entity\BlockContentType
   *   Created custom block type.
   */
  protected function createBlockContentType($label, $create_body = FALSE) {
    $bundle = BlockContentType::create([
      'id' => $label,
      'label' => $label,
      'revision' => FALSE,
    ]);
    $bundle
      ->save();
    if ($create_body) {
      block_content_add_body_field($bundle
        ->id());
    }
    return $bundle;
  }

}

Classes

Namesort descending Description
QuickEditIntegrationTest Test Settings Tray and Quick Edit modules integration.