public function FieldTestBase::assertFieldValues in Drupal 8
Same name in this branch
- 8 core/modules/field/src/Tests/FieldTestBase.php \Drupal\field\Tests\FieldTestBase::assertFieldValues()
- 8 core/modules/field/tests/src/Functional/FieldTestBase.php \Drupal\Tests\field\Functional\FieldTestBase::assertFieldValues()
Assert that a field has the expected values in an entity.
This function only checks a single column in the field values.
Parameters
\Drupal\Core\Entity\EntityInterface $entity: The entity to test.
$field_name: The name of the field to test
$expected_values: The array of expected values.
$langcode: (Optional) The language code for the values. Defaults to \Drupal\Core\Language\LanguageInterface::LANGCODE_DEFAULT.
$column: (Optional) The name of the column to check. Defaults to 'value'.
File
- core/
modules/ field/ src/ Tests/ FieldTestBase.php, line 57
Class
- FieldTestBase
- Parent class for Field API tests.
Namespace
Drupal\field\TestsCode
public function assertFieldValues(EntityInterface $entity, $field_name, $expected_values, $langcode = LanguageInterface::LANGCODE_DEFAULT, $column = 'value') {
// Re-load the entity to make sure we have the latest changes.
$storage = $this->container
->get('entity_type.manager')
->getStorage($entity
->getEntityTypeId());
$storage
->resetCache([
$entity
->id(),
]);
$e = $storage
->load($entity
->id());
$field = $values = $e
->getTranslation($langcode)->{$field_name};
// Filter out empty values so that they don't mess with the assertions.
$field
->filterEmptyItems();
$values = $field
->getValue();
$this
->assertEqual(count($values), count($expected_values), 'Expected number of values were saved.');
foreach ($expected_values as $key => $value) {
$this
->assertEqual($values[$key][$column], $value, new FormattableMarkup('Value @value was saved correctly.', [
'@value' => $value,
]));
}
}