You are here

UserKernelTestBase.php in Drupal 9

Same filename and directory in other branches
  1. 8 core/modules/user/tests/src/Kernel/Views/UserKernelTestBase.php

File

core/modules/user/tests/src/Kernel/Views/UserKernelTestBase.php
View source
<?php

namespace Drupal\Tests\user\Kernel\Views;

use Drupal\Tests\views\Kernel\ViewsKernelTestBase;
use Drupal\views\Tests\ViewTestData;

/**
 * Provides a common test base for user views tests.
 */
abstract class UserKernelTestBase extends ViewsKernelTestBase {

  /**
   * Modules to enable.
   *
   * @var array
   */
  protected static $modules = [
    'user_test_views',
    'user',
    'system',
    'field',
  ];

  /**
   * Users to use during this test.
   *
   * @var array
   */
  protected $users = [];

  /**
   * The entity storage for roles.
   *
   * @var \Drupal\user\RoleStorage
   */
  protected $roleStorage;

  /**
   * The entity storage for users.
   *
   * @var \Drupal\user\UserStorage
   */
  protected $userStorage;
  protected function setUp($import_test_views = TRUE) {
    parent::setUp();
    ViewTestData::createTestViews(static::class, [
      'user_test_views',
    ]);
    $this
      ->installEntitySchema('user');
    $entity_type_manager = $this->container
      ->get('entity_type.manager');
    $this->roleStorage = $entity_type_manager
      ->getStorage('user_role');
    $this->userStorage = $entity_type_manager
      ->getStorage('user');
  }

  /**
   * Set some test data for permission related tests.
   */
  protected function setupPermissionTestData() {

    // Setup a role without any permission.
    $this->roleStorage
      ->create([
      'id' => 'authenticated',
    ])
      ->save();
    $this->roleStorage
      ->create([
      'id' => 'no_permission',
    ])
      ->save();

    // Setup a role with just one permission.
    $this->roleStorage
      ->create([
      'id' => 'one_permission',
    ])
      ->save();
    user_role_grant_permissions('one_permission', [
      'administer permissions',
    ]);

    // Setup a role with multiple permissions.
    $this->roleStorage
      ->create([
      'id' => 'multiple_permissions',
    ])
      ->save();
    user_role_grant_permissions('multiple_permissions', [
      'administer permissions',
      'administer users',
      'access user profiles',
    ]);

    // Setup a user without an extra role.
    $this->users[] = $account = $this->userStorage
      ->create([
      'name' => $this
        ->randomString(),
    ]);
    $account
      ->save();

    // Setup a user with just the first role (so no permission beside the
    // ones from the authenticated role).
    $this->users[] = $account = $this->userStorage
      ->create([
      'name' => 'first_role',
    ]);
    $account
      ->addRole('no_permission');
    $account
      ->save();

    // Setup a user with just the second role (so one additional permission).
    $this->users[] = $account = $this->userStorage
      ->create([
      'name' => 'second_role',
    ]);
    $account
      ->addRole('one_permission');
    $account
      ->save();

    // Setup a user with both the second and the third role.
    $this->users[] = $account = $this->userStorage
      ->create([
      'name' => 'second_third_role',
    ]);
    $account
      ->addRole('one_permission');
    $account
      ->addRole('multiple_permissions');
    $account
      ->save();
  }

}

Classes

Namesort descending Description
UserKernelTestBase Provides a common test base for user views tests.