UserUpdateRoleDependenciesTest.php in Drupal 9
File
core/modules/user/tests/src/Functional/Update/UserUpdateRoleDependenciesTest.php
View source
<?php
namespace Drupal\Tests\user\Functional\Update;
use Drupal\FunctionalTests\Update\UpdatePathTestBase;
use Drupal\user\Entity\Role;
class UserUpdateRoleDependenciesTest extends UpdatePathTestBase {
protected function setDatabaseDumpFiles() {
$this->databaseDumpFiles = [
__DIR__ . '/../../../../../system/tests/fixtures/update/drupal-8.8.0.bare.standard.php.gz',
];
}
public function testRolePermissions() {
$raw_config = $this
->config('user.role.authenticated');
$permissions = $raw_config
->get('permissions');
$permissions[] = 'does_not_exist';
$raw_config
->set('permissions', $permissions)
->save();
$authenticated = Role::load('authenticated');
$this
->assertTrue($authenticated
->hasPermission('does_not_exist'), 'Authenticated role has a permission that does not exist');
$this
->assertEquals([], $authenticated
->getDependencies());
$this
->runUpdates();
$this
->assertSession()
->pageTextContains('The roles Anonymous user, Authenticated user have had non-existent permissions removed. Check the logs for details.');
$authenticated = Role::load('authenticated');
$this
->assertFalse($authenticated
->hasPermission('does_not_exist'), 'Authenticated role does not have a permission that does not exist');
$this
->assertEquals([
'config' => [
'filter.format.basic_html',
],
'module' => [
'comment',
'contact',
'filter',
'shortcut',
'system',
],
], $authenticated
->getDependencies());
$this
->drupalLogin($this
->createUser([
'access site reports',
]));
$this
->drupalGet('admin/reports/dblog', [
'query' => [
'type[]' => 'update',
],
]);
$this
->clickLink('The role Authenticated user has had the following non-…');
$this
->assertSession()
->pageTextContains('The role Authenticated user has had the following non-existent permission(s) removed: use text format plain_text, does_not_exist.');
$this
->getSession()
->back();
$this
->clickLink('The role Anonymous user has had the following non-…');
$this
->assertSession()
->pageTextContains('The role Anonymous user has had the following non-existent permission(s) removed: use text format plain_text.');
}
}