You are here

function ImportOPMLTestCase::submitImportForm in Drupal 7

Submits form with invalid, empty, and valid OPML files.

1 call to ImportOPMLTestCase::submitImportForm()
ImportOPMLTestCase::testOPMLImport in modules/aggregator/aggregator.test
Tests the import of an OPML file.

File

modules/aggregator/aggregator.test, line 792
Tests for aggregator.module.

Class

ImportOPMLTestCase
Tests importing feeds from OPML functionality for the Aggregator module.

Code

function submitImportForm() {
  $before = db_query('SELECT COUNT(*) FROM {aggregator_feed}')
    ->fetchField();
  $form['files[upload]'] = $this
    ->getInvalidOpml();
  $this
    ->drupalPost('admin/config/services/aggregator/add/opml', $form, t('Import'));
  $this
    ->assertText(t('No new feed has been added.'), 'Attempting to upload invalid XML.');
  $edit = array(
    'remote' => file_create_url($this
      ->getEmptyOpml()),
  );
  $this
    ->drupalPost('admin/config/services/aggregator/add/opml', $edit, t('Import'));
  $this
    ->assertText(t('No new feed has been added.'), 'Attempting to load empty OPML from remote URL.');
  $after = db_query('SELECT COUNT(*) FROM {aggregator_feed}')
    ->fetchField();
  $this
    ->assertEqual($before, $after, 'No feeds were added during the two last form submissions.');
  db_delete('aggregator_feed')
    ->execute();
  db_delete('aggregator_category')
    ->execute();
  db_delete('aggregator_category_feed')
    ->execute();
  $category = $this
    ->randomName(10);
  db_insert('aggregator_category')
    ->fields(array(
    'cid' => 1,
    'title' => $category,
    'description' => '',
  ))
    ->execute();
  $feeds[0] = $this
    ->getFeedEditArray();
  $feeds[1] = $this
    ->getFeedEditArray();
  $feeds[2] = $this
    ->getFeedEditArray();
  $edit = array(
    'files[upload]' => $this
      ->getValidOpml($feeds),
    'refresh' => '900',
    'category[1]' => $category,
  );
  $this
    ->drupalPost('admin/config/services/aggregator/add/opml', $edit, t('Import'));
  $this
    ->assertRaw(t('A feed with the URL %url already exists.', array(
    '%url' => $feeds[0]['url'],
  )), 'Verifying that a duplicate URL was identified');
  $this
    ->assertRaw(t('A feed named %title already exists.', array(
    '%title' => $feeds[1]['title'],
  )), 'Verifying that a duplicate title was identified');
  $after = db_query('SELECT COUNT(*) FROM {aggregator_feed}')
    ->fetchField();
  $this
    ->assertEqual($after, 2, 'Verifying that two distinct feeds were added.');
  $feeds_from_db = db_query("SELECT f.title, f.url, f.refresh, cf.cid FROM {aggregator_feed} f LEFT JOIN {aggregator_category_feed} cf ON f.fid = cf.fid");
  $refresh = $category = TRUE;
  foreach ($feeds_from_db as $feed) {
    $title[$feed->url] = $feed->title;
    $url[$feed->title] = $feed->url;
    $category = $category && $feed->cid == 1;
    $refresh = $refresh && $feed->refresh == 900;
  }
  $this
    ->assertEqual($title[$feeds[0]['url']], $feeds[0]['title'], 'First feed was added correctly.');
  $this
    ->assertEqual($url[$feeds[1]['title']], $feeds[1]['url'], 'Second feed was added correctly.');
  $this
    ->assertTrue($refresh, 'Refresh times are correct.');
  $this
    ->assertTrue($category, 'Categories are correct.');
}