function field_test_memorize
Same name in other branches
- 7.x modules/field/tests/field_test.module \field_test_memorize()
- 9 core/modules/field/tests/modules/field_test/field_test.module \field_test_memorize()
- 10 core/modules/field/tests/modules/field_test/field_test.module \field_test_memorize()
- 11.x core/modules/field/tests/modules/field_test/field_test.module \field_test_memorize()
Store and retrieve keyed data for later verification by unit tests.
This function is a simple in-memory key-value store with the distinction that it stores all values for a given key instead of just the most recently set value. field_test module hooks call this function to record their arguments, keyed by hook name. The unit tests later call this function to verify that the correct hooks were called and were passed the correct arguments.
This function ignores all calls until the first time it is called with $key of NULL. Each time it is called with $key of NULL, it erases all previously stored data from its internal cache, but also returns the previously stored data to the caller. A typical usage scenario is:
// calls to field_test_memorize() here are ignored
// turn on memorization
field_test_memorize();
// call some Field API functions that invoke field_test hooks
FieldStorageConfig::create($field_definition)->save();
// retrieve and reset the memorized hook call data
$mem = field_test_memorize();
// make sure hook_field_storage_config_create() is invoked correctly
assertEqual(count($mem['field_test_field_storage_config_create']), 1);
assertEqual($mem['field_test_field_storage_config_create'][0], array(
$field,
));
Parameters
$key: The key under which to store to $value, or NULL as described above.
$value: A value to store for $key.
Return value
An array mapping each $key to an array of each $value passed in for that key.
5 calls to field_test_memorize()
- BulkDeleteTest::testPurgeField in core/
modules/ field/ tests/ src/ Kernel/ BulkDeleteTest.php - Verify that field data items and fields are purged when a field storage is deleted.
- BulkDeleteTest::testPurgeFieldStorage in core/
modules/ field/ tests/ src/ Kernel/ BulkDeleteTest.php - Verify that field storages are preserved and purged correctly as multiple fields are deleted and purged.
- FieldStorageCrudTest::testCreate in core/
modules/ field/ tests/ src/ Kernel/ FieldStorageCrudTest.php - Test the creation of a field storage.
- field_test_field_storage_config_create in core/
modules/ field/ tests/ modules/ field_test/ field_test.module - Memorize calls to field_test_field_storage_config_create().
- TestItem::delete in core/
modules/ field/ tests/ modules/ field_test/ src/ Plugin/ Field/ FieldType/ TestItem.php - Defines custom delete behavior for field values.
File
-
core/
modules/ field/ tests/ modules/ field_test/ field_test.module, line 66
Code
function field_test_memorize($key = NULL, $value = NULL) {
static $memorize;
if (!isset($key)) {
$return = $memorize;
$memorize = [];
return $return;
}
if (is_array($memorize)) {
$memorize[$key][] = $value;
}
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.