class AccessGroupAndTest in Drupal 8
Same name and namespace in other branches
- 9 core/modules/block_content/tests/src/Unit/Access/AccessGroupAndTest.php \Drupal\Tests\block_content\Unit\Access\AccessGroupAndTest
- 10 core/modules/block_content/tests/src/Unit/Access/AccessGroupAndTest.php \Drupal\Tests\block_content\Unit\Access\AccessGroupAndTest
Tests accessible groups.
@group block_content
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait- class \Drupal\Tests\block_content\Unit\Access\AccessGroupAndTest uses AccessibleTestingTrait
 
Expanded class hierarchy of AccessGroupAndTest
File
- core/modules/ block_content/ tests/ src/ Unit/ Access/ AccessGroupAndTest.php, line 15 
Namespace
Drupal\Tests\block_content\Unit\AccessView source
class AccessGroupAndTest extends UnitTestCase {
  use AccessibleTestingTrait;
  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    $this->account = $this
      ->prophesize(AccountInterface::class)
      ->reveal();
  }
  /**
   * @covers \Drupal\block_content\Access\AccessGroupAnd
   */
  public function testGroups() {
    $allowedAccessible = $this
      ->createAccessibleDouble(AccessResult::allowed());
    $forbiddenAccessible = $this
      ->createAccessibleDouble(AccessResult::forbidden());
    $neutralAccessible = $this
      ->createAccessibleDouble(AccessResult::neutral());
    // Ensure that groups with no dependencies return a neutral access result.
    $this
      ->assertTrue((new AccessGroupAnd())
      ->access('view', $this->account, TRUE)
      ->isNeutral());
    $andNeutral = new AccessGroupAnd();
    $andNeutral
      ->addDependency($allowedAccessible)
      ->addDependency($neutralAccessible);
    $this
      ->assertTrue($andNeutral
      ->access('view', $this->account, TRUE)
      ->isNeutral());
    $andForbidden = $andNeutral;
    $andForbidden
      ->addDependency($forbiddenAccessible);
    $this
      ->assertTrue($andForbidden
      ->access('view', $this->account, TRUE)
      ->isForbidden());
    // Ensure that groups added to other groups works.
    $andGroupsForbidden = new AccessGroupAnd();
    $andGroupsForbidden
      ->addDependency($andNeutral)
      ->addDependency($andForbidden);
    $this
      ->assertTrue($andGroupsForbidden
      ->access('view', $this->account, TRUE)
      ->isForbidden());
    // Ensure you can add a non-group accessible object.
    $andGroupsForbidden
      ->addDependency($allowedAccessible);
    $this
      ->assertTrue($andGroupsForbidden
      ->access('view', $this->account, TRUE)
      ->isForbidden());
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| AccessGroupAndTest:: | protected | function | Overrides UnitTestCase:: | |
| AccessGroupAndTest:: | public | function | @covers \Drupal\block_content\Access\AccessGroupAnd | |
| AccessibleTestingTrait:: | protected | property | The test account. | |
| AccessibleTestingTrait:: | private | function | Creates AccessibleInterface object from access result object for testing. | |
| PhpunitCompatibilityTrait:: | public | function | Returns a mock object for the specified class using the available method. | |
| PhpunitCompatibilityTrait:: | public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
| UnitTestCase:: | protected | property | The random generator. | |
| UnitTestCase:: | protected | property | The app root. | 1 | 
| UnitTestCase:: | protected | function | Asserts if two arrays are equal by sorting them first. | |
| UnitTestCase:: | protected | function | Mocks a block with a block plugin. | 1 | 
| UnitTestCase:: | protected | function | Returns a stub class resolver. | |
| UnitTestCase:: | public | function | Returns a stub config factory that behaves according to the passed array. | |
| UnitTestCase:: | public | function | Returns a stub config storage that returns the supplied configuration. | |
| UnitTestCase:: | protected | function | Sets up a container with a cache tags invalidator. | |
| UnitTestCase:: | protected | function | Gets the random generator for the utility methods. | |
| UnitTestCase:: | public | function | Returns a stub translation manager that just returns the passed string. | |
| UnitTestCase:: | public | function | Generates a unique random string containing letters and numbers. | 
