- <?php
- * @file
- * Helper module for the Field API tests.
- *
- * The module defines
- * - an entity type (field_test.entity.inc)
- * - a field type and its formatters and widgets (field_test.field.inc)
- * - a field storage backend (field_test.storage.inc)
- *
- * The main field_test.module file implements generic hooks and provides some
- * test helper functions
- */
-
- require_once BACKDROP_ROOT . '/core/modules/field/tests/field_test/field_test.entity.inc';
- require_once BACKDROP_ROOT . '/core/modules/field/tests/field_test/field_test.field.inc';
- require_once BACKDROP_ROOT . '/core/modules/field/tests/field_test/field_test.storage.inc';
-
- * Implements hook_permission().
- */
- function field_test_permission() {
- $perms = array(
- 'access field_test content' => array(
- 'title' => t('Access field_test content'),
- 'description' => t('View published field_test content.'),
- ),
- 'administer field_test content' => array(
- 'title' => t('Administer field_test content'),
- 'description' => t('Manage field_test content'),
- ),
- );
- return $perms;
- }
-
- * Implements hook_menu().
- */
- function field_test_menu() {
- $items = array();
- $bundles = field_info_bundles('test_entity');
-
- foreach ($bundles as $bundle_name => $bundle_info) {
- $bundle_url_str = str_replace('_', '-', $bundle_name);
- $items['test-entity/add/' . $bundle_url_str] = array(
- 'title' => t('Add @bundle test_entity', array('@bundle' => $bundle_info['label'])),
- 'page callback' => 'field_test_entity_add',
- 'page arguments' => array(2),
- 'access arguments' => array('administer field_test content'),
- 'type' => MENU_NORMAL_ITEM,
- );
- }
- $items['test-entity/manage/%field_test_entity_test/edit'] = array(
- 'title' => 'Edit test entity',
- 'page callback' => 'field_test_entity_edit',
- 'page arguments' => array(2),
- 'access arguments' => array('administer field_test content'),
- 'type' => MENU_NORMAL_ITEM,
- );
-
- $items['test-entity/nested/%field_test_entity_test/%field_test_entity_test'] = array(
- 'title' => 'Nested entity form',
- 'page callback' => 'backdrop_get_form',
- 'page arguments' => array('field_test_entity_nested_form', 2, 3),
- 'access arguments' => array('administer field_test content'),
- 'type' => MENU_NORMAL_ITEM,
- );
-
- return $items;
- }
-
- * Generic op to test _field_invoke behavior.
- *
- * This simulates a field operation callback to be invoked by _field_invoke().
- */
- function field_test_field_test_op($entity_type, $entity, $field, $instance, $langcode, &$items) {
- return array($langcode => hash('sha256', serialize(array($entity_type, $entity, $field['field_name'], $langcode, $items))));
- }
-
- * Generic op to test _field_invoke_multiple behavior.
- *
- * This simulates a multiple field operation callback to be invoked by
- * _field_invoke_multiple().
- */
- function field_test_field_test_op_multiple($entity_type, $entities, $field, $instances, $langcode, &$items) {
- $result = array();
- foreach ($entities as $id => $entity) {
-
-
-
-
- $field_name = $instances[$id]['field_name'];
- $result[$id] = array($langcode => hash('sha256', serialize(array($entity_type, $entity, $field_name, $langcode, $items[$id]))));
- }
- return $result;
- }
-
- * Implements hook_field_available_languages_alter().
- */
- function field_test_field_available_languages_alter(&$languages, $context) {
- if (state_get('field_test_field_available_languages_alter', FALSE)) {
-
- $languages[] = 'xx';
-
- $index = array_search('en', $languages);
- unset($languages[$index]);
- }
- }
-
- * Implements hook_field_language_alter().
- */
- function field_test_field_language_alter(&$display_language, $context) {
- if (state_get('field_test_language_fallback', TRUE)) {
- locale_field_language_fallback($display_language, $context['entity'], $context['language']);
- }
- }
-
- * 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:
- *
- * @code
- * // calls to field_test_memorize() here are ignored
- *
- * // turn on memorization
- * field_test_memorize();
- *
- * // call some Field API functions that invoke field_test hooks
- * $field = field_create_field(...);
- *
- * // retrieve and reset the memorized hook call data
- * $mem = field_test_memorize();
- *
- * // make sure hook_field_create_field() is invoked correctly
- * assertEqual(count($mem['field_test_field_create_field']), 1);
- * assertEqual($mem['field_test_field_create_field'][0], array($field));
- * @endcode
- *
- * @param $key
- * The key under which to store to $value, or NULL as described above.
- * @param $value
- * A value to store for $key.
- * @return
- * An array mapping each $key to an array of each $value passed in
- * for that key.
- */
- function field_test_memorize($key = NULL, $value = NULL) {
- $memorize = &backdrop_static(__FUNCTION__, NULL);
-
- if (!isset($key)) {
- $return = $memorize;
- $memorize = array();
- return $return;
- }
- if (is_array($memorize)) {
- $memorize[$key][] = $value;
- }
- }
-
- * Memorize calls to hook_field_create_field().
- */
- function field_test_field_create_field($field) {
- $args = func_get_args();
- field_test_memorize(__FUNCTION__, $args);
- }
-
- * Implements hook_entity_query_alter().
- */
- function field_test_entity_query_alter(&$query) {
- if (isset($query->tags['alterMyExecuteCallbackPlease'])) {
- $query->executeCallback = 'field_test_dummy_field_storage_query';
- }
- }
-
- * Pseudo-implements hook_field_storage_query().
- */
- function field_test_dummy_field_storage_query(EntityFieldQuery $query) {
-
- return array(
- 'user' => array(
- 1 => (object) array('entity_id' => 1, 'revision_id' => NULL, 'bundle' => NULL),
- ),
- );
- }
-
- * Implements hook_field_attach_view_alter().
- */
- function field_test_field_attach_view_alter(&$output, $context) {
- if (!empty($context['display']['settings']['alter'])) {
- $output['test_field'][] = array('#markup' => 'field_test_field_attach_view_alter');
- }
- }
-
- * Implements hook_field_widget_properties_alter().
- */
- function field_test_field_widget_properties_alter(&$widget, $context) {
-
- if (in_array($context['entity_type'], array('node', 'comment')) && ($context['field']['field_name'] == 'alter_test_text')) {
- $widget['settings']['size'] = 42;
- }
- }
-
- * Implements hook_field_widget_properties_ENTITY_TYPE_alter().
- */
- function field_test_field_widget_properties_user_alter(&$widget, $context) {
-
- if ($context['field']['field_name'] == 'alter_test_options') {
- $widget['type'] = 'options_buttons';
- }
- }
-
- * Implements hook_field_widget_form_alter().
- */
- function field_test_field_widget_form_alter(&$element, &$form_state, $context) {
- switch ($context['field']['field_name']) {
- case 'alter_test_text':
- backdrop_set_message('Field size: ' . $context['instance']['widget']['settings']['size']);
- break;
-
- case 'alter_test_options':
- backdrop_set_message('Widget type: ' . $context['instance']['widget']['type']);
- break;
- }
- }
-
- * Implements hook_autoload_info().
- */
- function field_test_autoload_info() {
- return array(
- 'TestFieldEntity' => 'field_test.class.inc',
- 'TestEntity' => 'field_test.class.inc',
- 'TestEntityBundleController' => 'field_test.controller.inc',
- );
- }
-
- * Implements hook_query_TAG_alter() for tag 'efq_table_prefixing_test'.
- *
- * @see EntityFieldQueryTestCase::testTablePrefixing()
- */
- function field_test_query_efq_table_prefixing_test_alter(&$query) {
-
-
- $query->join('test_entity','te2','%alias.ftid = test_entity.ftid');
- }
-
- * Implements hook_query_TAG_alter() for tag 'store_global_test_query'.
- */
- function field_test_query_store_global_test_query_alter($query) {
-
-
-
-
- $GLOBALS['test_query'] = $query;
- }
-
- * Implements hook_field_formatter_settings_form_alter().
- */
- function field_test_field_formatter_settings_form_alter(&$element, &$form_state, $context) {
- $settings = array();
- if (!empty($context)) {
- $settings = $context['instance']['display'][$context['view_mode']]['settings'];
- }
-
- $element['field_test_formatter_settings_form_alter'] = array(
- '#type' => 'textfield',
- '#title' => t('Formatter settings form alter'),
- '#default_value' => isset($settings['field_test_formatter_settings_form_alter']) ? $settings['field_test_formatter_settings_form_alter'] : '',
- );
- }
-
- * Implements hook_field_formatter_settings_summary_alter().
- */
- function field_test_field_formatter_settings_summary_alter(&$summary, $context) {
- $settings = $context['instance']['display'][$context['view_mode']]['settings'];
-
- if (!empty($summary)) {
- $summary .= '<br />';
- }
-
- if (!empty($settings['field_test_formatter_settings_form_alter'])) {
- $summary .= t('Display text: @text', array('@text' => $settings['field_test_formatter_settings_form_alter']));
- }
- else {
- $summary .= 'field_test_field_formatter_settings_summary_alter';
- }
- }