FieldTestBase.php
Same filename in this branch
Same filename in other branches
- 9 core/modules/field/tests/src/Functional/Views/FieldTestBase.php
- 9 core/modules/field/tests/src/Functional/FieldTestBase.php
- 8.9.x core/modules/field/src/Tests/Views/FieldTestBase.php
- 8.9.x core/modules/field/src/Tests/FieldTestBase.php
- 8.9.x core/modules/field/tests/src/Functional/Views/FieldTestBase.php
- 8.9.x core/modules/field/tests/src/Functional/FieldTestBase.php
- 11.x core/modules/field/tests/src/Functional/Views/FieldTestBase.php
- 11.x core/modules/field/tests/src/Functional/FieldTestBase.php
Namespace
Drupal\Tests\field\Functional\ViewsFile
-
core/
modules/ field/ tests/ src/ Functional/ Views/ FieldTestBase.php
View source
<?php
declare (strict_types=1);
namespace Drupal\Tests\field\Functional\Views;
use Drupal\field\Entity\FieldConfig;
use Drupal\node\Entity\NodeType;
use Drupal\Tests\views\Functional\ViewTestBase;
use Drupal\field\Entity\FieldStorageConfig;
/**
* Provides some helper methods for testing fieldapi integration into views.
*
* @todo Test on a generic entity not on a node. What has to be tested:
* - Make sure that every wanted field is added to the according entity type.
* - Make sure the joins are done correctly.
* - Use basic fields and make sure that the full wanted object is built.
* - Use relationships between different entity types, for example node and
* the node author(user).
*/
abstract class FieldTestBase extends ViewTestBase {
/**
* {@inheritdoc}
*/
protected static $modules = [
'node',
'field_test_views',
];
/**
* Stores the field definitions used by the test.
*
* @var array
*/
public $fieldStorages;
/**
* Stores the fields of the field storage.
*
* @var array
*/
public $fields;
/**
* {@inheritdoc}
*/
protected function setUp($import_test_views = TRUE, $modules = [
'field_test_views',
]) : void {
parent::setUp($import_test_views, $modules);
// Ensure the page node type exists.
NodeType::create([
'type' => 'page',
'name' => 'page',
])->save();
}
public function setUpFieldStorages($amount = 3, $type = 'string') {
// Create three fields.
$field_names = [];
for ($i = 0; $i < $amount; $i++) {
$field_names[$i] = 'field_name_' . $i;
$this->fieldStorages[$i] = FieldStorageConfig::create([
'field_name' => $field_names[$i],
'entity_type' => 'node',
'type' => $type,
]);
$this->fieldStorages[$i]
->save();
}
return $field_names;
}
public function setUpFields($bundle = 'page') {
foreach ($this->fieldStorages as $key => $field_storage) {
$this->fields[$key] = FieldConfig::create([
'field_storage' => $field_storage,
'bundle' => $bundle,
]);
$this->fields[$key]
->save();
}
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
FieldTestBase | Provides some helper methods for testing fieldapi integration into views. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.