function UserDeleteTest::testUserDeleteMultiple

Same name in other branches
  1. 9 core/modules/user/tests/src/Kernel/UserDeleteTest.php \Drupal\Tests\user\Kernel\UserDeleteTest::testUserDeleteMultiple()
  2. 10 core/modules/user/tests/src/Kernel/UserDeleteTest.php \Drupal\Tests\user\Kernel\UserDeleteTest::testUserDeleteMultiple()
  3. 11.x core/modules/user/tests/src/Kernel/UserDeleteTest.php \Drupal\Tests\user\Kernel\UserDeleteTest::testUserDeleteMultiple()

Test deleting multiple users.

File

core/modules/user/tests/src/Kernel/UserDeleteTest.php, line 30

Class

UserDeleteTest
Tests deleting of user accounts.

Namespace

Drupal\Tests\user\Kernel

Code

public function testUserDeleteMultiple() {
    $this->installSchema('system', [
        'sequences',
    ]);
    $this->installSchema('user', [
        'users_data',
    ]);
    $this->installEntitySchema('user');
    // Create a few users with permissions, so roles will be created.
    $user_a = $this->createUser([
        'access user profiles',
    ]);
    $user_b = $this->createUser([
        'access user profiles',
    ]);
    $user_c = $this->createUser([
        'access user profiles',
    ]);
    $uids = [
        $user_a->id(),
        $user_b->id(),
        $user_c->id(),
    ];
    // These users should have a role
    $connection = Database::getConnection();
    $query = $connection->select('user__roles', 'r');
    $roles_created = $query->fields('r', [
        'entity_id',
    ])
        ->condition('entity_id', $uids, 'IN')
        ->countQuery()
        ->execute()
        ->fetchField();
    $this->assertGreaterThan(0, $roles_created);
    // We should be able to load one of the users.
    $this->assertNotNull(User::load($user_a->id()));
    // Delete the users.
    $storage = $this->container
        ->get('entity_type.manager')
        ->getStorage('user');
    $users = $storage->loadMultiple($uids);
    $storage->delete($users);
    // Test if the roles assignments are deleted.
    $query = $connection->select('user__roles', 'r');
    $roles_after_deletion = $query->fields('r', [
        'entity_id',
    ])
        ->condition('entity_id', $uids, 'IN')
        ->countQuery()
        ->execute()
        ->fetchField();
    $this->assertEquals(0, $roles_after_deletion);
    // Test if the users are deleted, User::load() will return NULL.
    $this->assertNull(User::load($user_a->id()));
    $this->assertNull(User::load($user_b->id()));
    $this->assertNull(User::load($user_c->id()));
}

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