You are here

abstract class RabbitHoleBehaviorSettingsFormTestBase in Rabbit Hole 8

Same name and namespace in other branches
  1. 2.x tests/src/Functional/RabbitHoleBehaviorSettingsFormTestBase.php \Drupal\Tests\rabbit_hole\Functional\RabbitHoleBehaviorSettingsFormTestBase

Base class for the Rabbit Hole form additions tests.

Hierarchy

Expanded class hierarchy of RabbitHoleBehaviorSettingsFormTestBase

6 files declare their use of RabbitHoleBehaviorSettingsFormTestBase
GroupBehaviorSettingsFormTest.php in modules/rh_group/tests/src/Functional/GroupBehaviorSettingsFormTest.php
MediaBehaviorSettingsFormTest.php in modules/rh_media/tests/src/Functional/MediaBehaviorSettingsFormTest.php
NodeBehaviorSettingsFormTest.php in modules/rh_node/tests/src/Functional/NodeBehaviorSettingsFormTest.php
ProductBehaviorSettingsFormTest.php in modules/rh_commerce/tests/src/Functional/ProductBehaviorSettingsFormTest.php
TaxonomyBehaviorSettingsFormTest.php in modules/rh_taxonomy/tests/src/Functional/TaxonomyBehaviorSettingsFormTest.php

... See full list

File

tests/src/Functional/RabbitHoleBehaviorSettingsFormTestBase.php, line 12

Namespace

Drupal\Tests\rabbit_hole\Functional
View source
abstract class RabbitHoleBehaviorSettingsFormTestBase extends BrowserTestBase {
  const DEFAULT_BUNDLE_ACTION = 'display_page';
  const DEFAULT_ACTION = 'bundle_default';

  /**
   * {@inheritdoc}
   */
  protected $defaultTheme = 'stark';

  /**
   * {@inheritdoc}
   */
  public static $modules = [
    'rabbit_hole',
  ];

  /**
   * Admin user.
   *
   * @var \Drupal\user\UserInterface
   */
  protected $adminUser;

  /**
   * The name of bundle entity type.
   *
   * @var string
   */
  protected $bundleEntityTypeName;

  /**
   * The behavior settings manager.
   *
   * @var \Drupal\rabbit_hole\BehaviorSettingsManagerInterface
   */
  protected $behaviorSettingsManager;

  /**
   * {@inheritdoc}
   */
  protected function setUp() {
    parent::setUp();
    $this->behaviorSettingsManager = $this->container
      ->get('rabbit_hole.behavior_settings_manager');
    $admin_permissions = array_merge($this
      ->getAdminPermissions(), [
      'rabbit hole administer ' . $this->entityType,
    ]);
    $this->adminUser = $this
      ->drupalCreateUser($admin_permissions);
  }

  /**
   * Test that bundle form contains Rabbit Hole settings and required fields.
   */
  public function testDefaultBundleForm() {
    $bundle_id = $this
      ->createEntityBundle();
    $this
      ->loadEntityBundleForm($bundle_id);
    $this
      ->assertRabbitHoleSettings();
    $this
      ->assertSession()
      ->fieldValueEquals('rh_override', BehaviorSettings::OVERRIDE_ALLOW);
    $this
      ->assertSession()
      ->checkboxChecked($this
      ->getOptionId(static::DEFAULT_BUNDLE_ACTION));
  }

  /**
   * Test the "rabbit hole administer *" permission.
   *
   * User without "rabbit hole administer *" permission should not be able to
   * see and administer Rabbit Hole settings.
   */
  public function testAdministerPermission() {
    $this
      ->drupalLogin($this
      ->drupalCreateUser($this
      ->getAdminPermissions()));
    $this
      ->createEntityBundle();
    $this
      ->drupalGet($this
      ->getCreateEntityUrl());
    $this
      ->assertNoRabbitHoleSettings();
  }

  /**
   * Test that Rabbit Hole settings are created together with entity bundle.
   */
  public function testBundleCreation() {
    $override = BehaviorSettings::OVERRIDE_DISALLOW;
    $action = 'access_denied';
    $bundle_id = $this
      ->createEntityBundleFormSubmit($action, $override);
    $saved_config = $this->behaviorSettingsManager
      ->loadBehaviorSettingsAsConfig($this->bundleEntityTypeName, $bundle_id);
    $this
      ->assertEquals($action, $saved_config
      ->get('action'));
    $this
      ->assertEquals($override, $saved_config
      ->get('allow_override'));
    $this
      ->loadEntityBundleForm($bundle_id);
    $this
      ->assertSession()
      ->fieldValueEquals('rh_override', $override);
    $this
      ->assertSession()
      ->checkboxChecked($this
      ->getOptionId($action));
  }

  /**
   * Test the first bundle form save with Rabbit Hole configuration.
   */
  public function testBundleFormFirstSave() {
    $test_bundle_id = $this
      ->createEntityBundle();
    $this
      ->loadEntityBundleForm($test_bundle_id);
    $override = BehaviorSettings::OVERRIDE_DISALLOW;
    $action = 'access_denied';
    $this
      ->submitForm([
      'rh_override' => $override,
      'rh_action' => $action,
    ], 'edit-submit');
    $saved_config = $this->behaviorSettingsManager
      ->loadBehaviorSettingsAsConfig($this->bundleEntityTypeName, $test_bundle_id);
    $this
      ->assertEquals($action, $saved_config
      ->get('action'));
    $this
      ->assertEquals($override, $saved_config
      ->get('allow_override'));
  }

  /**
   * Test Rabbit Hole settings with allowed/disallowed overrides.
   */
  public function testAllowOverrideValue() {
    $bundle_allow = $this
      ->createEntityBundle();
    $this->behaviorSettingsManager
      ->saveBehaviorSettings([
      'action' => 'access_denied',
      'allow_override' => BehaviorSettings::OVERRIDE_ALLOW,
      'redirect_code' => BehaviorSettings::REDIRECT_NOT_APPLICABLE,
    ], $this->bundleEntityTypeName, $bundle_allow);
    $this
      ->loadCreateEntityForm();
    $this
      ->assertRabbitHoleSettings();
    $bundle_disallow = $this
      ->createEntityBundle();
    $this->behaviorSettingsManager
      ->saveBehaviorSettings([
      'action' => 'access_denied',
      'allow_override' => BehaviorSettings::OVERRIDE_DISALLOW,
      'redirect_code' => BehaviorSettings::REDIRECT_NOT_APPLICABLE,
    ], $this->bundleEntityTypeName, $bundle_disallow);
    $this
      ->loadCreateEntityForm();
    $this
      ->assertNoRabbitHoleSettings();
  }

  /**
   * Test that bundle form with a configured bundle behaviour loads config.
   */
  public function testBundleFormExistingBehavior() {
    $action = 'page_not_found';
    $override = BehaviorSettings::OVERRIDE_DISALLOW;
    $test_bundle_id = $this
      ->createEntityBundle();
    $this->behaviorSettingsManager
      ->saveBehaviorSettings([
      'action' => $action,
      'allow_override' => $override,
      'redirect_code' => BehaviorSettings::REDIRECT_NOT_APPLICABLE,
    ], $this->bundleEntityTypeName, $test_bundle_id);
    $this
      ->loadEntityBundleForm($test_bundle_id);
    $this
      ->assertSession()
      ->fieldValueEquals('rh_override', $override);
    $this
      ->assertSession()
      ->checkboxChecked($this
      ->getOptionId($action));
  }

  /**
   * Test new changes to bundle with existing rabbit hole settings changes key.
   *
   * Test that saving changes to a bundle form which already has
   * configured rabbit hole behavior settings changes the existing key.
   */
  public function testBundleFormSave() {
    $test_bundle_id = $this
      ->createEntityBundle();
    $this->behaviorSettingsManager
      ->saveBehaviorSettings([
      'action' => 'access_denied',
      'allow_override' => BehaviorSettings::OVERRIDE_DISALLOW,
      'redirect_code' => BehaviorSettings::REDIRECT_NOT_APPLICABLE,
    ], $this->bundleEntityTypeName, $test_bundle_id);
    $this
      ->loadEntityBundleForm($test_bundle_id);
    $action = 'page_not_found';
    $override = BehaviorSettings::OVERRIDE_ALLOW;
    $this
      ->submitForm([
      'rh_override' => $override,
      'rh_action' => $action,
    ], 'edit-submit');
    $saved_config = $this->behaviorSettingsManager
      ->loadBehaviorSettingsAsConfig($this->bundleEntityTypeName, $test_bundle_id);
    $this
      ->assertEquals($action, $saved_config
      ->get('action'));
    $this
      ->assertEquals($override, $saved_config
      ->get('allow_override'));
  }

  /**
   * Test saving settings for entity that did not previously have them.
   *
   * Test that an existing entity that previously didn't have settings will have
   * settings saved when the entity form is saved.
   */
  public function testExistingEntityNoConfigSave() {
    $this
      ->createEntityBundle();
    $entity_id = $this
      ->createEntity();
    $this
      ->loadEditEntityForm($entity_id);
    $action = 'access_denied';
    $this
      ->submitForm([
      'rh_action' => $action,
    ], 'Save');
    $entity = $this
      ->loadEntity($entity_id);
    $this
      ->assertEquals($action, $entity
      ->get('rh_action')->value);
  }

  /**
   * Test that existing entity is edited on saving the entity form.
   */
  public function testExistingEntitySave() {
    $this
      ->createEntityBundle();
    $entity_id = $this
      ->createEntity('display_page');
    $this
      ->loadEditEntityForm($entity_id);
    $action = 'access_denied';
    $this
      ->submitForm([
      'rh_action' => $action,
    ], 'Save');

    // Make sure the editor didn't hit error page after the form save.
    $this
      ->assertSession()
      ->statusCodeEquals(200);
    $entity = $this
      ->loadEntity($entity_id);
    $this
      ->assertEquals($action, $entity
      ->get('rh_action')->value);
  }

  /**
   * Test that when entity form is loaded it defaults the bundle configuration.
   */
  public function testDefaultEntitySettingsLoad() {
    $this
      ->createEntityBundle();
    $this
      ->loadCreateEntityForm();
    $this
      ->assertRabbitHoleSettings();
    $this
      ->assertSession()
      ->checkboxChecked($this
      ->getOptionId(static::DEFAULT_ACTION));
  }

  /**
   * Test that entity form correctly loads previously saved behavior settings.
   */
  public function testExistingEntitySettingsLoad() {
    $this
      ->createEntityBundle();
    $action = 'access_denied';
    $entity_id = $this
      ->createEntity($action);
    $this
      ->loadEditEntityForm($entity_id);
    $this
      ->assertSession()
      ->checkboxChecked($this
      ->getOptionId($action));
  }

  /**
   * Test redirect after entity form save.
   */
  public function testEntityFormSaveRedirect() {
    $override = BehaviorSettings::OVERRIDE_DISALLOW;
    $action = 'access_denied';
    $this
      ->createEntityBundleFormSubmit($action, $override);
    $this
      ->loadCreateEntityForm();
    $this
      ->assertNoRabbitHoleSettings();
    $this
      ->submitForm([], $this
      ->getEntityFormSubmit());

    // Make sure the editor didn't hit error page after the form save in case
    // there is no Rabbit Hole actions available.
    $this
      ->assertSession()
      ->statusCodeEquals(200);
  }

  /**
   * Combines multiple asserts to check the "Rabbit Hole" settings fieldset.
   */
  protected function assertRabbitHoleSettings() {
    $this
      ->assertSession()
      ->fieldExists('rh_action');
    $this
      ->assertSession()
      ->fieldExists('edit-rh-action-access-denied');
    $this
      ->assertSession()
      ->fieldExists('edit-rh-action-display-page');
    $this
      ->assertSession()
      ->fieldExists('edit-rh-action-page-not-found');
    $this
      ->assertSession()
      ->fieldExists('edit-rh-action-page-redirect');
  }

  /**
   * Combines multiple asserts to check that "Rabbit Hole" settings are hidden.
   */
  protected function assertNoRabbitHoleSettings() {
    $this
      ->assertSession()
      ->fieldNotExists('rh_action');
    $this
      ->assertSession()
      ->fieldNotExists('edit-rh-action-access-denied');
    $this
      ->assertSession()
      ->fieldNotExists('edit-rh-action-display-page');
    $this
      ->assertSession()
      ->fieldNotExists('edit-rh-action-page-not-found');
    $this
      ->assertSession()
      ->fieldNotExists('edit-rh-action-page-redirect');
  }

  /**
   * Loads the bundle configuration form.
   */
  protected function loadEntityBundleForm($bundle) {
    $this
      ->drupalLogin($this->adminUser);
    $this
      ->drupalGet($this
      ->getEditBundleUrl($bundle));
    $this
      ->assertSession()
      ->statusCodeEquals(200);
  }

  /**
   * Loads the "Create" entity form.
   */
  protected function loadCreateEntityForm() {
    $this
      ->drupalLogin($this->adminUser);
    $this
      ->drupalGet($this
      ->getCreateEntityUrl());
    $this
      ->assertSession()
      ->statusCodeEquals(200);
  }

  /**
   * Loads the "Edit" entity form.
   */
  protected function loadEditEntityForm($entity_id) {
    $this
      ->drupalLogin($this->adminUser);
    $this
      ->drupalGet($this
      ->getEditEntityUrl($entity_id));
    $this
      ->assertSession()
      ->statusCodeEquals(200);
  }

  /**
   * Loads test entity.
   *
   * @param mixed $id
   *   ID of loaded entity.
   *
   * @return \Drupal\Core\Entity\EntityInterface
   *   Loaded entity.
   */
  protected function loadEntity($id) {
    $storage = \Drupal::entityTypeManager()
      ->getStorage($this->entityType);
    $storage
      ->resetCache([
      $id,
    ]);
    return $storage
      ->load($id);
  }

  /**
   * Loads test bundle object.
   *
   * @param mixed $id
   *   Bundle ID.
   *
   * @return \Drupal\Core\Config\Entity\ConfigEntityBundleBase
   *   Loaded bundle.
   */
  protected function loadBundle($id) {
    $storage = \Drupal::entityTypeManager()
      ->getStorage($this->bundleEntityTypeName);
    $storage
      ->resetCache([
      $id,
    ]);
    $bundle = $storage
      ->load($id);
    $this
      ->assertInstanceOf(ConfigEntityBundleBase::class, $bundle);
    return $bundle;
  }

  /**
   * Formats selector of the action input.
   *
   * @param string $action
   *   Rabbit hole action.
   *
   * @return string
   *   Selector for the given behavior option.
   */
  protected function getOptionId($action) {
    return 'edit-rh-action-' . str_replace('_', '-', $action);
  }

  /**
   * Returns form submit name/identifier for entity create/edit form.
   *
   * @return string
   *   Value of the submit button whose click is to be emulated.
   */
  protected function getEntityFormSubmit() {
    return 'edit-submit';
  }

  /**
   * Returns URL of the "Edit" entity bundle page.
   *
   * @param string $bundle
   *   Entity bundle id.
   *
   * @return \Drupal\Core\Url
   *   URL object.
   */
  protected abstract function getEditBundleUrl($bundle);

  /**
   * Returns URL of the "Create" entity page.
   *
   * @return \Drupal\Core\Url
   *   URL object.
   */
  protected abstract function getCreateEntityUrl();

  /**
   * Creates new entity bundle.
   *
   * @return string
   *   ID of the created bundle.
   */
  protected abstract function createEntityBundle();

  /**
   * Creates new entity bundle via form submit.
   */
  protected abstract function createEntityBundleFormSubmit($action, $override);

  /**
   * Creates new entity.
   *
   * @param string $action
   *   Rabbit Hole action.
   *
   * @return int
   *   ID of the created entity.
   */
  protected abstract function createEntity($action = NULL);

  /**
   * Returns a list of admin permissions for current entity type.
   *
   * @return array
   *   A list of admin permissions.
   */
  protected abstract function getAdminPermissions();

}

Members

Namesort descending Modifiers Type Description Overrides
AssertHelperTrait::castSafeStrings protected static function Casts MarkupInterface objects into strings.
AssertLegacyTrait::assert protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertTrue() instead.
AssertLegacyTrait::assertCacheTag protected function Asserts whether an expected cache tag was present in the last response.
AssertLegacyTrait::assertElementNotPresent protected function Asserts that the element with the given CSS selector is not present.
AssertLegacyTrait::assertElementPresent protected function Asserts that the element with the given CSS selector is present.
AssertLegacyTrait::assertEqual protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertEquals() instead.
AssertLegacyTrait::assertEscaped protected function Passes if the raw text IS found escaped on the loaded page, fail otherwise.
AssertLegacyTrait::assertField protected function Asserts that a field exists with the given name or ID.
AssertLegacyTrait::assertFieldById protected function Asserts that a field exists with the given ID and value.
AssertLegacyTrait::assertFieldByName protected function Asserts that a field exists with the given name and value.
AssertLegacyTrait::assertFieldByXPath protected function Asserts that a field exists in the current page by the given XPath.
AssertLegacyTrait::assertFieldChecked protected function Asserts that a checkbox field in the current page is checked.
AssertLegacyTrait::assertFieldsByValue protected function Asserts that a field exists in the current page with a given Xpath result.
AssertLegacyTrait::assertHeader protected function Checks that current response header equals value.
AssertLegacyTrait::assertIdentical protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertSame() instead.
AssertLegacyTrait::assertIdenticalObject protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertEquals() instead.
AssertLegacyTrait::assertLink protected function Passes if a link with the specified label is found.
AssertLegacyTrait::assertLinkByHref protected function Passes if a link containing a given href (part) is found.
AssertLegacyTrait::assertNoCacheTag protected function Asserts whether an expected cache tag was absent in the last response.
AssertLegacyTrait::assertNoEscaped protected function Passes if the raw text is not found escaped on the loaded page.
AssertLegacyTrait::assertNoField protected function Asserts that a field does NOT exist with the given name or ID.
AssertLegacyTrait::assertNoFieldById protected function Asserts that a field does not exist with the given ID and value.
AssertLegacyTrait::assertNoFieldByName protected function Asserts that a field does not exist with the given name and value.
AssertLegacyTrait::assertNoFieldByXPath protected function Asserts that a field does not exist or its value does not match, by XPath.
AssertLegacyTrait::assertNoFieldChecked protected function Asserts that a checkbox field in the current page is not checked.
AssertLegacyTrait::assertNoLink protected function Passes if a link with the specified label is not found.
AssertLegacyTrait::assertNoLinkByHref protected function Passes if a link containing a given href (part) is not found.
AssertLegacyTrait::assertNoOption protected function Asserts that a select option does NOT exist in the current page.
AssertLegacyTrait::assertNoPattern protected function Triggers a pass if the Perl regex pattern is not found in the raw content.
AssertLegacyTrait::assertNoRaw protected function Passes if the raw text IS not found on the loaded page, fail otherwise. 1
AssertLegacyTrait::assertNotEqual protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertNotEquals() instead.
AssertLegacyTrait::assertNoText protected function Passes if the page (with HTML stripped) does not contains the text. 1
AssertLegacyTrait::assertNotIdentical protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertNotSame() instead.
AssertLegacyTrait::assertNoUniqueText protected function Passes if the text is found MORE THAN ONCE on the text version of the page.
AssertLegacyTrait::assertOption protected function Asserts that a select option in the current page exists.
AssertLegacyTrait::assertOptionByText protected function Asserts that a select option with the visible text exists.
AssertLegacyTrait::assertOptionSelected protected function Asserts that a select option in the current page is checked.
AssertLegacyTrait::assertPattern protected function Triggers a pass if the Perl regex pattern is found in the raw content.
AssertLegacyTrait::assertRaw protected function Passes if the raw text IS found on the loaded page, fail otherwise. 1
AssertLegacyTrait::assertResponse protected function Asserts the page responds with the specified response code. 1
AssertLegacyTrait::assertText protected function Passes if the page (with HTML stripped) contains the text. 1
AssertLegacyTrait::assertTextHelper protected function Helper for assertText and assertNoText.
AssertLegacyTrait::assertTitle protected function Pass if the page title is the given string.
AssertLegacyTrait::assertUniqueText protected function Passes if the text is found ONLY ONCE on the text version of the page.
AssertLegacyTrait::assertUrl protected function Passes if the internal browser's URL matches the given path.
AssertLegacyTrait::buildXPathQuery protected function Builds an XPath query.
AssertLegacyTrait::constructFieldXpath protected function Helper: Constructs an XPath for the given set of attributes and value.
AssertLegacyTrait::getAllOptions protected function Get all option elements, including nested options, in a select.
AssertLegacyTrait::getRawContent protected function Gets the current raw content.
AssertLegacyTrait::pass protected function Deprecated Scheduled for removal in Drupal 10.0.0. Use self::assertTrue() instead.
AssertLegacyTrait::verbose protected function
BlockCreationTrait::placeBlock protected function Creates a block instance based on default settings. Aliased as: drupalPlaceBlock
BrowserHtmlDebugTrait::$htmlOutputBaseUrl protected property The Base URI to use for links to the output files.
BrowserHtmlDebugTrait::$htmlOutputClassName protected property Class name for HTML output logging.
BrowserHtmlDebugTrait::$htmlOutputCounter protected property Counter for HTML output logging.
BrowserHtmlDebugTrait::$htmlOutputCounterStorage protected property Counter storage for HTML output logging.
BrowserHtmlDebugTrait::$htmlOutputDirectory protected property Directory name for HTML output logging.
BrowserHtmlDebugTrait::$htmlOutputEnabled protected property HTML output output enabled.
BrowserHtmlDebugTrait::$htmlOutputFile protected property The file name to write the list of URLs to.
BrowserHtmlDebugTrait::$htmlOutputTestId protected property HTML output test ID.
BrowserHtmlDebugTrait::formatHtmlOutputHeaders protected function Formats HTTP headers as string for HTML output logging.
BrowserHtmlDebugTrait::getHtmlOutputHeaders protected function Returns headers in HTML output format. 1
BrowserHtmlDebugTrait::htmlOutput protected function Logs a HTML output message in a text file.
BrowserHtmlDebugTrait::initBrowserOutputFile protected function Creates the directory to store browser output.
BrowserTestBase::$baseUrl protected property The base URL.
BrowserTestBase::$configImporter protected property The config importer that can be used in a test.
BrowserTestBase::$customTranslations protected property An array of custom translations suitable for drupal_rewrite_settings().
BrowserTestBase::$databasePrefix protected property The database prefix of this test run.
BrowserTestBase::$mink protected property Mink session manager.
BrowserTestBase::$minkDefaultDriverArgs protected property
BrowserTestBase::$minkDefaultDriverClass protected property 1
BrowserTestBase::$originalContainer protected property The original container.
BrowserTestBase::$originalShutdownCallbacks protected property The original array of shutdown function callbacks.
BrowserTestBase::$preserveGlobalState protected property
BrowserTestBase::$profile protected property The profile to install as a basis for testing. 39
BrowserTestBase::$root protected property The app root.
BrowserTestBase::$runTestInSeparateProcess protected property Browser tests are run in separate processes to prevent collisions between code that may be loaded by tests.
BrowserTestBase::$timeLimit protected property Time limit in seconds for the test.
BrowserTestBase::$translationFilesDirectory protected property The translation file directory for the test environment.
BrowserTestBase::cleanupEnvironment protected function Clean up the Simpletest environment.
BrowserTestBase::config protected function Configuration accessor for tests. Returns non-overridden configuration.
BrowserTestBase::cssSelectToXpath protected function Translates a CSS expression to its XPath equivalent.
BrowserTestBase::drupalGetHeader protected function Gets the value of an HTTP response header.
BrowserTestBase::drupalGetHeaders Deprecated protected function Returns all response headers.
BrowserTestBase::filePreDeleteCallback public static function Ensures test files are deletable.
BrowserTestBase::getDefaultDriverInstance protected function Gets an instance of the default Mink driver.
BrowserTestBase::getDrupalSettings protected function Gets the JavaScript drupalSettings variable for the currently-loaded page. 1
BrowserTestBase::getHttpClient protected function Obtain the HTTP client for the system under test.
BrowserTestBase::getMinkDriverArgs protected function Get the Mink driver args from an environment variable, if it is set. Can be overridden in a derived class so it is possible to use a different value for a subset of tests, e.g. the JavaScript tests. 1
BrowserTestBase::getOptions protected function Helper function to get the options of select field.
BrowserTestBase::getResponseLogHandler protected function Provides a Guzzle middleware handler to log every response received. Overrides BrowserHtmlDebugTrait::getResponseLogHandler
BrowserTestBase::getSession public function Returns Mink session.
BrowserTestBase::getSessionCookies protected function Get session cookies from current session.
BrowserTestBase::getTestMethodCaller protected function Retrieves the current calling line in the class under test. Overrides BrowserHtmlDebugTrait::getTestMethodCaller
BrowserTestBase::initFrontPage protected function Visits the front page when initializing Mink. 3
BrowserTestBase::initMink protected function Initializes Mink sessions. 1
BrowserTestBase::installDrupal public function Installs Drupal into the Simpletest site. 1
BrowserTestBase::registerSessions protected function Registers additional Mink sessions.
BrowserTestBase::tearDown protected function 3
BrowserTestBase::translatePostValues protected function Transforms a nested array into a flat array suitable for drupalPostForm().
BrowserTestBase::xpath protected function Performs an xpath search on the contents of the internal browser.
BrowserTestBase::__construct public function 1
BrowserTestBase::__sleep public function Prevents serializing any properties.
ConfigTestTrait::configImporter protected function Returns a ConfigImporter object to import test configuration.
ConfigTestTrait::copyConfig protected function Copies configuration objects from source storage to target storage.
ContentTypeCreationTrait::createContentType protected function Creates a custom content type based on default settings. Aliased as: drupalCreateContentType 1
FunctionalTestSetupTrait::$apcuEnsureUniquePrefix protected property The flag to set 'apcu_ensure_unique_prefix' setting. 1
FunctionalTestSetupTrait::$classLoader protected property The class loader to use for installation and initialization of setup.
FunctionalTestSetupTrait::$configDirectories Deprecated protected property The config directories used in this test.
FunctionalTestSetupTrait::$rootUser protected property The "#1" admin user.
FunctionalTestSetupTrait::doInstall protected function Execute the non-interactive installer. 1
FunctionalTestSetupTrait::getDatabaseTypes protected function Returns all supported database driver installer objects.
FunctionalTestSetupTrait::initConfig protected function Initialize various configurations post-installation. 2
FunctionalTestSetupTrait::initKernel protected function Initializes the kernel after installation.
FunctionalTestSetupTrait::initSettings protected function Initialize settings created during install.
FunctionalTestSetupTrait::initUserSession protected function Initializes user 1 for the site to be installed.
FunctionalTestSetupTrait::installDefaultThemeFromClassProperty protected function Installs the default theme defined by `static::$defaultTheme` when needed.
FunctionalTestSetupTrait::installModulesFromClassProperty protected function Install modules defined by `static::$modules`. 1
FunctionalTestSetupTrait::installParameters protected function Returns the parameters that will be used when Simpletest installs Drupal. 9
FunctionalTestSetupTrait::prepareEnvironment protected function Prepares the current environment for running the test. 23
FunctionalTestSetupTrait::prepareRequestForGenerator protected function Creates a mock request and sets it on the generator.
FunctionalTestSetupTrait::prepareSettings protected function Prepares site settings and services before installation. 2
FunctionalTestSetupTrait::rebuildAll protected function Resets and rebuilds the environment after setup.
FunctionalTestSetupTrait::rebuildContainer protected function Rebuilds \Drupal::getContainer().
FunctionalTestSetupTrait::resetAll protected function Resets all data structures after having enabled new modules.
FunctionalTestSetupTrait::setContainerParameter protected function Changes parameters in the services.yml file.
FunctionalTestSetupTrait::setupBaseUrl protected function Sets up the base URL based upon the environment variable.
FunctionalTestSetupTrait::writeSettings protected function Rewrites the settings.php file of the test site.
NodeCreationTrait::createNode protected function Creates a node based on default settings. Aliased as: drupalCreateNode
NodeCreationTrait::getNodeByTitle public function Get a node from the database based on its title. Aliased as: drupalGetNodeByTitle
PhpunitCompatibilityTrait::getMock Deprecated public function Returns a mock object for the specified class using the available method.
PhpunitCompatibilityTrait::setExpectedException Deprecated public function Compatibility layer for PHPUnit 6 to support PHPUnit 4 code.
RabbitHoleBehaviorSettingsFormTestBase::$adminUser protected property Admin user. 1
RabbitHoleBehaviorSettingsFormTestBase::$behaviorSettingsManager protected property The behavior settings manager. 1
RabbitHoleBehaviorSettingsFormTestBase::$bundleEntityTypeName protected property The name of bundle entity type. 6
RabbitHoleBehaviorSettingsFormTestBase::$defaultTheme protected property The theme to install as the default for testing. Overrides BrowserTestBase::$defaultTheme
RabbitHoleBehaviorSettingsFormTestBase::$modules public static property Modules to enable. Overrides BrowserTestBase::$modules 6
RabbitHoleBehaviorSettingsFormTestBase::assertNoRabbitHoleSettings protected function Combines multiple asserts to check that "Rabbit Hole" settings are hidden.
RabbitHoleBehaviorSettingsFormTestBase::assertRabbitHoleSettings protected function Combines multiple asserts to check the "Rabbit Hole" settings fieldset.
RabbitHoleBehaviorSettingsFormTestBase::createEntity abstract protected function Creates new entity. 6
RabbitHoleBehaviorSettingsFormTestBase::createEntityBundle abstract protected function Creates new entity bundle. 6
RabbitHoleBehaviorSettingsFormTestBase::createEntityBundleFormSubmit abstract protected function Creates new entity bundle via form submit. 6
RabbitHoleBehaviorSettingsFormTestBase::DEFAULT_ACTION constant 1
RabbitHoleBehaviorSettingsFormTestBase::DEFAULT_BUNDLE_ACTION constant 1
RabbitHoleBehaviorSettingsFormTestBase::getAdminPermissions abstract protected function Returns a list of admin permissions for current entity type. 6
RabbitHoleBehaviorSettingsFormTestBase::getCreateEntityUrl abstract protected function Returns URL of the "Create" entity page. 6
RabbitHoleBehaviorSettingsFormTestBase::getEditBundleUrl abstract protected function Returns URL of the "Edit" entity bundle page. 6
RabbitHoleBehaviorSettingsFormTestBase::getEntityFormSubmit protected function Returns form submit name/identifier for entity create/edit form. 1
RabbitHoleBehaviorSettingsFormTestBase::getOptionId protected function Formats selector of the action input.
RabbitHoleBehaviorSettingsFormTestBase::loadBundle protected function Loads test bundle object.
RabbitHoleBehaviorSettingsFormTestBase::loadCreateEntityForm protected function Loads the "Create" entity form.
RabbitHoleBehaviorSettingsFormTestBase::loadEditEntityForm protected function Loads the "Edit" entity form.
RabbitHoleBehaviorSettingsFormTestBase::loadEntity protected function Loads test entity.
RabbitHoleBehaviorSettingsFormTestBase::loadEntityBundleForm protected function Loads the bundle configuration form.
RabbitHoleBehaviorSettingsFormTestBase::setUp protected function Overrides BrowserTestBase::setUp 1
RabbitHoleBehaviorSettingsFormTestBase::testAdministerPermission public function Test the "rabbit hole administer *" permission.
RabbitHoleBehaviorSettingsFormTestBase::testAllowOverrideValue public function Test Rabbit Hole settings with allowed/disallowed overrides.
RabbitHoleBehaviorSettingsFormTestBase::testBundleCreation public function Test that Rabbit Hole settings are created together with entity bundle. 1
RabbitHoleBehaviorSettingsFormTestBase::testBundleFormExistingBehavior public function Test that bundle form with a configured bundle behaviour loads config.
RabbitHoleBehaviorSettingsFormTestBase::testBundleFormFirstSave public function Test the first bundle form save with Rabbit Hole configuration.
RabbitHoleBehaviorSettingsFormTestBase::testBundleFormSave public function Test new changes to bundle with existing rabbit hole settings changes key.
RabbitHoleBehaviorSettingsFormTestBase::testDefaultBundleForm public function Test that bundle form contains Rabbit Hole settings and required fields.
RabbitHoleBehaviorSettingsFormTestBase::testDefaultEntitySettingsLoad public function Test that when entity form is loaded it defaults the bundle configuration.
RabbitHoleBehaviorSettingsFormTestBase::testEntityFormSaveRedirect public function Test redirect after entity form save.
RabbitHoleBehaviorSettingsFormTestBase::testExistingEntityNoConfigSave public function Test saving settings for entity that did not previously have them.
RabbitHoleBehaviorSettingsFormTestBase::testExistingEntitySave public function Test that existing entity is edited on saving the entity form.
RabbitHoleBehaviorSettingsFormTestBase::testExistingEntitySettingsLoad public function Test that entity form correctly loads previously saved behavior settings.
RandomGeneratorTrait::$randomGenerator protected property The random generator.
RandomGeneratorTrait::getRandomGenerator protected function Gets the random generator for the utility methods.
RandomGeneratorTrait::randomMachineName protected function Generates a unique random string containing letters and numbers. 1
RandomGeneratorTrait::randomObject public function Generates a random PHP object.
RandomGeneratorTrait::randomString public function Generates a pseudo-random string of ASCII characters of codes 32 to 126.
RandomGeneratorTrait::randomStringValidate public function Callback for random string validation.
RefreshVariablesTrait::refreshVariables protected function Refreshes in-memory configuration and state information. 3
SessionTestTrait::$sessionName protected property The name of the session cookie.
SessionTestTrait::generateSessionName protected function Generates a session cookie name.
SessionTestTrait::getSessionName protected function Returns the session name in use on the child site.
StorageCopyTrait::replaceStorageContents protected static function Copy the configuration from one storage to another and remove stale items.
TestRequirementsTrait::checkModuleRequirements private function Checks missing module requirements.
TestRequirementsTrait::checkRequirements protected function Check module requirements for the Drupal use case. 1
TestRequirementsTrait::getDrupalRoot protected static function Returns the Drupal root directory.
TestSetupTrait::$configSchemaCheckerExclusions protected static property An array of config object names that are excluded from schema checking.
TestSetupTrait::$container protected property The dependency injection container used in the test.
TestSetupTrait::$kernel protected property The DrupalKernel instance used in the test.
TestSetupTrait::$originalSite protected property The site directory of the original parent site.
TestSetupTrait::$privateFilesDirectory protected property The private file directory for the test environment.
TestSetupTrait::$publicFilesDirectory protected property The public file directory for the test environment.
TestSetupTrait::$siteDirectory protected property The site directory of this test run.
TestSetupTrait::$strictConfigSchema protected property Set to TRUE to strict check all configuration saved. 2
TestSetupTrait::$tempFilesDirectory protected property The temporary file directory for the test environment.
TestSetupTrait::$testId protected property The test run ID.
TestSetupTrait::changeDatabasePrefix protected function Changes the database connection to the prefixed one.
TestSetupTrait::getConfigSchemaExclusions protected function Gets the config schema exclusions for this test.
TestSetupTrait::getDatabaseConnection public static function Returns the database connection to the site running Simpletest.
TestSetupTrait::prepareDatabasePrefix protected function Generates a database prefix for running tests. 2
UiHelperTrait::$loggedInUser protected property The current user logged in using the Mink controlled browser.
UiHelperTrait::$maximumMetaRefreshCount protected property The number of meta refresh redirects to follow, or NULL if unlimited.
UiHelperTrait::$metaRefreshCount protected property The number of meta refresh redirects followed during ::drupalGet().
UiHelperTrait::assertSession public function Returns WebAssert object. 1
UiHelperTrait::buildUrl protected function Builds an a absolute URL from a system path or a URL object.
UiHelperTrait::checkForMetaRefresh protected function Checks for meta refresh tag and if found call drupalGet() recursively.
UiHelperTrait::click protected function Clicks the element with the given CSS selector.
UiHelperTrait::clickLink protected function Follows a link by complete name.
UiHelperTrait::cssSelect protected function Searches elements using a CSS selector in the raw content.
UiHelperTrait::drupalGet protected function Retrieves a Drupal path or an absolute path. 3
UiHelperTrait::drupalLogin protected function Logs in a user using the Mink controlled browser.
UiHelperTrait::drupalLogout protected function Logs a user out of the Mink controlled browser and confirms.
UiHelperTrait::drupalPostForm protected function Executes a form submission.
UiHelperTrait::drupalUserIsLoggedIn protected function Returns whether a given user account is logged in.
UiHelperTrait::getAbsoluteUrl protected function Takes a path and returns an absolute path.
UiHelperTrait::getTextContent protected function Retrieves the plain-text content from the current page.
UiHelperTrait::getUrl protected function Get the current URL from the browser.
UiHelperTrait::prepareRequest protected function Prepare for a request to testing site. 1
UiHelperTrait::submitForm protected function Fills and submits a form.
UserCreationTrait::checkPermissions protected function Checks whether a given list of permission names is valid.
UserCreationTrait::createAdminRole protected function Creates an administrative role.
UserCreationTrait::createRole protected function Creates a role with specified permissions. Aliased as: drupalCreateRole
UserCreationTrait::createUser protected function Create a user with a given set of permissions. Aliased as: drupalCreateUser
UserCreationTrait::grantPermissions protected function Grant permissions to a user role.
UserCreationTrait::setCurrentUser protected function Switch the current logged in user.
UserCreationTrait::setUpCurrentUser protected function Creates a random user account and sets it as current user.
XdebugRequestTrait::extractCookiesFromRequest protected function Adds xdebug cookies, from request setup.