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/%field_test_entity_test/edit'] = array( 'title' => 'Edit test entity', 'page callback' => 'field_test_entity_edit', 'page arguments' => array(1), '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($obj_type, $object, $field, $instance, $langcode, &$items) { return array($langcode => md5(serialize(array($obj_type, $object, $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($obj_type, $objects, $field, $instances, $langcode, &$items) { $result = array(); foreach ($objects as $id => $object) { $result[$id] = array($langcode => md5(serialize(array($obj_type, $object, $field['field_name'], $langcode, $items[$id])))); } return $result; } /** * Implements hook_field_languages(). */ function field_test_field_languages($obj_type, $field, &$languages) { if ($field['settings']['test_hook_in']) { // Add an unavailable language. $languages[] = 'xx'; // Remove an available language. unset($languages[0]); } } /** * Helper function to enable entity translations. */ function field_test_entity_info_translatable($obj_type = NULL, $translatable = NULL) { $stored_value = &drupal_static(__FUNCTION__, array()); if (isset($obj_type)) { $stored_value[$obj_type] = $translatable; entity_info_cache_clear(); } return $stored_value; } /** * 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 = &drupal_static(__FUNCTION__, NULL); if (is_null($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); } /** * Memorize calls to hook_field_insert(). */ function field_test_field_insert($obj_type, $object, $field, $instance, $items) { $args = func_get_args(); field_test_memorize(__FUNCTION__, $args); } /** * Memorize calls to hook_field_update(). */ function field_test_field_update($obj_type, $object, $field, $instance, $items) { $args = func_get_args(); field_test_memorize(__FUNCTION__, $args); } /** * Memorize calls to hook_field_delete(). */ function field_test_field_delete($obj_type, $object, $field, $instance, $items) { $args = func_get_args(); field_test_memorize(__FUNCTION__, $args); }