123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720 |
- <?php
- /**
- * @file
- * Common functionality for all Feeds tests.
- */
- /**
- * Test basic Data API functionality.
- */
- class FeedsWebTestCase extends DrupalWebTestCase {
- protected $profile = 'testing';
- public function setUp() {
- $args = func_get_args();
- // Build the list of required modules which can be altered by passing in an
- // array of module names to setUp().
- if (isset($args[0])) {
- if (is_array($args[0])) {
- $modules = $args[0];
- }
- else {
- $modules = $args;
- }
- }
- else {
- $modules = array();
- }
- $modules[] = 'taxonomy';
- $modules[] = 'image';
- $modules[] = 'file';
- $modules[] = 'field';
- $modules[] = 'field_ui';
- $modules[] = 'feeds';
- $modules[] = 'feeds_ui';
- $modules[] = 'feeds_tests';
- $modules[] = 'ctools';
- $modules[] = 'job_scheduler';
- $modules = array_unique($modules);
- parent::setUp($modules);
- // Add text formats Directly.
- $filtered_html_format = array(
- 'format' => 'filtered_html',
- 'name' => 'Filtered HTML',
- 'weight' => 0,
- 'filters' => array(
- // URL filter.
- 'filter_url' => array(
- 'weight' => 0,
- 'status' => 1,
- ),
- // HTML filter.
- 'filter_html' => array(
- 'weight' => 1,
- 'status' => 1,
- ),
- // Line break filter.
- 'filter_autop' => array(
- 'weight' => 2,
- 'status' => 1,
- ),
- // HTML corrector filter.
- 'filter_htmlcorrector' => array(
- 'weight' => 10,
- 'status' => 1,
- ),
- ),
- );
- $filtered_html_format = (object) $filtered_html_format;
- filter_format_save($filtered_html_format);
- // Build the list of required administration permissions. Additional
- // permissions can be passed as an array into setUp()'s second parameter.
- if (isset($args[1]) && is_array($args[1])) {
- $permissions = $args[1];
- }
- else {
- $permissions = array();
- }
- $permissions[] = 'access content';
- $permissions[] = 'administer site configuration';
- $permissions[] = 'administer content types';
- $permissions[] = 'administer nodes';
- $permissions[] = 'bypass node access';
- $permissions[] = 'administer taxonomy';
- $permissions[] = 'administer users';
- $permissions[] = 'administer feeds';
- $permissions[] = 'administer filters';
- // Create an admin user and log in.
- $this->admin_user = $this->drupalCreateUser($permissions);
- $this->drupalLogin($this->admin_user);
- $types = array(
- array(
- 'type' => 'page',
- 'name' => 'Basic page',
- 'node_options[status]' => 1,
- 'node_options[promote]' => 0,
- ),
- array(
- 'type' => 'article',
- 'name' => 'Article',
- 'node_options[status]' => 1,
- 'node_options[promote]' => 1,
- ),
- );
- foreach ($types as $type) {
- $this->drupalPost('admin/structure/types/add', $type, 'Save content type');
- $this->assertText("The content type " . $type['name'] . " has been added.");
- }
- }
- /**
- * Absolute path to Drupal root.
- */
- public function absolute() {
- return realpath(getcwd());
- }
- /**
- * Get the absolute directory path of the feeds module.
- */
- public function absolutePath() {
- return $this->absolute() . '/' . drupal_get_path('module', 'feeds');
- }
- /**
- * Generate an OPML test feed.
- *
- * The purpose of this function is to create a dynamic OPML feed that points
- * to feeds included in this test.
- */
- public function generateOPML() {
- $path = $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'feeds') . '/tests/feeds/';
- $output =
- '<?xml version="1.0" encoding="utf-8"?>
- <opml version="1.1">
- <head>
- <title>Feeds test OPML</title>
- <dateCreated>Fri, 16 Oct 2009 02:53:17 GMT</dateCreated>
- <ownerName></ownerName>
- </head>
- <body>
- <outline text="Feeds test group" >
- <outline title="Development Seed - Technological Solutions for Progressive Organizations" text="" xmlUrl="' . $path . 'developmentseed.rss2" type="rss" />
- <outline title="Magyar Nemzet Online - H\'rek" text="" xmlUrl="' . $path . 'feed_without_guid.rss2" type="rss" />
- <outline title="Drupal planet" text="" type="rss" xmlUrl="' . $path . 'drupalplanet.rss2" />
- </outline>
- </body>
- </opml>';
- // UTF 8 encode output string and write it to disk
- $output = utf8_encode($output);
- $filename = file_default_scheme() . '://test-opml-' . $this->randomName() . '.opml';
- $filename = file_unmanaged_save_data($output, $filename);
- return $filename;
- }
- /**
- * Create an importer configuration.
- *
- * @param $name
- * The natural name of the feed.
- * @param $id
- * The persistent id of the feed.
- * @param $edit
- * Optional array that defines the basic settings for the feed in a format
- * that can be posted to the feed's basic settings form.
- */
- public function createImporterConfiguration($name = 'Syndication', $id = 'syndication') {
- // Create new feed configuration.
- $this->drupalGet('admin/structure/feeds');
- $this->clickLink('Add importer');
- $edit = array(
- 'name' => $name,
- 'id' => $id,
- );
- $this->drupalPost('admin/structure/feeds/create', $edit, 'Create');
- // Assert message and presence of default plugins.
- $this->assertText('Your configuration has been created with default settings.');
- $this->assertPlugins($id, 'FeedsHTTPFetcher', 'FeedsSyndicationParser', 'FeedsNodeProcessor');
- // Per default attach to page content type.
- $this->setSettings($id, NULL, array('content_type' => 'page'));
- // Per default attached to article content type.
- $this->setSettings($id, 'FeedsNodeProcessor', array('bundle' => 'article'));
- }
- /**
- * Choose a plugin for a importer configuration and assert it.
- *
- * @param $id
- * The importer configuration's id.
- * @param $plugin_key
- * The key string of the plugin to choose (one of the keys defined in
- * feeds_feeds_plugins()).
- */
- public function setPlugin($id, $plugin_key) {
- if ($type = FeedsPlugin::typeOf($plugin_key)) {
- $edit = array(
- 'plugin_key' => $plugin_key,
- );
- $this->drupalPost("admin/structure/feeds/$id/$type", $edit, 'Save');
- // Assert actual configuration.
- $config = unserialize(db_query("SELECT config FROM {feeds_importer} WHERE id = :id", array(':id' => $id))->fetchField());
- $this->assertEqual($config[$type]['plugin_key'], $plugin_key, 'Verified correct ' . $type . ' (' . $plugin_key . ').');
- }
- }
- /**
- * Set importer or plugin settings.
- *
- * @param $id
- * The importer configuration's id.
- * @param $plugin
- * The plugin (class) name, or NULL to set importer's settings
- * @param $settings
- * The settings to set.
- */
- public function setSettings($id, $plugin, $settings) {
- $this->drupalPost('admin/structure/feeds/' . $id . '/settings/' . $plugin, $settings, 'Save');
- $this->assertText('Your changes have been saved.');
- }
- /**
- * Create a test feed node. Test user has to have sufficient permissions:
- *
- * * create [type] content
- * * use feeds
- *
- * Assumes that page content type has been configured with
- * createImporterConfiguration() as a feed content type.
- *
- * @return
- * The node id of the node created.
- */
- public function createFeedNode($id = 'syndication', $feed_url = NULL, $title = '', $content_type = NULL) {
- if (empty($feed_url)) {
- $feed_url = $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'feeds') . '/tests/feeds/developmentseed.rss2';
- }
- // If content type not given, retrieve it.
- if (!$content_type) {
- $result= db_select('feeds_importer', 'f')
- ->condition('f.id', $id, '=')
- ->fields('f', array('config'))
- ->execute();
- $config = unserialize($result->fetchField());
- $content_type = $config['content_type'];
- $this->assertFalse(empty($content_type), 'Valid content type found: ' . $content_type);
- }
- // Create a feed node.
- $edit = array(
- 'title' => $title,
- 'feeds[FeedsHTTPFetcher][source]' => $feed_url,
- );
- $this->drupalPost('node/add/' . str_replace('_', '-', $content_type), $edit, 'Save');
- $this->assertText('has been created.');
- // Get the node id from URL.
- $nid = $this->getNid($this->getUrl());
- // Check whether feed got recorded in feeds_source table.
- $query = db_select('feeds_source', 's')
- ->condition('s.id', $id, '=')
- ->condition('s.feed_nid', $nid, '=');
- $query->addExpression("COUNT(*)");
- $result = $query->execute()->fetchField();
- $this->assertEqual(1, $result);
- $source = db_select('feeds_source', 's')
- ->condition('s.id', $id, '=')
- ->condition('s.feed_nid', $nid, '=')
- ->fields('s', array('config'))
- ->execute()->fetchObject();
- $config = unserialize($source->config);
- $this->assertEqual($config['FeedsHTTPFetcher']['source'], $feed_url, t('URL in DB correct.'));
- return $nid;
- }
- /**
- * Edit the configuration of a feed node to test update behavior.
- *
- * @param $nid
- * The nid to edit.
- * @param $feed_url
- * The new (absolute) feed URL to use.
- * @param $title
- * Optional parameter to change title of feed node.
- */
- public function editFeedNode($nid, $feed_url, $title = '') {
- $edit = array(
- 'title' => $title,
- 'feeds[FeedsHTTPFetcher][source]' => $feed_url,
- );
- // Check that the update was saved.
- $this->drupalPost('node/' . $nid . '/edit', $edit, 'Save');
- $this->assertText('has been updated.');
- // Check that the URL was updated in the feeds_source table.
- $source = db_query("SELECT * FROM {feeds_source} WHERE feed_nid = :nid", array(':nid' => $nid))->fetchObject();
- $config = unserialize($source->config);
- $this->assertEqual($config['FeedsHTTPFetcher']['source'], $feed_url, t('URL in DB correct.'));
- }
- /**
- * Batch create a variable amount of feed nodes. All will have the
- * same URL configured.
- *
- * @return
- * An array of node ids of the nodes created.
- */
- public function createFeedNodes($id = 'syndication', $num = 20, $content_type = NULL) {
- $nids = array();
- for ($i = 0; $i < $num; $i++) {
- $nids[] = $this->createFeedNode($id, NULL, $this->randomName(), $content_type);
- }
- return $nids;
- }
- /**
- * Import a URL through the import form. Assumes FeedsHTTPFetcher in place.
- */
- public function importURL($id, $feed_url = NULL) {
- if (empty($feed_url)) {
- $feed_url = $GLOBALS['base_url'] . '/' . drupal_get_path('module', 'feeds') . '/tests/feeds/developmentseed.rss2';
- }
- $edit = array(
- 'feeds[FeedsHTTPFetcher][source]' => $feed_url,
- );
- $nid = $this->drupalPost('import/' . $id, $edit, 'Import');
- // Check whether feed got recorded in feeds_source table.
- $this->assertEqual(1, db_query("SELECT COUNT(*) FROM {feeds_source} WHERE id = :id AND feed_nid = 0", array(':id' => $id))->fetchField());
- $source = db_query("SELECT * FROM {feeds_source} WHERE id = :id AND feed_nid = 0", array(':id' => $id))->fetchObject();
- $config = unserialize($source->config);
- $this->assertEqual($config['FeedsHTTPFetcher']['source'], $feed_url, t('URL in DB correct.'));
- // Check whether feed got properly added to scheduler.
- $this->assertEqual(1, db_query("SELECT COUNT(*) FROM {job_schedule} WHERE type = :id AND id = 0 AND name = 'feeds_source_import' AND last <> 0 AND scheduled = 0", array(':id' => $id))->fetchField());
- // Check expire scheduler.
- if (feeds_importer($id)->processor->expiryTime() == FEEDS_EXPIRE_NEVER) {
- $this->assertEqual(0, db_query("SELECT COUNT(*) FROM {job_schedule} WHERE type = :id AND id = 0 AND name = 'feeds_source_expire'", array(':id' => $id))->fetchField());
- }
- else {
- $this->assertEqual(1, db_query("SELECT COUNT(*) FROM {job_schedule} WHERE type = :id AND id = 0 AND name = 'feeds_source_expire'", array(':id' => $id))->fetchField());
- }
- }
- /**
- * Import a file through the import form. Assumes FeedsFileFetcher in place.
- */
- public function importFile($id, $file) {
- $this->assertTrue(file_exists($file), 'Source file exists');
- $edit = array(
- 'files[feeds]' => $file,
- );
- $this->drupalPost('import/' . $id, $edit, 'Import');
- }
- /**
- * Assert a feeds configuration's plugins.
- *
- * @deprecated:
- * Use setPlugin() instead.
- *
- * @todo Refactor users of assertPlugin() and make them use setPugin() instead.
- */
- public function assertPlugins($id, $fetcher, $parser, $processor) {
- // Assert actual configuration.
- $config = unserialize(db_query("SELECT config FROM {feeds_importer} WHERE id = :id", array(':id' => $id))->fetchField());
- $this->assertEqual($config['fetcher']['plugin_key'], $fetcher, 'Correct fetcher');
- $this->assertEqual($config['parser']['plugin_key'], $parser, 'Correct parser');
- $this->assertEqual($config['processor']['plugin_key'], $processor, 'Correct processor');
- }
- /**
- * Overrides DrupalWebTestCase::assertFieldByXPath().
- *
- * The core version has a bug, this is the D8 version.
- *
- * @todo Remove once https://drupal.org/node/2105617 lands.
- */
- protected function assertFieldByXPath($xpath, $value = NULL, $message = '', $group = 'Other') {
- $fields = $this->xpath($xpath);
- // If value specified then check array for match.
- $found = TRUE;
- if (isset($value)) {
- $found = FALSE;
- if ($fields) {
- foreach ($fields as $field) {
- if (isset($field['value']) && $field['value'] == $value) {
- // Input element with correct value.
- $found = TRUE;
- }
- elseif (isset($field->option) || isset($field->optgroup)) {
- // Select element found.
- $selected = $this->getSelectedItem($field);
- if ($selected === FALSE) {
- // No item selected so use first item.
- $items = $this->getAllOptions($field);
- if (!empty($items) && $items[0]['value'] == $value) {
- $found = TRUE;
- }
- }
- elseif ($selected == $value) {
- $found = TRUE;
- }
- }
- elseif ((string) $field == $value) {
- // Text area with correct text.
- $found = TRUE;
- }
- }
- }
- }
- return $this->assertTrue($fields && $found, $message, $group);
- }
- /**
- * Adds mappings to a given configuration.
- *
- * @param string $id
- * ID of the importer.
- * @param array $mappings
- * An array of mapping arrays. Each mapping array must have a source and
- * an target key and can have a unique key.
- * @param bool $test_mappings
- * (optional) TRUE to automatically test mapping configs. Defaults to TRUE.
- */
- public function addMappings($id, array $mappings, $test_mappings = TRUE) {
- $path = "admin/structure/feeds/$id/mapping";
- // Iterate through all mappings and add the mapping via the form.
- foreach ($mappings as $i => $mapping) {
- if ($test_mappings) {
- $current_mapping_key = $this->mappingExists($id, $i, $mapping['source'], $mapping['target']);
- $this->assertEqual($current_mapping_key, -1, 'Mapping does not exist before addition.');
- }
- // Get unique flag and unset it. Otherwise, drupalPost will complain that
- // Split up config and mapping.
- $config = $mapping;
- unset($config['source'], $config['target']);
- $mapping = array('source' => $mapping['source'], 'target' => $mapping['target']);
- // Add mapping.
- $this->drupalPost($path, $mapping, t('Save'));
- // If there are other configuration options, set them.
- if ($config) {
- $this->drupalPostAJAX(NULL, array(), 'mapping_settings_edit_' . $i);
- // Set some settings.
- $edit = array();
- foreach ($config as $key => $value) {
- $edit["config[$i][settings][$key]"] = $value;
- }
- $this->drupalPostAJAX(NULL, $edit, 'mapping_settings_update_' . $i);
- $this->drupalPost(NULL, array(), t('Save'));
- }
- if ($test_mappings) {
- $current_mapping_key = $this->mappingExists($id, $i, $mapping['source'], $mapping['target']);
- $this->assertTrue($current_mapping_key >= 0, 'Mapping exists after addition.');
- }
- }
- }
- /**
- * Remove mappings from a given configuration.
- *
- * @param string $id
- * ID of the importer.
- * @param array $mappings
- * An array of mapping arrays. Each mapping array must have a source and
- * a target key and can have a unique key.
- * @param bool $test_mappings
- * (optional) TRUE to automatically test mapping configs. Defaults to TRUE.
- */
- public function removeMappings($id, array $mappings, $test_mappings = TRUE) {
- $path = "admin/structure/feeds/$id/mapping";
- $edit = array();
- // Iterate through all mappings and remove via the form.
- foreach ($mappings as $i => $mapping) {
- if ($test_mappings) {
- $current_mapping_key = $this->mappingExists($id, $i, $mapping['source'], $mapping['target']);
- $this->assertEqual($current_mapping_key, $i, 'Mapping exists before removal.');
- }
- $edit["remove_flags[$i]"] = 1;
- }
- $this->drupalPost($path, $edit, t('Save'));
- $this->assertText('Your changes have been saved.');
- }
- /**
- * Gets an array of current mappings from the feeds_importer config.
- *
- * @param string $id
- * ID of the importer.
- *
- * @return bool|array
- * FALSE if the importer has no mappings, or an an array of mappings.
- */
- public function getCurrentMappings($id) {
- $config = db_query("SELECT config FROM {feeds_importer} WHERE id = :id", array(':id' => $id))->fetchField();
- $config = unserialize($config);
- // We are very specific here. 'mappings' can either be an array or not
- // exist.
- if (array_key_exists('mappings', $config['processor']['config'])) {
- $this->assertTrue(is_array($config['processor']['config']['mappings']), 'Mappings is an array.');
- return $config['processor']['config']['mappings'];
- }
- return FALSE;
- }
- /**
- * Determines if a mapping exists for a given importer.
- *
- * @param string $id
- * ID of the importer.
- * @param integer $i
- * The key of the mapping.
- * @param string $source
- * The source field.
- * @param string $target
- * The target field.
- *
- * @return integer
- * -1 if the mapping doesn't exist, the key of the mapping otherwise.
- */
- public function mappingExists($id, $i, $source, $target) {
- $current_mappings = $this->getCurrentMappings($id);
- if ($current_mappings) {
- foreach ($current_mappings as $key => $mapping) {
- if ($mapping['source'] == $source && $mapping['target'] == $target && $key == $i) {
- return $key;
- }
- }
- }
- return -1;
- }
- /**
- * Helper function, retrieves node id from a URL.
- */
- public function getNid($url) {
- $matches = array();
- preg_match('/node\/(\d+?)$/', $url, $matches);
- $nid = $matches[1];
- // Test for actual integerness.
- $this->assertTrue($nid === (string) (int) $nid, 'Node id is an integer.');
- return $nid;
- }
- /**
- * Copies a directory.
- */
- public function copyDir($source, $dest) {
- $result = file_prepare_directory($dest, FILE_CREATE_DIRECTORY | FILE_MODIFY_PERMISSIONS);
- foreach (@scandir($source) as $file) {
- if (is_file("$source/$file")) {
- $file = file_unmanaged_copy("$source/$file", "$dest/$file");
- }
- }
- }
- /**
- * Download and extract SimplePIE.
- *
- * Sets the 'feeds_simplepie_library_dir' variable to the directory where
- * SimplePie is downloaded.
- */
- function downloadExtractSimplePie($version) {
- $url = "http://simplepie.org/downloads/simplepie_$version.mini.php";
- $filename = 'simplepie.mini.php';
- // Avoid downloading the file dozens of times
- $library_dir = DRUPAL_ROOT . '/' . $this->originalFileDirectory . '/simpletest/feeds';
- $simplepie_library_dir = $library_dir . '/simplepie';
- if (!file_exists($library_dir)) {
- drupal_mkdir($library_dir);
- }
- if (!file_exists($simplepie_library_dir)) {
- drupal_mkdir($simplepie_library_dir);
- }
- // Local file name.
- $local_file = $simplepie_library_dir . '/' . $filename;
- // Begin single threaded code.
- if (function_exists('sem_get')) {
- $semaphore = sem_get(ftok(__FILE__, 1));
- sem_acquire($semaphore);
- }
- // Download and extact the archive, but only in one thread.
- if (!file_exists($local_file)) {
- $local_file = system_retrieve_file($url, $local_file, FALSE, FILE_EXISTS_REPLACE);
- }
- if (function_exists('sem_get')) {
- sem_release($semaphore);
- }
- // End single threaded code.
- // Verify that files were successfully extracted.
- $this->assertTrue(file_exists($local_file), t('@file found.', array('@file' => $local_file)));
- // Set the simpletest library directory.
- variable_set('feeds_library_dir', $library_dir);
- }
- }
- /**
- * Provides a wrapper for DrupalUnitTestCase for Feeds unit testing.
- */
- class FeedsUnitTestHelper extends DrupalUnitTestCase {
- public function setUp() {
- parent::setUp();
- // Manually include the feeds module.
- // @todo Allow an array of modules from the child class.
- drupal_load('module', 'feeds');
- }
- }
- class FeedsUnitTestCase extends FeedsUnitTestHelper {
- public static function getInfo() {
- return array(
- 'name' => 'Unit tests',
- 'description' => 'Test basic low-level Feeds module functionality.',
- 'group' => 'Feeds',
- );
- }
- /**
- * Test valid absolute urls.
- *
- * @see ValidUrlTestCase
- *
- * @todo Remove when http://drupal.org/node/1191252 is fixed.
- */
- function testFeedsValidURL() {
- $url_schemes = array('http', 'https', 'ftp', 'feed', 'webcal');
- $valid_absolute_urls = array(
- 'example.com',
- 'www.example.com',
- 'ex-ample.com',
- '3xampl3.com',
- 'example.com/paren(the)sis',
- 'example.com/index.html#pagetop',
- 'example.com:8080',
- 'subdomain.example.com',
- 'example.com/index.php?q=node',
- 'example.com/index.php?q=node¶m=false',
- 'user@www.example.com',
- 'user:pass@www.example.com:8080/login.php?do=login&style=%23#pagetop',
- '127.0.0.1',
- 'example.org?',
- 'john%20doe:secret:foo@example.org/',
- 'example.org/~,$\'*;',
- 'caf%C3%A9.example.org',
- '[FEDC:BA98:7654:3210:FEDC:BA98:7654:3210]:80/index.html',
- 'graph.asfdasdfasdf.com/blarg/feed?access_token=133283760145143|tGew8jbxi1ctfVlYh35CPYij1eE',
- );
- foreach ($url_schemes as $scheme) {
- foreach ($valid_absolute_urls as $url) {
- $test_url = $scheme . '://' . $url;
- $valid_url = feeds_valid_url($test_url, TRUE);
- $this->assertTrue($valid_url, t('@url is a valid url.', array('@url' => $test_url)));
- }
- }
- $invalid_ablosule_urls = array(
- '',
- 'ex!ample.com',
- 'ex%ample.com',
- );
- foreach ($url_schemes as $scheme) {
- foreach ($invalid_ablosule_urls as $url) {
- $test_url = $scheme . '://' . $url;
- $valid_url = feeds_valid_url($test_url, TRUE);
- $this->assertFalse($valid_url, t('@url is NOT a valid url.', array('@url' => $test_url)));
- }
- }
- }
- }
|