trait CommentTestTrait in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/modules/comment/src/Tests/CommentTestTrait.php \Drupal\comment\Tests\CommentTestTrait
Provides common functionality for the Comment test classes.
Hierarchy
- trait \Drupal\comment\Tests\CommentTestTrait
27 files declare their use of CommentTestTrait
- CommentTestBase.php in core/
modules/ comment/ src/ Tests/ Views/ CommentTestBase.php - Contains \Drupal\comment\Tests\Views\CommentTestBase.
- ContentTranslationSettingsTest.php in core/
modules/ content_translation/ src/ Tests/ ContentTranslationSettingsTest.php - Contains \Drupal\content_translation\Tests\ContentTranslationSettingsTest.
- CreateTest.php in core/
modules/ rest/ src/ Tests/ CreateTest.php - Contains \Drupal\rest\Tests\CreateTest.
- DefaultViewRecentCommentsTest.php in core/
modules/ comment/ src/ Tests/ Views/ DefaultViewRecentCommentsTest.php - Contains \Drupal\comment\Tests\Views\DefaultViewRecentCommentsTest.
- DefaultViewsTest.php in core/
modules/ views/ src/ Tests/ DefaultViewsTest.php - Contains \Drupal\views\Tests\DefaultViewsTest.
File
- core/
modules/ comment/ src/ Tests/ CommentTestTrait.php, line 16 - Contains \Drupal\comment\Tests\CommentTestTrait.
Namespace
Drupal\comment\TestsView source
trait CommentTestTrait {
/**
* Adds the default comment field to an entity.
*
* Attaches a comment field named 'comment' to the given entity type and
* bundle. Largely replicates the default behavior in Drupal 7 and earlier.
*
* @param string $entity_type
* The entity type to attach the default comment field to.
* @param string $bundle
* The bundle to attach the default comment field to.
* @param string $field_name
* (optional) Field name to use for the comment field. Defaults to
* 'comment'.
* @param int $default_value
* (optional) Default value, one of CommentItemInterface::HIDDEN,
* CommentItemInterface::OPEN, CommentItemInterface::CLOSED. Defaults to
* CommentItemInterface::OPEN.
* @param string $comment_type_id
* (optional) ID of comment type to use. Defaults to 'comment'.
*/
public function addDefaultCommentField($entity_type, $bundle, $field_name = 'comment', $default_value = CommentItemInterface::OPEN, $comment_type_id = 'comment') {
$entity_manager = \Drupal::entityManager();
// Create the comment type if needed.
$comment_type_storage = $entity_manager
->getStorage('comment_type');
if ($comment_type = $comment_type_storage
->load($comment_type_id)) {
if ($comment_type
->getTargetEntityTypeId() !== $entity_type) {
throw new \InvalidArgumentException("The given comment type id {$comment_type_id} can only be used with the {$entity_type} entity type");
}
}
else {
$comment_type_storage
->create(array(
'id' => $comment_type_id,
'label' => Unicode::ucfirst($comment_type_id),
'target_entity_type_id' => $entity_type,
'description' => 'Default comment field',
))
->save();
}
// Add a body field to the comment type.
\Drupal::service('comment.manager')
->addBodyField($comment_type_id);
// Add a comment field to the host entity type. Create the field storage if
// needed.
if (!array_key_exists($field_name, $entity_manager
->getFieldStorageDefinitions($entity_type))) {
$entity_manager
->getStorage('field_storage_config')
->create(array(
'entity_type' => $entity_type,
'field_name' => $field_name,
'type' => 'comment',
'translatable' => TRUE,
'settings' => array(
'comment_type' => $comment_type_id,
),
))
->save();
}
// Create the field if needed, and configure its form and view displays.
if (!array_key_exists($field_name, $entity_manager
->getFieldDefinitions($entity_type, $bundle))) {
$entity_manager
->getStorage('field_config')
->create(array(
'label' => 'Comments',
'description' => '',
'field_name' => $field_name,
'entity_type' => $entity_type,
'bundle' => $bundle,
'required' => 1,
'default_value' => array(
array(
'status' => $default_value,
'cid' => 0,
'last_comment_name' => '',
'last_comment_timestamp' => 0,
'last_comment_uid' => 0,
),
),
))
->save();
// Entity form displays: assign widget settings for the 'default' form
// mode, and hide the field in all other form modes.
entity_get_form_display($entity_type, $bundle, 'default')
->setComponent($field_name, array(
'type' => 'comment_default',
'weight' => 20,
))
->save();
foreach ($entity_manager
->getFormModes($entity_type) as $id => $form_mode) {
$display = entity_get_form_display($entity_type, $bundle, $id);
// Only update existing displays.
if ($display && !$display
->isNew()) {
$display
->removeComponent($field_name)
->save();
}
}
// Entity view displays: assign widget settings for the 'default' view
// mode, and hide the field in all other view modes.
entity_get_display($entity_type, $bundle, 'default')
->setComponent($field_name, array(
'label' => 'above',
'type' => 'comment_default',
'weight' => 20,
))
->save();
foreach ($entity_manager
->getViewModes($entity_type) as $id => $view_mode) {
$display = entity_get_display($entity_type, $bundle, $id);
// Only update existing displays.
if ($display && !$display
->isNew()) {
$display
->removeComponent($field_name)
->save();
}
}
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
CommentTestTrait:: |
public | function | Adds the default comment field to an entity. |