123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469 |
- <?php
- /**
- * @file
- * Helper module for the file tests.
- *
- * The caller is must call file_test_reset() to initializing this module before
- * calling file_test_get_calls() or file_test_set_return().
- */
- define('FILE_URL_TEST_CDN_1', 'http://cdn1.example.com');
- define('FILE_URL_TEST_CDN_2', 'http://cdn2.example.com');
- /**
- * Implements hook_menu().
- */
- function file_test_menu() {
- $items['file-test/upload'] = array(
- 'title' => 'Upload test',
- 'page callback' => 'drupal_get_form',
- 'page arguments' => array('_file_test_form'),
- 'access arguments' => array('access content'),
- 'type' => MENU_CALLBACK,
- );
- return $items;
- }
- /**
- * Implements hook_stream_wrappers().
- */
- function file_test_stream_wrappers() {
- return array(
- 'dummy' => array(
- 'name' => t('Dummy files'),
- 'class' => 'DrupalDummyStreamWrapper',
- 'description' => t('Dummy wrapper for simpletest.'),
- ),
- 'dummy-remote' => array(
- 'name' => t('Dummy files (remote)'),
- 'class' => 'DrupalDummyRemoteStreamWrapper',
- 'description' => t('Dummy wrapper for simpletest (remote).'),
- ),
- );
- }
- /**
- * Form to test file uploads.
- */
- function _file_test_form($form, &$form_state) {
- $form['file_test_upload'] = array(
- '#type' => 'file',
- '#title' => t('Upload a file'),
- );
- $form['file_test_replace'] = array(
- '#type' => 'select',
- '#title' => t('Replace existing image'),
- '#options' => array(
- FILE_EXISTS_RENAME => t('Appends number until name is unique'),
- FILE_EXISTS_REPLACE => t('Replace the existing file'),
- FILE_EXISTS_ERROR => t('Fail with an error'),
- ),
- '#default_value' => FILE_EXISTS_RENAME,
- );
- $form['file_subdir'] = array(
- '#type' => 'textfield',
- '#title' => t('Subdirectory for test file'),
- '#default_value' => '',
- );
- $form['extensions'] = array(
- '#type' => 'textfield',
- '#title' => t('Allowed extensions.'),
- '#default_value' => '',
- );
- $form['allow_all_extensions'] = array(
- '#type' => 'radios',
- '#options' => array(
- 'false' => 'No',
- 'empty_array' => 'Empty array',
- 'empty_string' => 'Empty string',
- ),
- '#default_value' => 'false',
- );
- $form['is_image_file'] = array(
- '#type' => 'checkbox',
- '#title' => t('Is this an image file?'),
- '#default_value' => TRUE,
- );
- $form['submit'] = array(
- '#type' => 'submit',
- '#value' => t('Submit'),
- );
- return $form;
- }
- /**
- * Process the upload.
- */
- function _file_test_form_submit(&$form, &$form_state) {
- // Process the upload and perform validation. Note: we're using the
- // form value for the $replace parameter.
- if (!empty($form_state['values']['file_subdir'])) {
- $destination = 'temporary://' . $form_state['values']['file_subdir'];
- file_prepare_directory($destination, FILE_CREATE_DIRECTORY);
- }
- else {
- $destination = FALSE;
- }
- // Setup validators.
- $validators = array();
- if ($form_state['values']['is_image_file']) {
- $validators['file_validate_is_image'] = array();
- }
- $allow = $form_state['values']['allow_all_extensions'];
- if ($allow === 'empty_array') {
- $validators['file_validate_extensions'] = array();
- }
- elseif ($allow === 'empty_string') {
- $validators['file_validate_extensions'] = array('');
- }
- elseif (!empty($form_state['values']['extensions'])) {
- $validators['file_validate_extensions'] = array($form_state['values']['extensions']);
- }
- $file = file_save_upload('file_test_upload', $validators, $destination, $form_state['values']['file_test_replace']);
- if ($file) {
- $form_state['values']['file_test_upload'] = $file;
- drupal_set_message(t('File @filepath was uploaded.', array('@filepath' => $file->uri)));
- drupal_set_message(t('File name is @filename.', array('@filename' => $file->filename)));
- drupal_set_message(t('File MIME type is @mimetype.', array('@mimetype' => $file->filemime)));
- drupal_set_message(t('You WIN!'));
- }
- elseif ($file === FALSE) {
- drupal_set_message(t('Epic upload FAIL!'), 'error');
- }
- }
- /**
- * Reset/initialize the history of calls to the file_* hooks.
- *
- * @see file_test_get_calls()
- * @see file_test_reset()
- */
- function file_test_reset() {
- // Keep track of calls to these hooks
- $results = array(
- 'load' => array(),
- 'validate' => array(),
- 'download' => array(),
- 'insert' => array(),
- 'update' => array(),
- 'copy' => array(),
- 'move' => array(),
- 'delete' => array(),
- );
- variable_set('file_test_results', $results);
- // These hooks will return these values, see file_test_set_return().
- $return = array(
- 'validate' => array(),
- 'download' => NULL,
- );
- variable_set('file_test_return', $return);
- }
- /**
- * Get the arguments passed to invocation of a given hook since
- * file_test_reset() was last called.
- *
- * @param $op
- * One of the hook_file_* operations: 'load', 'validate', 'download',
- * 'insert', 'update', 'copy', 'move', 'delete'.
- *
- * @return
- * Array of the parameters passed to each call.
- *
- * @see _file_test_log_call()
- * @see file_test_reset()
- */
- function file_test_get_calls($op) {
- $results = variable_get('file_test_results', array());
- return $results[$op];
- }
- /**
- * Get an array with the calls for all hooks.
- *
- * @return
- * An array keyed by hook name ('load', 'validate', 'download', 'insert',
- * 'update', 'copy', 'move', 'delete') with values being arrays of parameters
- * passed to each call.
- */
- function file_test_get_all_calls() {
- return variable_get('file_test_results', array());
- }
- /**
- * Store the values passed to a hook invocation.
- *
- * @param $op
- * One of the hook_file_* operations: 'load', 'validate', 'download',
- * 'insert', 'update', 'copy', 'move', 'delete'.
- * @param $args
- * Values passed to hook.
- *
- * @see file_test_get_calls()
- * @see file_test_reset()
- */
- function _file_test_log_call($op, $args) {
- $results = variable_get('file_test_results', array());
- $results[$op][] = $args;
- variable_set('file_test_results', $results);
- }
- /**
- * Load the appropriate return value.
- *
- * @param $op
- * One of the hook_file_[validate,download] operations.
- *
- * @return
- * Value set by file_test_set_return().
- *
- * @see file_test_set_return()
- * @see file_test_reset()
- */
- function _file_test_get_return($op) {
- $return = variable_get('file_test_return', array($op => NULL));
- return $return[$op];
- }
- /**
- * Assign a return value for a given operation.
- *
- * @param $op
- * One of the hook_file_[validate,download] operations.
- * @param $value
- * Value for the hook to return.
- *
- * @see _file_test_get_return()
- * @see file_test_reset()
- */
- function file_test_set_return($op, $value) {
- $return = variable_get('file_test_return', array());
- $return[$op] = $value;
- variable_set('file_test_return', $return);
- }
- /**
- * Implements hook_file_load().
- */
- function file_test_file_load($files) {
- foreach ($files as $file) {
- _file_test_log_call('load', array($file));
- // Assign a value on the object so that we can test that the $file is passed
- // by reference.
- $file->file_test['loaded'] = TRUE;
- }
- }
- /**
- * Implements hook_file_validate().
- */
- function file_test_file_validate($file) {
- _file_test_log_call('validate', array($file));
- return _file_test_get_return('validate');
- }
- /**
- * Implements hook_file_download().
- */
- function file_test_file_download($uri) {
- _file_test_log_call('download', array($uri));
- return _file_test_get_return('download');
- }
- /**
- * Implements hook_file_insert().
- */
- function file_test_file_insert($file) {
- _file_test_log_call('insert', array($file));
- }
- /**
- * Implements hook_file_update().
- */
- function file_test_file_update($file) {
- _file_test_log_call('update', array($file));
- }
- /**
- * Implements hook_file_copy().
- */
- function file_test_file_copy($file, $source) {
- _file_test_log_call('copy', array($file, $source));
- }
- /**
- * Implements hook_file_move().
- */
- function file_test_file_move($file, $source) {
- _file_test_log_call('move', array($file, $source));
- }
- /**
- * Implements hook_file_delete().
- */
- function file_test_file_delete($file) {
- _file_test_log_call('delete', array($file));
- }
- /**
- * Implements hook_file_url_alter().
- */
- function file_test_file_url_alter(&$uri) {
- // Only run this hook when this variable is set. Otherwise, we'd have to add
- // another hidden test module just for this hook.
- $alter_mode = variable_get('file_test_hook_file_url_alter', FALSE);
- if (!$alter_mode) {
- return;
- }
- // Test alteration of file URLs to use a CDN.
- elseif ($alter_mode == 'cdn') {
- $cdn_extensions = array('css', 'js', 'gif', 'jpg', 'jpeg', 'png');
- // Most CDNs don't support private file transfers without a lot of hassle,
- // so don't support this in the common case.
- $schemes = array('public');
- $scheme = file_uri_scheme($uri);
- // Only serve shipped files and public created files from the CDN.
- if (!$scheme || in_array($scheme, $schemes)) {
- // Shipped files.
- if (!$scheme) {
- $path = $uri;
- }
- // Public created files.
- else {
- $wrapper = file_stream_wrapper_get_instance_by_scheme($scheme);
- $path = $wrapper->getDirectoryPath() . '/' . file_uri_target($uri);
- }
- // Clean up Windows paths.
- $path = str_replace('\\', '/', $path);
- // Serve files with one of the CDN extensions from CDN 1, all others from
- // CDN 2.
- $pathinfo = pathinfo($path);
- if (array_key_exists('extension', $pathinfo) && in_array($pathinfo['extension'], $cdn_extensions)) {
- $uri = FILE_URL_TEST_CDN_1 . '/' . $path;
- }
- else {
- $uri = FILE_URL_TEST_CDN_2 . '/' . $path;
- }
- }
- }
- // Test alteration of file URLs to use root-relative URLs.
- elseif ($alter_mode == 'root-relative') {
- // Only serve shipped files and public created files with root-relative
- // URLs.
- $scheme = file_uri_scheme($uri);
- if (!$scheme || $scheme == 'public') {
- // Shipped files.
- if (!$scheme) {
- $path = $uri;
- }
- // Public created files.
- else {
- $wrapper = file_stream_wrapper_get_instance_by_scheme($scheme);
- $path = $wrapper->getDirectoryPath() . '/' . file_uri_target($uri);
- }
- // Clean up Windows paths.
- $path = str_replace('\\', '/', $path);
- // Generate a root-relative URL.
- $uri = base_path() . '/' . $path;
- }
- }
- // Test alteration of file URLs to use protocol-relative URLs.
- elseif ($alter_mode == 'protocol-relative') {
- // Only serve shipped files and public created files with protocol-relative
- // URLs.
- $scheme = file_uri_scheme($uri);
- if (!$scheme || $scheme == 'public') {
- // Shipped files.
- if (!$scheme) {
- $path = $uri;
- }
- // Public created files.
- else {
- $wrapper = file_stream_wrapper_get_instance_by_scheme($scheme);
- $path = $wrapper->getDirectoryPath() . '/' . file_uri_target($uri);
- }
- // Clean up Windows paths.
- $path = str_replace('\\', '/', $path);
- // Generate a protocol-relative URL.
- $uri = '/' . base_path() . '/' . $path;
- }
- }
- }
- /**
- * Implements hook_file_mimetype_mapping_alter().
- */
- function file_test_file_mimetype_mapping_alter(&$mapping) {
- // Add new mappings.
- $mapping['mimetypes']['file_test_mimetype_1'] = 'madeup/file_test_1';
- $mapping['mimetypes']['file_test_mimetype_2'] = 'madeup/file_test_2';
- $mapping['mimetypes']['file_test_mimetype_3'] = 'madeup/doc';
- $mapping['extensions']['file_test_1'] = 'file_test_mimetype_1';
- $mapping['extensions']['file_test_2'] = 'file_test_mimetype_2';
- $mapping['extensions']['file_test_3'] = 'file_test_mimetype_2';
- // Override existing mapping.
- $mapping['extensions']['doc'] = 'file_test_mimetype_3';
- }
- /**
- * Helper class for testing the stream wrapper registry.
- *
- * Dummy stream wrapper implementation (dummy://).
- */
- class DrupalDummyStreamWrapper extends DrupalLocalStreamWrapper {
- function getDirectoryPath() {
- return variable_get('stream_public_path', 'sites/default/files');
- }
- /**
- * Override getInternalUri().
- *
- * Return a dummy path for testing.
- */
- function getInternalUri() {
- return '/dummy/example.txt';
- }
- /**
- * Override getExternalUrl().
- *
- * Return the HTML URI of a public file.
- */
- function getExternalUrl() {
- return '/dummy/example.txt';
- }
- }
- /**
- * Helper class for testing the stream wrapper registry.
- *
- * Dummy remote stream wrapper implementation (dummy-remote://).
- *
- * Basically just the public scheme but not returning a local file for realpath.
- */
- class DrupalDummyRemoteStreamWrapper extends DrupalPublicStreamWrapper {
- function realpath() {
- return FALSE;
- }
- }
|