NodeActionsConfigurationTest.php

Same filename in other branches
  1. 8.9.x core/modules/node/tests/src/Functional/NodeActionsConfigurationTest.php
  2. 10 core/modules/action/tests/src/Functional/Node/NodeActionsConfigurationTest.php
  3. 11.x core/modules/action/tests/src/Functional/Node/NodeActionsConfigurationTest.php

Namespace

Drupal\Tests\node\Functional

File

core/modules/node/tests/src/Functional/NodeActionsConfigurationTest.php

View source
<?php

namespace Drupal\Tests\node\Functional;

use Drupal\Component\Serialization\Json;
use Drupal\Tests\BrowserTestBase;
use Drupal\system\Entity\Action;
use Drupal\user\Entity\User;

/**
 * Tests configuration of actions provided by the Node module.
 *
 * @group node
 */
class NodeActionsConfigurationTest extends BrowserTestBase {
    
    /**
     * Modules to install.
     *
     * @var array
     */
    protected static $modules = [
        'action',
        'node',
    ];
    
    /**
     * {@inheritdoc}
     */
    protected $defaultTheme = 'stark';
    
    /**
     * Tests configuration of the node_assign_owner_action action.
     */
    public function testAssignOwnerNodeActionConfiguration() {
        // Create a user with permission to view the actions administration pages.
        $user = $this->drupalCreateUser([
            'administer actions',
        ]);
        $this->drupalLogin($user);
        // Make a POST request to admin/config/system/actions.
        $edit = [];
        $edit['action'] = 'node_assign_owner_action';
        $this->drupalGet('admin/config/system/actions');
        $this->submitForm($edit, 'Create');
        $this->assertSession()
            ->statusCodeEquals(200);
        // Make a POST request to the individual action configuration page.
        $edit = [];
        $action_label = $this->randomMachineName();
        $edit['label'] = $action_label;
        $edit['id'] = strtolower($action_label);
        $edit['owner_uid'] = $user->id();
        $this->drupalGet('admin/config/system/actions/add/node_assign_owner_action');
        $this->submitForm($edit, 'Save');
        $this->assertSession()
            ->statusCodeEquals(200);
        $action_id = $edit['id'];
        // Make sure that the new action was saved properly.
        $this->assertSession()
            ->pageTextContains('The action has been successfully saved.');
        // Check that the label of the node_assign_owner_action action appears on
        // the actions administration page after saving.
        $this->assertSession()
            ->pageTextContains($action_label);
        // Make another POST request to the action edit page.
        $this->clickLink('Configure');
        $edit = [];
        $new_action_label = $this->randomMachineName();
        $edit['label'] = $new_action_label;
        $edit['owner_uid'] = $user->id();
        $this->submitForm($edit, 'Save');
        $this->assertSession()
            ->statusCodeEquals(200);
        // Make sure that the action updated properly.
        $this->assertSession()
            ->pageTextContains('The action has been successfully saved.');
        // Check that the old label for the node_assign_owner_action action does not
        // appear on the actions administration page after updating.
        $this->assertSession()
            ->pageTextNotContains($action_label);
        // Check that the new label for the node_assign_owner_action action appears
        // on the actions administration page after updating.
        $this->assertSession()
            ->pageTextContains($new_action_label);
        // Make sure that deletions work properly.
        $this->drupalGet('admin/config/system/actions');
        $this->clickLink('Delete');
        $this->assertSession()
            ->statusCodeEquals(200);
        $edit = [];
        $this->submitForm($edit, 'Delete');
        $this->assertSession()
            ->statusCodeEquals(200);
        // Make sure that the action was actually deleted.
        $this->assertSession()
            ->pageTextContains("The action {$new_action_label} has been deleted.");
        $this->drupalGet('admin/config/system/actions');
        $this->assertSession()
            ->statusCodeEquals(200);
        // Check that the label for the node_assign_owner_action action does not
        // appear on the actions administration page after deleting.
        $this->assertSession()
            ->pageTextNotContains($new_action_label);
        $action = Action::load($action_id);
        $this->assertNull($action, 'The node_assign_owner_action action is not available after being deleted.');
    }
    
    /**
     * Tests the autocomplete field when configuring the AssignOwnerNode action.
     */
    public function testAssignOwnerNodeActionAutocomplete() {
        // Create 200 users to force the action's configuration page to use an
        // autocomplete field instead of a select field. See
        // \Drupal\node\Plugin\Action\AssignOwnerNode::buildConfigurationForm().
        for ($i = 0; $i < 200; $i++) {
            $this->drupalCreateUser();
        }
        // Create a user with permission to view the actions administration pages
        // and additionally permission to administer users. Otherwise the user would
        // not be able to reference the anonymous user.
        $this->drupalLogin($this->drupalCreateUser([
            'administer actions',
            'administer users',
        ]));
        // Create AssignOwnerNode action.
        $this->drupalGet('admin/config/system/actions');
        $this->submitForm([
            'action' => 'node_assign_owner_action',
        ], 'Create');
        // Get the autocomplete URL of the owner_uid textfield.
        $autocomplete_field = $this->getSession()
            ->getPage()
            ->findField('owner_uid');
        $autocomplete_url = $this->getAbsoluteUrl($autocomplete_field->getAttribute('data-autocomplete-path'));
        // Make sure that autocomplete works.
        $user = $this->drupalCreateUser();
        $data = Json::decode($this->drupalGet($autocomplete_url, [
            'query' => [
                'q' => $user->getDisplayName(),
                '_format' => 'json',
            ],
        ]));
        $this->assertNotEmpty($data);
        $anonymous = User::getAnonymousUser();
        // Ensure that the anonymous user exists.
        $this->assertNotNull($anonymous);
        // Make sure the autocomplete does not show the anonymous user.
        $data = Json::decode($this->drupalGet($autocomplete_url, [
            'query' => [
                'q' => $anonymous->getDisplayName(),
                '_format' => 'json',
            ],
        ]));
        $this->assertEmpty($data);
    }

}

Classes

Title Deprecated Summary
NodeActionsConfigurationTest Tests configuration of actions provided by the Node module.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.