class TestSiteClaroInstallTestScript

Same name in other branches
  1. 11.x core/tests/Drupal/TestSite/TestSiteClaroInstallTestScript.php \Drupal\TestSite\TestSiteClaroInstallTestScript

Setup file used by TestSiteInstallTestScript.

Hierarchy

Expanded class hierarchy of TestSiteClaroInstallTestScript

See also

\Drupal\Tests\Scripts\TestSiteApplicationTest

File

core/tests/Drupal/TestSite/TestSiteClaroInstallTestScript.php, line 17

Namespace

Drupal\TestSite
View source
class TestSiteClaroInstallTestScript implements TestSetupInterface {
    
    /**
     * {@inheritdoc}
     */
    public function setup() {
        // Install required module for the Olivero front page.
        $module_installer = \Drupal::service('module_installer');
        assert($module_installer instanceof ModuleInstallerInterface);
        $module_installer->install([
            'olivero_test',
        ]);
        // Install Claro instead of Olivero and set it as the default theme.
        $theme_installer = \Drupal::service('theme_installer');
        assert($theme_installer instanceof ThemeInstallerInterface);
        $theme_installer->install([
            'claro',
        ], TRUE);
        $system_theme_config = \Drupal::configFactory()->getEditable('system.theme');
        $system_theme_config->set('default', 'claro')
            ->save();
        // Create an article that will have no comments
        $article_no_comments = Node::create([
            'type' => 'article',
        ]);
        $article_no_comments->set('title', 'Article without comments');
        // Enable comments
        $article_no_comments->set('comment', 2);
        $article_no_comments->save();
        // Create an article that will have comments
        $article_with_comments = Node::create([
            'type' => 'article',
        ]);
        $article_with_comments->set('title', 'Article with comments');
        // Enable comments
        $article_with_comments->set('comment', 2);
        $article_with_comments->save();
        $values = [
            // These values are for the entity that you're creating the comment for, not the comment itself.
'entity_type' => 'node',
            'entity_id' => 2,
            'field_name' => 'comment',
            'uid' => 1,
            // These values are for the comment itself.
'comment_type' => 'comment',
            'subject' => 'A comment',
            'comment_body' => 'Body of comment',
            // Whether the comment is 'approved' or not.
'status' => 1,
        ];
        // Create comment entities out of our field values
        $comment1 = Comment::create($values);
        $comment1->save();
        $comment2 = Comment::create($values);
        $comment2->save();
    }

}

Members

Title Sort descending Modifiers Object type Summary Overriden Title
TestSiteClaroInstallTestScript::setup public function Overrides TestSetupInterface::setup

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.