class CommentFieldsTest in Drupal 10
Same name and namespace in other branches
- 8 core/modules/comment/tests/src/Functional/CommentFieldsTest.php \Drupal\Tests\comment\Functional\CommentFieldsTest
- 9 core/modules/comment/tests/src/Functional/CommentFieldsTest.php \Drupal\Tests\comment\Functional\CommentFieldsTest
Tests fields on comments.
@group comment
Hierarchy
- class \Drupal\Tests\BrowserTestBase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, FunctionalTestSetupTrait, TestSetupTrait, BlockCreationTrait, ConfigTestTrait, ExtensionListTestTrait, ContentTypeCreationTrait, NodeCreationTrait, RandomGeneratorTrait, TestRequirementsTrait, PhpUnitWarnings, UiHelperTrait, UserCreationTrait, XdebugRequestTrait
- class \Drupal\Tests\comment\Functional\CommentTestBase uses CommentTestTrait
- class \Drupal\Tests\comment\Functional\CommentFieldsTest
- class \Drupal\Tests\comment\Functional\CommentTestBase uses CommentTestTrait
Expanded class hierarchy of CommentFieldsTest
3 string references to 'CommentFieldsTest'
- drupal7.php in core/
modules/ tracker/ tests/ fixtures/ drupal7.php - A database agnostic dump for testing purposes.
- drupal7.php in core/
modules/ rdf/ tests/ fixtures/ drupal7.php - A database agnostic dump for testing purposes.
- drupal7.php in core/
modules/ migrate_drupal/ tests/ fixtures/ drupal7.php - A database agnostic dump for testing purposes.
File
- core/
modules/ comment/ tests/ src/ Functional/ CommentFieldsTest.php, line 16
Namespace
Drupal\Tests\comment\FunctionalView source
class CommentFieldsTest extends CommentTestBase {
/**
* Install the field UI.
*
* @var array
*/
protected static $modules = [
'field_ui',
];
/**
* {@inheritdoc}
*/
protected $defaultTheme = 'stark';
/**
* Tests that the default 'comment_body' field is correctly added.
*/
public function testCommentDefaultFields() {
// Do not make assumptions on default node types created by the test
// installation profile, and create our own.
$this
->drupalCreateContentType([
'type' => 'test_node_type',
]);
$this
->addDefaultCommentField('node', 'test_node_type');
// Check that the 'comment_body' field is present on the comment bundle.
$field = FieldConfig::loadByName('comment', 'comment', 'comment_body');
$this
->assertNotEmpty($field, 'The comment_body field is added when a comment bundle is created');
$field
->delete();
// Check that the 'comment_body' field is not deleted since it is persisted
// even if it has no fields.
$field_storage = FieldStorageConfig::loadByName('comment', 'comment_body');
$this
->assertInstanceOf(FieldStorageConfig::class, $field_storage);
// Create a new content type.
$type_name = 'test_node_type_2';
$this
->drupalCreateContentType([
'type' => $type_name,
]);
$this
->addDefaultCommentField('node', $type_name);
// Check that the 'comment_body' field exists and has an instance on the
// new comment bundle.
$field_storage = FieldStorageConfig::loadByName('comment', 'comment_body');
$this
->assertInstanceOf(FieldStorageConfig::class, $field_storage);
$field = FieldConfig::loadByName('comment', 'comment', 'comment_body');
$this
->assertTrue(isset($field), new FormattableMarkup('The comment_body field is present for comments on type @type', [
'@type' => $type_name,
]));
// Test adding a field that defaults to CommentItemInterface::CLOSED.
$this
->addDefaultCommentField('node', 'test_node_type', 'who_likes_ponies', CommentItemInterface::CLOSED, 'who_likes_ponies');
$field = FieldConfig::load('node.test_node_type.who_likes_ponies');
$this
->assertEquals(CommentItemInterface::CLOSED, $field
->getDefaultValueLiteral()[0]['status']);
}
/**
* Tests that you can remove a comment field.
*/
public function testCommentFieldDelete() {
$this
->drupalCreateContentType([
'type' => 'test_node_type',
]);
$this
->addDefaultCommentField('node', 'test_node_type');
// We want to test the handling of removing the primary comment field, so we
// ensure there is at least one other comment field attached to a node type
// so that comment_entity_load() runs for nodes.
$this
->addDefaultCommentField('node', 'test_node_type', 'comment2');
// Create a sample node.
$node = $this
->drupalCreateNode([
'title' => 'Baloney',
'type' => 'test_node_type',
]);
$this
->drupalLogin($this->webUser);
$this
->drupalGet('node/' . $node->nid->value);
$elements = $this
->cssSelect('.comment-form');
$this
->assertCount(2, $elements, 'There are two comment fields on the node.');
// Delete the first comment field.
FieldStorageConfig::loadByName('node', 'comment')
->delete();
$this
->drupalGet('node/' . $node->nid->value);
$elements = $this
->cssSelect('.comment-form');
$this
->assertCount(1, $elements, 'There is one comment field on the node.');
}
/**
* Tests link building with non-default comment field names.
*/
public function testCommentFieldLinksNonDefaultName() {
$this
->drupalCreateContentType([
'type' => 'test_node_type',
]);
$this
->addDefaultCommentField('node', 'test_node_type', 'comment2');
$web_user2 = $this
->drupalCreateUser([
'access comments',
'post comments',
'create article content',
'edit own comments',
'skip comment approval',
'access content',
]);
// Create a sample node.
$node = $this
->drupalCreateNode([
'title' => 'Baloney',
'type' => 'test_node_type',
]);
// Go to the node first so that webuser2 see new comments.
$this
->drupalLogin($web_user2);
$this
->drupalGet($node
->toUrl());
$this
->drupalLogout();
// Test that buildCommentedEntityLinks() does not break when the 'comment'
// field does not exist. Requires at least one comment.
$this
->drupalLogin($this->webUser);
$this
->postComment($node, 'Here is a comment', '', NULL, 'comment2');
$this
->drupalLogout();
$this
->drupalLogin($web_user2);
// We want to check the attached drupalSettings of
// \Drupal\comment\CommentLinkBuilder::buildCommentedEntityLinks. Therefore
// we need a node listing, let's use views for that.
$this->container
->get('module_installer')
->install([
'views',
], TRUE);
$this
->drupalGet('node');
$link_info = $this
->getDrupalSettings()['comment']['newCommentsLinks']['node']['comment2']['2'];
$this
->assertSame(1, $link_info['new_comment_count']);
$this
->assertSame($node
->toUrl('canonical', [
'fragment' => 'new',
])
->toString(), $link_info['first_new_comment_link']);
}
/**
* Tests creating a comment field through the interface.
*/
public function testCommentFieldCreate() {
// Create user who can administer user fields.
$user = $this
->drupalCreateUser([
'administer user fields',
]);
$this
->drupalLogin($user);
// Create comment field in account settings.
$edit = [
'new_storage_type' => 'comment',
'label' => 'User comment',
'field_name' => 'user_comment',
];
$this
->drupalGet('admin/config/people/accounts/fields/add-field');
$this
->submitForm($edit, 'Save and continue');
// Try to save the comment field without selecting a comment type.
$edit = [];
$this
->drupalGet('admin/config/people/accounts/fields/user.user.field_user_comment/storage');
$this
->submitForm($edit, 'Save field settings');
// We should get an error message.
$this
->assertSession()
->pageTextContains('An illegal choice has been detected. Please contact the site administrator.');
// Create a comment type for users.
$bundle = CommentType::create([
'id' => 'user_comment_type',
'label' => 'user_comment_type',
'description' => '',
'target_entity_type_id' => 'user',
]);
$bundle
->save();
// Select a comment type and try to save again.
$edit = [
'settings[comment_type]' => 'user_comment_type',
];
$this
->drupalGet('admin/config/people/accounts/fields/user.user.field_user_comment/storage');
$this
->submitForm($edit, 'Save field settings');
// We shouldn't get an error message.
$this
->assertSession()
->pageTextNotContains('An illegal choice has been detected. Please contact the site administrator.');
}
/**
* Tests that comment module works when installed after a content module.
*/
public function testCommentInstallAfterContentModule() {
// Create a user to do module administration.
$this->adminUser = $this
->drupalCreateUser([
'access administration pages',
'administer modules',
]);
$this
->drupalLogin($this->adminUser);
// Drop default comment field added in CommentTestBase::setUp().
FieldStorageConfig::loadByName('node', 'comment')
->delete();
if ($field_storage = FieldStorageConfig::loadByName('node', 'comment_forum')) {
$field_storage
->delete();
}
// Purge field data now to allow comment module to be uninstalled once the
// field has been deleted.
field_purge_batch(10);
// Uninstall the comment module.
$edit = [];
$edit['uninstall[comment]'] = TRUE;
$this
->drupalGet('admin/modules/uninstall');
$this
->submitForm($edit, 'Uninstall');
$this
->submitForm([], 'Uninstall');
$this
->rebuildContainer();
$this
->assertFalse($this->container
->get('module_handler')
->moduleExists('comment'), 'Comment module uninstalled.');
// Install core content type module (book).
$edit = [];
$edit['modules[book][enable]'] = 'book';
$this
->drupalGet('admin/modules');
$this
->submitForm($edit, 'Install');
// Now install the comment module.
$edit = [];
$edit['modules[comment][enable]'] = 'comment';
$this
->drupalGet('admin/modules');
$this
->submitForm($edit, 'Install');
$this
->rebuildContainer();
$this
->assertTrue($this->container
->get('module_handler')
->moduleExists('comment'), 'Comment module enabled.');
// Create nodes of each type.
$this
->addDefaultCommentField('node', 'book');
$book_node = $this
->drupalCreateNode([
'type' => 'book',
]);
$this
->drupalLogout();
// Try to post a comment on each node. A failure will be triggered if the
// comment body is missing on one of these forms, due to postComment()
// asserting that the body is actually posted correctly.
$this->webUser = $this
->drupalCreateUser([
'access content',
'access comments',
'post comments',
'skip comment approval',
]);
$this
->drupalLogin($this->webUser);
$this
->postComment($book_node, $this
->randomMachineName(), $this
->randomMachineName());
}
}