RulesActionAccessTest.php

Namespace

Drupal\Tests\rules\Unit\Integration\RulesAction

File

tests/src/Unit/Integration/RulesAction/RulesActionAccessTest.php

View source
<?php

namespace Drupal\Tests\rules\Unit\Integration\RulesAction;

use Drupal\Tests\rules\Unit\Integration\RulesIntegrationTestBase;
use Drupal\Core\Session\AccountInterface;
use Prophecy\Argument;

/**
 * Tests configuration access control for Rules Actions.
 *
 * @group RulesAction
 */
class RulesActionAccessTest extends RulesIntegrationTestBase {
    
    /**
     * Confirm that a condition plugin respects configure permission.
     */
    public function testHasConfigurationAccessInfo() {
        $plugin = $this->actionManager
            ->createInstance('rules_test_string');
        $definition = $plugin->getPluginDefinition();
        $this->assertNotEmpty($definition['configure_permissions'], "Plugin has configuration permission info.");
        $perms = $definition['configure_permissions'];
        $this->assertIsArray($perms, "configure_permissions is an array");
        $this->assertContains("access test configuration", $perms, "Expected permission found in configure_permissions.");
        // Now see if the permission is actually used.
        $user_with_perm = $this->prophesize(AccountInterface::class);
        $user_with_perm->hasPermission("access test configuration")
            ->willReturn(TRUE)
            ->shouldBeCalledTimes(2);
        $user_with_perm->hasPermission(Argument::type('string'))
            ->willReturn(FALSE);
        $this->container
            ->set('current_user', $user_with_perm->reveal());
        $this->assertTrue($plugin->checkConfigurationAccess(), "User with permission has configuration access.");
        $object_result = $plugin->checkConfigurationAccess($user_with_perm->reveal(), TRUE);
        $this->assertTrue($object_result->isAllowed(), "AccessResult in allowed state if an object is requested.");
        $user_without_perm = $this->prophesize(AccountInterface::class);
        $user_without_perm->hasPermission("access test configuration")
            ->willReturn(FALSE)
            ->shouldBeCalledTimes(2);
        $user_without_perm->hasPermission(Argument::type('string'))
            ->willReturn(FALSE);
        $this->assertFalse($plugin->checkConfigurationAccess($user_without_perm->reveal()), "User without permission does not have configuration access.");
        $object_result = $plugin->checkConfigurationAccess($user_without_perm->reveal(), TRUE);
        $this->assertTrue($object_result->isNeutral(), "an AccessResultNeutral object is returned on not allowed if an object is requested.");
    }

}

Classes

Title Deprecated Summary
RulesActionAccessTest Tests configuration access control for Rules Actions.