You are here

class UpdatePathTestBaseFilledTest in Drupal 9

Same name and namespace in other branches
  1. 8 core/modules/system/tests/src/Functional/UpdateSystem/UpdatePathTestBaseFilledTest.php \Drupal\Tests\system\Functional\UpdateSystem\UpdatePathTestBaseFilledTest

Runs UpdatePathTestBaseTest with a dump filled with content.

@group #slow @group Update

Hierarchy

Expanded class hierarchy of UpdatePathTestBaseFilledTest

File

core/modules/system/tests/src/Functional/UpdateSystem/UpdatePathTestBaseFilledTest.php, line 16

Namespace

Drupal\Tests\system\Functional\UpdateSystem
View source
class UpdatePathTestBaseFilledTest extends UpdatePathTestBaseTest {

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

  /**
   * {@inheritdoc}
   */
  protected function setDatabaseDumpFiles() {
    parent::setDatabaseDumpFiles();
    $this->databaseDumpFiles[0] = __DIR__ . '/../../../../tests/fixtures/update/drupal-9.0.0.filled.standard.php.gz';
  }

  /**
   * Tests that the content and configuration were properly updated.
   */
  public function testUpdatedSite() {
    $this
      ->runUpdates();
    $spanish = \Drupal::languageManager()
      ->getLanguage('es');
    $expected_node_data = [
      [
        1,
        'article',
        'en',
        'Test Article - New title',
      ],
      [
        2,
        'book',
        'en',
        'Book page',
      ],
      [
        3,
        'forum',
        'en',
        'Forum topic',
      ],
      [
        4,
        'page',
        'en',
        'Test page',
      ],
      [
        8,
        'test_content_type',
        'en',
        'Test title',
      ],
    ];
    foreach ($expected_node_data as $node_data) {
      $id = $node_data[0];
      $type = $node_data[1];
      $langcode = $node_data[2];
      $title = $node_data[3];

      // Make sure our English nodes still exist.
      $node = Node::load($id);
      $this
        ->assertEquals($langcode, $node
        ->language()
        ->getId());
      $this
        ->assertEquals($type, $node
        ->getType());
      $this
        ->assertEquals($title, $node
        ->getTitle());

      // Assert that nodes are all published.
      $this
        ->assertTrue($node
        ->isPublished());
      $this
        ->drupalGet('node/' . $id);
      $this
        ->assertSession()
        ->pageTextContains($title);
    }

    // Make sure the translated node still exists.
    $translation = Node::load(8)
      ->getTranslation('es');
    $this
      ->assertEquals('Test title Spanish', $translation
      ->getTitle());

    // Make sure our alias still works.
    $this
      ->drupalGet('test-article');
    $this
      ->assertSession()
      ->pageTextContains('Test Article - New title');
    $this
      ->assertSession()
      ->pageTextContains('Body');
    $this
      ->assertSession()
      ->pageTextContains('Tags');

    // Make sure a translated page exists.
    $this
      ->drupalGet('node/8', [
      'language' => $spanish,
    ]);

    // Check for text of two comments.
    $this
      ->assertSession()
      ->pageTextContains('Hola');
    $this
      ->assertSession()
      ->pageTextContains('Hello');

    // The user entity reference field is access restricted.
    $this
      ->assertSession()
      ->pageTextNotContains('Test 12');

    // Make sure all other field labels are there.
    for ($i = 1; $i <= 23; $i++) {
      if ($i != 12) {
        $this
          ->assertSession()
          ->pageTextContains('Test ' . $i);
      }
    }

    // Make sure the translated slogan appears.
    $this
      ->assertSession()
      ->pageTextContains('drupal Spanish');

    // Make sure the custom block appears.
    $this
      ->drupalGet('<front>');

    // Block title.
    $this
      ->assertSession()
      ->pageTextContains('Another block');

    // Block body.
    $this
      ->assertSession()
      ->pageTextContains('Hello');

    // Log in as user 1.
    $account = User::load(1);
    $account->passRaw = 'drupal';
    $this
      ->drupalLogin($account);

    // Make sure we can see the access-restricted entity reference field
    // now that we're logged in.
    $this
      ->drupalGet('node/8', [
      'language' => $spanish,
    ]);
    $this
      ->assertSession()
      ->pageTextContains('Test 12');
    $this
      ->assertSession()
      ->linkExists('drupal');

    // Make sure the content for node 8 is still in the edit form.
    $this
      ->drupalGet('node/8/edit');
    $this
      ->assertSession()
      ->pageTextContains('Test title');
    $this
      ->assertSession()
      ->pageTextContains('Test body');
    $this
      ->assertSession()
      ->checkboxChecked('edit-field-test-1-value');
    $this
      ->assertSession()
      ->responseContains('2015-08-16');
    $this
      ->assertSession()
      ->responseContains('test@example.com');
    $this
      ->assertSession()
      ->responseContains('drupal.org');
    $this
      ->assertSession()
      ->pageTextContains('0.1');
    $this
      ->assertSession()
      ->pageTextContains('0.2');
    $this
      ->assertSession()
      ->responseContains('+31612345678');
    $this
      ->assertSession()
      ->responseContains('+31612345679');
    $this
      ->assertSession()
      ->pageTextContains('Test Article - New title');
    $this
      ->assertSession()
      ->pageTextContains('test.txt');
    $this
      ->assertSession()
      ->pageTextContains('druplicon.small');
    $this
      ->assertSession()
      ->responseContains('General discussion');
    $this
      ->assertSession()
      ->pageTextContains('Test Article - New title');
    $this
      ->assertSession()
      ->pageTextContains('Test 1');
    $this
      ->assertSession()
      ->responseContains('0.01');
    $this
      ->drupalGet('node/8/edit');
    $this
      ->submitForm([], 'Save (this translation)');
    $this
      ->assertSession()
      ->statusCodeEquals(200);
    $this
      ->drupalGet('node/8/edit', [
      'language' => $spanish,
    ]);
    $this
      ->assertSession()
      ->pageTextContains('Test title Spanish');
    $this
      ->assertSession()
      ->pageTextContains('Test body Spanish');

    // Make sure the user page is correct.
    $this
      ->drupalGet('user/3');
    $this
      ->assertSession()
      ->pageTextContains('usuario_test');
    $this
      ->assertSession()
      ->responseContains('druplicon.small');
    $this
      ->assertSession()
      ->pageTextContains('Test file field');
    $this
      ->assertSession()
      ->linkExists('test.txt');

    // Make sure the user is translated.
    $this
      ->drupalGet('user/3/translations');
    $this
      ->assertSession()
      ->pageTextNotContains('Not translated');

    // Make sure the custom field on the user is still there.
    $this
      ->drupalGet('admin/config/people/accounts/fields');
    $this
      ->assertSession()
      ->pageTextContains('Test file field');

    // Make sure the test view still exists.
    $this
      ->drupalGet('admin/structure/views/view/test_view');
    $this
      ->assertSession()
      ->pageTextContains('Test view');

    // Make sure the book node exists.
    $this
      ->drupalGet('admin/structure/book');
    $this
      ->clickLink('Test Article - New title');
    $this
      ->assertSession()
      ->pageTextContains('Body');
    $this
      ->assertSession()
      ->pageTextContains('Tags');
    $this
      ->assertSession()
      ->responseContains('Text format');

    // Make sure that users still exist.
    $this
      ->drupalGet('admin/people');
    $this
      ->assertSession()
      ->pageTextContains('usuario_test');
    $this
      ->assertSession()
      ->pageTextContains('drupal');
    $this
      ->drupalGet('user/1/edit');
    $this
      ->assertSession()
      ->responseContains('drupal@example.com');

    // Make sure the content view works.
    $this
      ->drupalGet('admin/content');
    $this
      ->assertSession()
      ->pageTextContains('Test title');

    // Make sure our custom blocks show up.
    $this
      ->drupalGet('admin/structure/block');
    $this
      ->assertSession()
      ->pageTextContains('Another block');
    $this
      ->assertSession()
      ->pageTextContains('Test block');
    $this
      ->drupalGet('admin/structure/block/block-content');
    $this
      ->assertSession()
      ->pageTextContains('Another block');
    $this
      ->assertSession()
      ->pageTextContains('Test block');

    // Make sure our custom visibility conditions are correct.
    $this
      ->drupalGet('admin/structure/block/manage/testblock');
    $this
      ->assertSession()
      ->checkboxNotChecked('edit-visibility-language-langcodes-es');
    $this
      ->assertSession()
      ->checkboxChecked('edit-visibility-language-langcodes-en');
    $this
      ->assertSession()
      ->checkboxNotChecked('edit-visibility-entity-bundlenode-bundles-book');
    $this
      ->assertSession()
      ->checkboxChecked('edit-visibility-entity-bundlenode-bundles-test-content-type');

    // Make sure our block is still translated.
    $this
      ->drupalGet('admin/structure/block/manage/testblock/translate/es/edit');
    $this
      ->assertSession()
      ->responseContains('Test block spanish');

    // Make sure our custom text format exists.
    $this
      ->drupalGet('admin/config/content/formats');
    $this
      ->assertSession()
      ->pageTextContains('Test text format');
    $this
      ->drupalGet('admin/config/content/formats/manage/test_text_format');
    $this
      ->assertSession()
      ->statusCodeEquals(200);

    // Make sure our feed still exists.
    $this
      ->drupalGet('admin/config/services/aggregator');
    $this
      ->assertSession()
      ->pageTextContains('Test feed');
    $this
      ->drupalGet('admin/config/services/aggregator/fields');
    $this
      ->assertSession()
      ->pageTextContains('field_test');

    // Make sure our view appears in the overview.
    $this
      ->drupalGet('admin/structure/views');
    $this
      ->assertSession()
      ->pageTextContains('test_view');
    $this
      ->assertSession()
      ->pageTextContains('Test view');

    // Make sure our custom forum exists.
    $this
      ->drupalGet('admin/structure/forum');
    $this
      ->assertSession()
      ->pageTextContains('Test forum');

    // Make sure our custom menu exists.
    $this
      ->drupalGet('admin/structure/menu');
    $this
      ->assertSession()
      ->pageTextContains('Test menu');

    // Make sure our custom menu exists.
    $this
      ->drupalGet('admin/structure/menu/manage/test-menu');
    $this
      ->clickLink('Admin');

    // Make sure the translation for the menu is still correct.
    $this
      ->drupalGet('admin/structure/menu/manage/test-menu/translate/es/edit');
    $this
      ->assertSession()
      ->responseContains('Menu test');

    // Make sure our custom menu link exists.
    $this
      ->drupalGet('admin/structure/menu/item/1/edit');
    $this
      ->assertSession()
      ->checkboxChecked('edit-enabled-value');

    // Make sure our comment type exists.
    $this
      ->drupalGet('admin/structure/comment');
    $this
      ->assertSession()
      ->pageTextContains('Test comment type');
    $this
      ->drupalGet('admin/structure/comment/manage/test_comment_type/fields');
    $this
      ->assertSession()
      ->pageTextContains('comment_body');

    // Make sure our contact form exists.
    $this
      ->drupalGet('admin/structure/contact');
    $this
      ->assertSession()
      ->pageTextContains('Test contact form');
    $this
      ->drupalGet('admin/structure/types');
    $this
      ->assertSession()
      ->pageTextContains('Test content type description');
    $this
      ->drupalGet('admin/structure/types/manage/test_content_type/fields');

    // Make sure fields are the right type.
    $this
      ->assertSession()
      ->linkExists('Text (formatted, long, with summary)');
    $this
      ->assertSession()
      ->linkExists('Boolean');
    $this
      ->assertSession()
      ->linkExists('Comments');
    $this
      ->assertSession()
      ->linkExists('Date');
    $this
      ->assertSession()
      ->linkExists('Email');
    $this
      ->assertSession()
      ->linkExists('Link');
    $this
      ->assertSession()
      ->linkExists('List (float)');
    $this
      ->assertSession()
      ->linkExists('Telephone number');
    $this
      ->assertSession()
      ->linkExists('Entity reference');
    $this
      ->assertSession()
      ->linkExists('File');
    $this
      ->assertSession()
      ->linkExists('Image');
    $this
      ->assertSession()
      ->linkExists('Text (plain, long)');
    $this
      ->assertSession()
      ->linkExists('List (text)');
    $this
      ->assertSession()
      ->linkExists('Text (formatted, long)');
    $this
      ->assertSession()
      ->linkExists('Text (plain)');
    $this
      ->assertSession()
      ->linkExists('List (integer)');
    $this
      ->assertSession()
      ->linkExists('Number (integer)');
    $this
      ->assertSession()
      ->linkExists('Number (float)');

    // Make sure our form mode exists.
    $this
      ->drupalGet('admin/structure/display-modes/form');
    $this
      ->assertSession()
      ->pageTextContains('New form mode');

    // Make sure our view mode exists.
    $this
      ->drupalGet('admin/structure/display-modes/view');
    $this
      ->assertSession()
      ->pageTextContains('New view mode');
    $this
      ->drupalGet('admin/structure/display-modes/view/manage/node.new_view_mode');
    $this
      ->assertSession()
      ->statusCodeEquals(200);

    // Make sure our other language is still there.
    $this
      ->drupalGet('admin/config/regional/language');
    $this
      ->assertSession()
      ->pageTextContains('Spanish');

    // Make sure our custom date format exists.
    $this
      ->drupalGet('admin/config/regional/date-time');
    $this
      ->assertSession()
      ->pageTextContains('Test date format');
    $this
      ->drupalGet('admin/config/regional/date-time/formats/manage/test_date_format');
    $this
      ->assertTrue($this
      ->assertSession()
      ->optionExists('edit-langcode', 'es')
      ->isSelected());

    // Make sure our custom image style exists.
    $this
      ->drupalGet('admin/config/media/image-styles/manage/test_image_style');
    $this
      ->assertSession()
      ->pageTextContains('Test image style');
    $this
      ->assertSession()
      ->pageTextContains('Desaturate');
    $this
      ->assertSession()
      ->pageTextContains('Convert PNG');

    // Make sure our custom responsive image style exists.
    $this
      ->drupalGet('admin/config/media/responsive-image-style/test');
    $this
      ->assertSession()
      ->statusCodeEquals(200);
    $this
      ->assertSession()
      ->pageTextContains('Test');

    // Make sure our custom shortcut exists.
    $this
      ->drupalGet('admin/config/user-interface/shortcut');
    $this
      ->assertSession()
      ->pageTextContains('Test shortcut');
    $this
      ->drupalGet('admin/config/user-interface/shortcut/manage/test/customize');
    $this
      ->assertSession()
      ->pageTextContains('All content');

    // Make sure our language detection settings are still correct.
    $this
      ->drupalGet('admin/config/regional/language/detection');
    $this
      ->assertSession()
      ->checkboxChecked('edit-language-interface-enabled-language-user-admin');
    $this
      ->assertSession()
      ->checkboxChecked('edit-language-interface-enabled-language-url');
    $this
      ->assertSession()
      ->checkboxChecked('edit-language-interface-enabled-language-session');
    $this
      ->assertSession()
      ->checkboxChecked('edit-language-interface-enabled-language-user');
    $this
      ->assertSession()
      ->checkboxChecked('edit-language-interface-enabled-language-browser');

    // Make sure strings are still translated.
    $this
      ->drupalGet('admin/structure/views/view/content/translate/es/edit');

    // cSpell:disable-next-line
    $this
      ->assertSession()
      ->pageTextContains('Contenido');
    $this
      ->drupalGet('admin/config/regional/translate');
    $this
      ->submitForm([
      'string' => 'Full comment',
    ], 'Filter');

    // cSpell:disable-next-line
    $this
      ->assertSession()
      ->pageTextContains('Comentario completo');

    // Make sure our custom action is still there.
    $this
      ->drupalGet('admin/config/system/actions');
    $this
      ->assertSession()
      ->pageTextContains('Test action');
    $this
      ->drupalGet('admin/config/system/actions/configure/test_action');
    $this
      ->assertSession()
      ->fieldValueEquals('id', 'test_action');
    $this
      ->assertSession()
      ->responseContains('drupal.org');

    // Make sure our ban still exists.
    $this
      ->drupalGet('admin/config/people/ban');
    $this
      ->assertSession()
      ->pageTextContains('8.8.8.8');

    // Make sure our vocabulary exists.
    $this
      ->drupalGet('admin/structure/taxonomy/manage/test_vocabulary/overview');

    // Make sure our terms exist.
    $this
      ->assertSession()
      ->pageTextContains('Test root term');
    $this
      ->assertSession()
      ->pageTextContains('Test child term');
    $this
      ->drupalGet('taxonomy/term/3');
    $this
      ->assertSession()
      ->statusCodeEquals(200);

    // Make sure the terms are still translated.
    $this
      ->drupalGet('taxonomy/term/2/translations');
    $this
      ->assertSession()
      ->linkExists('Test root term - Spanish');

    // Make sure our contact form exists.
    $this
      ->drupalGet('admin/structure/contact');
    $this
      ->assertSession()
      ->pageTextContains('Test contact form');
    $this
      ->drupalGet('admin/structure/contact/manage/test_contact_form');
    $this
      ->assertSession()
      ->pageTextContains('test@example.com');
    $this
      ->assertSession()
      ->pageTextContains('Hello');
    $this
      ->drupalGet('admin/structure/contact/manage/test_contact_form/translate/es/edit');
    $this
      ->assertSession()
      ->pageTextContains('Hola');
    $this
      ->assertSession()
      ->responseContains('Test contact form Spanish');

    // Make sure our modules are still enabled.
    $expected_enabled_modules = [
      'action',
      'aggregator',
      'ban',
      'basic_auth',
      'block',
      'block_content',
      'book',
      'breakpoint',
      'ckeditor',
      'color',
      'comment',
      'config',
      'config_translation',
      'contact',
      'content_translation',
      'contextual',
      'datetime',
      'dblog',
      'editor',
      'field',
      'field_ui',
      'file',
      'filter',
      'hal',
      'help',
      'history',
      'image',
      'language',
      'link',
      'locale',
      'menu_ui',
      'migrate',
      'migrate_drupal',
      'node',
      'options',
      'page_cache',
      'path',
      'quickedit',
      'rdf',
      'responsive_image',
      'rest',
      'search',
      'serialization',
      'shortcut',
      'statistics',
      'syslog',
      'system',
      'taxonomy',
      'telephone',
      'text',
      'toolbar',
      'tour',
      'tracker',
      'update',
      'user',
      'views_ui',
      'forum',
      'menu_link_content',
      'views',
      'standard',
    ];
    foreach ($expected_enabled_modules as $module) {
      $this
        ->assertTrue($this->container
        ->get('module_handler')
        ->moduleExists($module), 'The "' . $module . '" module is still enabled.');
    }

    // Make sure our themes are still enabled.
    $expected_enabled_themes = [
      'bartik',
      'seven',
      'stark',
    ];
    foreach ($expected_enabled_themes as $theme) {
      $this
        ->assertTrue($this->container
        ->get('theme_handler')
        ->themeExists($theme), 'The "' . $theme . '" is still enabled.');
    }

    // Ensure that the Book module's node type does not have duplicated enforced
    // dependencies.
    // @see system_post_update_fix_enforced_dependencies()
    $book_node_type = NodeType::load('book');
    $this
      ->assertEquals([
      'enforced' => [
        'module' => [
          'book',
        ],
      ],
    ], $book_node_type
      ->get('dependencies'));
  }

  /**
   * {@inheritdoc}
   */
  protected function replaceUser1() {

    // Do not replace the user from our dump.
  }

}

Members

Namesort descending Modifiers Type Description Overrides
AssertLegacyTrait::assert Deprecated protected function
AssertLegacyTrait::assertCacheTag Deprecated protected function Asserts whether an expected cache tag was present in the last response.
AssertLegacyTrait::assertElementNotPresent Deprecated protected function Asserts that the element with the given CSS selector is not present.
AssertLegacyTrait::assertElementPresent Deprecated protected function Asserts that the element with the given CSS selector is present.
AssertLegacyTrait::assertEqual Deprecated protected function
AssertLegacyTrait::assertEscaped Deprecated protected function Passes if the raw text IS found escaped on the loaded page, fail otherwise.
AssertLegacyTrait::assertField Deprecated protected function Asserts that a field exists with the given name or ID.
AssertLegacyTrait::assertFieldById Deprecated protected function Asserts that a field exists with the given ID and value.
AssertLegacyTrait::assertFieldByName Deprecated protected function Asserts that a field exists with the given name and value.
AssertLegacyTrait::assertFieldByXPath Deprecated protected function Asserts that a field exists in the current page by the given XPath.
AssertLegacyTrait::assertFieldChecked Deprecated protected function Asserts that a checkbox field in the current page is checked.
AssertLegacyTrait::assertFieldsByValue Deprecated protected function Asserts that a field exists in the current page with a given Xpath result.
AssertLegacyTrait::assertHeader Deprecated protected function Checks that current response header equals value.
AssertLegacyTrait::assertIdentical Deprecated protected function
AssertLegacyTrait::assertIdenticalObject Deprecated protected function
AssertLegacyTrait::assertLink Deprecated protected function Passes if a link with the specified label is found.
AssertLegacyTrait::assertLinkByHref Deprecated protected function Passes if a link containing a given href (part) is found.
AssertLegacyTrait::assertNoCacheTag Deprecated protected function Asserts whether an expected cache tag was absent in the last response.
AssertLegacyTrait::assertNoEscaped Deprecated protected function Passes if the raw text is not found escaped on the loaded page.
AssertLegacyTrait::assertNoField Deprecated protected function Asserts that a field does NOT exist with the given name or ID.
AssertLegacyTrait::assertNoFieldById Deprecated protected function Asserts that a field does not exist with the given ID and value.
AssertLegacyTrait::assertNoFieldByName Deprecated protected function Asserts that a field does not exist with the given name and value.
AssertLegacyTrait::assertNoFieldByXPath Deprecated protected function Asserts that a field does not exist or its value does not match, by XPath.
AssertLegacyTrait::assertNoFieldChecked Deprecated protected function Asserts that a checkbox field in the current page is not checked.
AssertLegacyTrait::assertNoLink Deprecated protected function Passes if a link with the specified label is not found.
AssertLegacyTrait::assertNoLinkByHref Deprecated protected function Passes if a link containing a given href (part) is not found.
AssertLegacyTrait::assertNoOption Deprecated protected function Asserts that a select option does NOT exist in the current page.
AssertLegacyTrait::assertNoPattern Deprecated protected function Triggers a pass if the Perl regex pattern is not found in the raw content.
AssertLegacyTrait::assertNoRaw Deprecated protected function Passes if the raw text IS not found on the loaded page, fail otherwise.
AssertLegacyTrait::assertNotEqual Deprecated protected function
AssertLegacyTrait::assertNoText Deprecated protected function Passes if the page (with HTML stripped) does not contains the text.
AssertLegacyTrait::assertNotIdentical Deprecated protected function
AssertLegacyTrait::assertNoUniqueText Deprecated protected function Passes if the text is found MORE THAN ONCE on the text version of the page.
AssertLegacyTrait::assertOption Deprecated protected function Asserts that a select option in the current page exists.
AssertLegacyTrait::assertOptionByText Deprecated protected function Asserts that a select option with the visible text exists.
AssertLegacyTrait::assertOptionSelected Deprecated protected function Asserts that a select option in the current page is checked.
AssertLegacyTrait::assertPattern Deprecated protected function Triggers a pass if the Perl regex pattern is found in the raw content.
AssertLegacyTrait::assertRaw Deprecated protected function Passes if the raw text IS found on the loaded page, fail otherwise.
AssertLegacyTrait::assertResponse Deprecated protected function Asserts the page responds with the specified response code.
AssertLegacyTrait::assertText Deprecated protected function Passes if the page (with HTML stripped) contains the text.
AssertLegacyTrait::assertTextHelper Deprecated protected function Helper for assertText and assertNoText.
AssertLegacyTrait::assertTitle Deprecated protected function Pass if the page title is the given string.
AssertLegacyTrait::assertUniqueText Deprecated protected function Passes if the text is found ONLY ONCE on the text version of the page.
AssertLegacyTrait::assertUrl Deprecated protected function Passes if the internal browser's URL matches the given path.
AssertLegacyTrait::buildXPathQuery Deprecated protected function Builds an XPath query.
AssertLegacyTrait::constructFieldXpath Deprecated protected function Helper: Constructs an XPath for the given set of attributes and value.
AssertLegacyTrait::getAllOptions Deprecated protected function Get all option elements, including nested options, in a select.
AssertLegacyTrait::getRawContent Deprecated protected function Gets the current raw content.
AssertLegacyTrait::pass Deprecated protected function
AssertLegacyTrait::verbose Deprecated 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::getResponseLogHandler protected function Provides a Guzzle middleware handler to log every response received.
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 Mink default driver params.
BrowserTestBase::$minkDefaultDriverClass protected property Mink class for the default driver to use. 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::drupalGetHeader Deprecated protected function Gets the value of an HTTP response header.
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::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::initMink protected function Initializes Mink sessions. 1
BrowserTestBase::registerSessions protected function Registers additional Mink sessions.
BrowserTestBase::setUpAppRoot protected function Sets up the root application path.
BrowserTestBase::setUpBeforeClass public static function 1
BrowserTestBase::tearDown protected function 3
BrowserTestBase::translatePostValues protected function Transforms a nested array into a flat array suitable for submitForm().
BrowserTestBase::xpath protected function Performs an xpath search on the contents of the internal browser.
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
ExtensionListTestTrait::getModulePath protected function Gets the path for the specified module.
ExtensionListTestTrait::getThemePath protected function Gets the path for the specified theme.
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::$rootUser protected property The "#1" admin user.
FunctionalTestSetupTrait::getDatabaseTypes protected function Returns all supported database driver installer objects.
FunctionalTestSetupTrait::initConfig protected function Initialize various configurations post-installation. 1
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. 20
FunctionalTestSetupTrait::prepareRequestForGenerator protected function Creates a mock request and sets it on the generator.
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. 1
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
PhpUnitWarnings::$deprecationWarnings private static property Deprecation warnings from PHPUnit to raise with @trigger_error().
PhpUnitWarnings::addWarning public function Converts PHPUnit deprecation warnings to E_USER_DEPRECATED.
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. 1
RequirementsPageTrait::assertWarningSummaries protected function Assert the given warning summaries are present on the page.
RequirementsPageTrait::continueOnExpectedWarnings protected function Continues installation when the expected warnings are found.
RequirementsPageTrait::updateRequirementsProblem protected function Handles the update requirements page.
SchemaCheckTestTrait::assertConfigSchema public function Asserts the TypedConfigManager has a valid schema for the configuration.
SchemaCheckTestTrait::assertConfigSchemaByName public function Asserts configuration, specified by name, has a valid schema.
SchemaCheckTrait::$configName protected property The configuration object name under test.
SchemaCheckTrait::$schema protected property The config schema wrapper object for the configuration object under test.
SchemaCheckTrait::checkConfigSchema public function Checks the TypedConfigManager has a valid schema for the configuration.
SchemaCheckTrait::checkValue protected function Helper method to check data type.
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::$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. 1
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 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::cssSelectToXpath protected function Translates a CSS expression to its XPath equivalent.
UiHelperTrait::drupalGet protected function Retrieves a Drupal path or an absolute path. 2
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 Deprecated 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::isTestUsingGuzzleClient protected function Determines if test is using DrupalTestBrowser.
UiHelperTrait::prepareRequest protected function Prepare for a request to testing site. 1
UiHelperTrait::submitForm protected function Fills and submits a form.
UpdatePathTestBase::$databaseDumpFiles protected property The file path(s) to the dumped database(s) to load into the child site.
UpdatePathTestBase::$loadedModules protected property Array of modules loaded when the test starts.
UpdatePathTestBase::$pendingUpdates protected property Flag to indicate whether there are pending updates or not.
UpdatePathTestBase::$strictConfigSchema protected property Disable strict config schema checking. Overrides TestSetupTrait::$strictConfigSchema
UpdatePathTestBase::$updateUrl protected property The update URL.
UpdatePathTestBase::$upgradedSite protected property Flag that indicates whether the child site has been updated.
UpdatePathTestBase::$upgradeErrors protected property Array of errors triggered during the update process.
UpdatePathTestBase::$zlibInstalled protected property Flag to indicate whether zlib is installed or not.
UpdatePathTestBase::doInstall protected function Execute the non-interactive installer. Overrides FunctionalTestSetupTrait::doInstall
UpdatePathTestBase::initFrontPage protected function Visits the front page when initializing Mink. Overrides BrowserTestBase::initFrontPage
UpdatePathTestBase::installDrupal public function Installs Drupal into the Simpletest site. Overrides BrowserTestBase::installDrupal
UpdatePathTestBase::prepareSettings protected function Add settings that are missed since the installer isn't run. Overrides FunctionalTestSetupTrait::prepareSettings
UpdatePathTestBase::runDbTasks protected function Runs the install database tasks for the driver used by the test runner.
UpdatePathTestBase::runUpdates protected function Helper function to run pending database updates.
UpdatePathTestBase::setUp protected function Overrides BrowserTestBase::setUp() for update testing. Overrides BrowserTestBase::setUp
UpdatePathTestBaseFilledTest::$defaultTheme protected property The theme to install as the default for testing. Overrides BrowserTestBase::$defaultTheme
UpdatePathTestBaseFilledTest::replaceUser1 protected function Replace User 1 with the user created here. Overrides UpdatePathTestBase::replaceUser1
UpdatePathTestBaseFilledTest::setDatabaseDumpFiles protected function Set database dump files to be used. Overrides UpdatePathTestBaseTest::setDatabaseDumpFiles
UpdatePathTestBaseFilledTest::testUpdatedSite public function Tests that the content and configuration were properly updated.
UpdatePathTestBaseTest::$modules protected static property Modules to enable after the database is loaded. Overrides UpdatePathTestBase::$modules
UpdatePathTestBaseTest::testDatabaseLoaded public function Tests that the database was properly loaded.
UpdatePathTestBaseTest::testFixturesSetup public function Tests the database fixtures are setup correctly.
UpdatePathTestBaseTest::testModuleListChange public function Tests that test running environment is updated when module list changes.
UpdatePathTestBaseTest::testPathAliasProcessing public function Tests that path aliases are not processed during database updates.
UpdatePathTestBaseTest::testSchemaChecking public function Tests that schema can be excluded from testing.
UpdatePathTestBaseTest::testUpdateHookN public function Tests that updates are properly run.
UpdatePathTestTrait::$checkFailedUpdates protected property Fail the test if there are failed updates.
UpdatePathTestTrait::doSelectionTest protected function Tests the selection page. 3
UpdatePathTestTrait::ensureUpdatesToRun protected function Installs the update_script_test module and makes an update available.
UpdatePathTestTrait::runUpdates protected function Helper function to run pending database updates. Aliased as: doRunUpdates
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.