| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707 | <?php// $Id: xmlsitemap.test,v 1.19 2010/01/24 07:12:25 davereid Exp $/** * @file * Unit tests for the xmlsitemap module. * * @ingroup xmlsitemap *//** * Helper test class with some added functions for testing. */class XMLSitemapTestHelper extends DrupalWebTestCase {  protected $admin_user;  function setUp() {    // Call parent::setUp() allowing test cases to pass further modules.    $modules = func_get_args();    $modules = array_merge(array('xmlsitemap'), $modules);    call_user_func_array(array('parent', 'setUp'), $modules);    // Ensure the files directory is created and writable during testing.    // @todo This can be removed when http://drupal.org/node/654752 is fixed.    drupal_static_reset('xmlsitemap_get_directory');    $this->checkFilesDirectory();  }  function tearDown() {    // Capture any (remaining) watchdog errors.    $this->assertNoWatchdogErrors();    // Reset the watchdog seen IDs for the next test run.    $this->getWatchdogMessages(array(), TRUE);    parent::tearDown();  }  /**   * Check the files directory is created (massive fails if not done).   *   * @todo This can be removed when http://drupal.org/node/654752 is fixed.   */  protected function checkFilesDirectory() {    if (!xmlsitemap_check_directory()) {      $this->fail(t('Sitemap directory was found and writable for testing.'));    }  }  protected function drupalGetSitemap($language = LANGUAGE_NONE, $regenerate = FALSE) {    if ($regenerate) {      $this->regenerateSitemap();    }    $this->drupalGet('sitemap.xml', array('language' => xmlsitemap_language_load($language)));    $this->assertResponse(200);  }  /**   * Regenerate the sitemap by setting the regenerate flag and running cron.   */  protected function regenerateSitemap() {    variable_set('xmlsitemap_regenerate_needed', TRUE);    variable_set('xmlsitemap_generated_last', 0);    module_load_include('inc', 'xmlsitemap');    xmlsitemap_regenerate();    $this->assertTrue(variable_get('xmlsitemap_generated_last', 0) && !variable_get('xmlsitemap_regenerate_needed', FALSE), t('XML sitemaps regenerated and flag cleared.'));  }  protected function assertSitemapLink($conditions) {    $link = xmlsitemap_load_link($conditions);    $this->assertTrue(is_array($link), 'Link loaded.');    return $link;  }  protected function assertNoSitemapLink($conditions) {    $link = xmlsitemap_load_link($conditions);    $this->assertFalse($link, 'Link not loaded.');    return $link;  }  protected function assertSitemapLinkVisible() {    $links = func_get_args();    foreach ($links as $link) {      $this->assertTrue($link && $link['access'] && $link['status'], 'Sitemap link is visible.');    }  }  protected function assertSitemapLinkNotVisible() {    $links = func_get_args();    foreach ($links as $link) {      $this->assertTrue($link && !($link['access'] && $link['status']), 'Sitemap link is not visible.');    }  }  protected function assertSitemapLinkValues(array $link, array $conditions) {    foreach ($conditions as $key => $value) {      if ($value === NULL || $link[$key] === NULL) {        // For nullable fields, always check for identical values (===).        $this->assertIdentical($link[$key], $value, t('Identical values for link field @key.', array('@key' => $key)));      }      else {        // Otherwise check simple equality (==).        $this->assertEqual($link[$key], $value, t('Equal values for link field @key.', array('@key' => $key)));      }    }  }  protected function assertNotSitemapLinkValues(array $link, array $conditions) {    foreach ($conditions as $key => $value) {      if ($value === NULL || $link[$key] === NULL) {        // For nullable fields, always check for identical values (===).        $this->assertNotIdentical($link[$key], $value, t('Not identical values for link field @key.', array('@key' => $key)));      }      else {        // Otherwise check simple equality (==).        $this->assertNotEqual($link[$key], $value, t('Not equal values for link field @key.', array('@key' => $key)));      }    }  }  protected function assertRawSitemapLinks() {    $links = func_get_args();    foreach ($links as $link) {      $path = url($link['loc'], array('language' => xmlsitemap_language_load($link['language']), 'absolute' => TRUE));      $this->assertRaw($link['loc'], t('Link %path found in the sitemap.', array('%path' => $path)));    }  }  protected function assertNoRawSitemapLinks() {    $links = func_get_args();    foreach ($links as $link) {      $path = url($link['loc'], array('language' => xmlsitemap_language_load($link['language']), 'absolute' => TRUE));      $this->assertNoRaw($link['loc'], t('Link %path not found in the sitemap.', array('%path' => $path)));    }  }  protected function addSitemapLink(array $link = array()) {    $last_id = &drupal_static(__FUNCTION__, 1);    $link += array(      'type' => 'testing',      'id' => $last_id,    );    // Make the default path easier to read than a random string.    $link += array('loc' => $link['type'] . '-' . $link['id']);    $last_id = $link['id'] + 1;    xmlsitemap_save_link($link);    return $link;  }  protected function assertFlag($variable, $assert_value = TRUE, $reset_if_true = TRUE) {    $value = xmlsitemap_var($variable);    if ($reset_if_true && $value) {      variable_set('xmlsitemap_' . $variable, FALSE);    }    return $this->assertEqual($value, $assert_value, "xmlsitemap_$variable is " . ($assert_value ? 'TRUE' : 'FALSE'));  }  protected function assertXMLSitemapProblems($problem_text = FALSE) {    $this->drupalGet('admin/config/search/xmlsitemap');    $this->assertText(t('One or more problems were detected with your XML sitemap configuration'));    if ($problem_text) {      $this->assertText($problem_text);    }  }  protected function assertNoXMLSitemapProblems() {    $this->drupalGet('admin/config/search/xmlsitemap');    $this->assertNoText(t('One or more problems were detected with your XML sitemap configuration'));  }  /**   * Fetch all seen watchdog messages.   *   * @todo Add unit tests for this function.   */  protected function getWatchdogMessages(array $conditions = array(), $reset = FALSE) {    static $seen_ids = array();    static $levels;    if (!module_exists('dblog') || $reset) {      $seen_ids = array();      return;    }    if (!isset($levels)) {      $levels = watchdog_severity_levels();    }    $query = db_select('watchdog');    $query->fields('watchdog', array('wid', 'type', 'severity', 'message', 'variables', 'timestamp'));    foreach ($conditions as $field => $value) {      if ($field == 'variables' && is_array($value)) {        $value = serialize($value);      }      $query->condition($field, $value);    }    if ($seen_ids) {      $query->condition('wid', $seen_ids, 'NOT IN');    }    $query->orderBy('timestamp', 'ASC');    $messages = $query->execute()->fetchAllAssoc('wid');    foreach ($messages as &$message) {      $message->variables = unserialize($message->variables);      if (!is_array($message->variables)) {        $message->variables = array();      }      $message->text = $message->timestamp . ' - ' . $levels[$message->severity] . ' - ' . t($message->message, $message->variables);    }    $seen_ids = array_merge($seen_ids, array_keys($messages));    return $messages;  }  protected function assertWatchdogMessage(array $conditions, $message = 'Watchdog message found.') {    $this->assertTrue($this->getWatchdogMessages($conditions), $message);  }  protected function assertNoWatchdogMessage(array $conditions, $message = 'Watchdog message not found.') {    $this->assertFalse($this->getWatchdogMessages($conditions), $message);  }  /**   * Check that there were no watchdog errors or worse.   */  protected function assertNoWatchdogErrors() {    $messages = $this->getWatchdogMessages();    $verbose = array();    foreach ($messages as $message) {      if (in_array($message->severity, array(WATCHDOG_EMERG, WATCHDOG_ALERT, WATCHDOG_CRITICAL, WATCHDOG_ERROR, WATCHDOG_WARNING))) {        $this->fail($message->text);      }      $verbose[] = $message->text;    }    if ($verbose) {      array_unshift($verbose, '<h2>Watchdog messages</h2>');      $this->verbose(implode("<br />", $verbose));    }  }}class XMLSitemapUnitTest extends XMLSitemapTestHelper {  public static function getInfo() {    return array(      'name' => 'XML sitemap unit tests',      'description' => 'Unit tests for the XML sitemap module.',      'group' => 'XML sitemap',    );  }  function setUp() {    parent::setUp('xmlsitemap');  }  function testAssertFlag() {    variable_set('xmlsitemap_rebuild_needed', TRUE);    $this->assertTrue(xmlsitemap_var('rebuild_needed'));    $this->assertTrue($this->assertFlag('rebuild_needed', TRUE, FALSE));    $this->assertTrue(xmlsitemap_var('rebuild_needed'));    $this->assertTrue($this->assertFlag('rebuild_needed', TRUE, TRUE));    $this->assertFalse(xmlsitemap_var('rebuild_needed'));    $this->assertTrue($this->assertFlag('rebuild_needed', FALSE, FALSE));    $this->assertFalse(xmlsitemap_var('rebuild_needed'));  }  /**   * Tests for xmlsitemap_get_changefreq().   */  function testGetChangefreq() {    // The test values.    $values = array(      0,      mt_rand(1, XMLSITEMAP_FREQUENCY_ALWAYS),      mt_rand(XMLSITEMAP_FREQUENCY_ALWAYS + 1, XMLSITEMAP_FREQUENCY_HOURLY),      mt_rand(XMLSITEMAP_FREQUENCY_HOURLY + 1, XMLSITEMAP_FREQUENCY_DAILY),      mt_rand(XMLSITEMAP_FREQUENCY_DAILY + 1, XMLSITEMAP_FREQUENCY_WEEKLY),      mt_rand(XMLSITEMAP_FREQUENCY_WEEKLY + 1, XMLSITEMAP_FREQUENCY_MONTHLY),      mt_rand(XMLSITEMAP_FREQUENCY_MONTHLY + 1, XMLSITEMAP_FREQUENCY_YEARLY),      mt_rand(XMLSITEMAP_FREQUENCY_YEARLY + 1, mt_getrandmax()),    );    // The expected values.    $expected = array(      FALSE,      'always',      'hourly',      'daily',      'weekly',      'monthly',      'yearly',      'never',    );    foreach ($values as $i => $value) {      $actual = xmlsitemap_get_changefreq($value);      $this->assertIdentical($actual, $expected[$i]);    }  }  /**   * Tests for xmlsitemap_get_chunk_count().   */  function testGetChunkCount() {    // Set a low chunk size for testing.    variable_set('xmlsitemap_chunk_size', 4);    // Make the total number of links just equal to the chunk size.    $count = db_query("SELECT COUNT(id) FROM {xmlsitemap}")->fetchField();    for ($i = $count; $i < 4; $i++) {      $this->addSitemapLink();      $this->assertEqual(xmlsitemap_get_chunk_count(TRUE), 1);    }    $this->assertEqual(db_query("SELECT COUNT(id) FROM {xmlsitemap}")->fetchField(), 4);    // Add a disabled link, should not change the chunk count.    $this->addSitemapLink(array('status' => FALSE));    $this->assertEqual(xmlsitemap_get_chunk_count(TRUE), 1);    // Add a visible link, should finally bump up the chunk count.    $this->addSitemapLink();    $this->assertEqual(xmlsitemap_get_chunk_count(TRUE), 2);    // Change all links to disabled. The chunk count should be 1 not 0.    db_query("UPDATE {xmlsitemap} SET status = 0");    $this->assertEqual(xmlsitemap_get_chunk_count(TRUE), 1);    $this->assertEqual(xmlsitemap_get_link_count(), 0);    // Delete all links. The chunk count should be 1 not 0.    db_query("DELETE FROM {xmlsitemap}");    $this->assertEqual(db_query("SELECT COUNT(id) FROM {xmlsitemap}")->fetchField(), 0);    $this->assertEqual(xmlsitemap_get_chunk_count(TRUE), 1);  }  //function testGetChunkFile() {  //}  //  //function testGetChunkSize() {  //}  //  //function testGetLinkCount() {  //}  /**   * Tests for xmlsitemap_calculate_changereq().   */  function testCalculateChangefreq() {    // The test values.    $values = array(      array(),      array(REQUEST_TIME),      array(REQUEST_TIME, REQUEST_TIME - 200),      array(REQUEST_TIME - 200, REQUEST_TIME, REQUEST_TIME - 600),    );    // Expected values.    $expected = array(0, 0, 200, 300);    foreach ($values as $i => $value) {      $actual = xmlsitemap_calculate_changefreq($value);      $this->assertEqual($actual, $expected[$i]);    }  }  /**   * Test for xmlsitemap_recalculate_changefreq().   */  function testRecalculateChangefreq() {    // The starting test value.    $value = array('lastmod' => REQUEST_TIME - 1000, 'changefreq' => 0, 'changecount' => 0);    // Expected values.    $expecteds = array(      array('lastmod' => REQUEST_TIME, 'changefreq' => 1000, 'changecount' => 1),      array('lastmod' => REQUEST_TIME, 'changefreq' => 500, 'changecount' => 2),      array('lastmod' => REQUEST_TIME, 'changefreq' => 333, 'changecount' => 3),    );    foreach ($expecteds as $expected) {      xmlsitemap_recalculate_changefreq($value);      $this->assertEqual($value, $expected);    }  }  /**   * Tests for xmlsitemap_switch_user and xmlsitemap_restore_user().   */  function testSwitchUser() {    global $user;    $original_user = $user;    $new_user = $this->drupalCreateUser();    // Switch to a new valid user.    $this->assertEqual(xmlsitemap_switch_user($new_user), TRUE);    $this->assertEqual($user->uid, $new_user->uid);    // Switch again to the anonymous user.    $this->assertEqual(xmlsitemap_switch_user(0), TRUE);    $this->assertEqual($user->uid, 0);    // Switch again to the new user.    $this->assertEqual(xmlsitemap_switch_user($new_user->uid), TRUE);    $this->assertEqual($user->uid, $new_user->uid);    // Test that after two switches the original user was restored.    $this->assertEqual(xmlsitemap_restore_user(), TRUE);    $this->assertEqual($user->uid, $original_user->uid);    // Attempt to switch to the same user.    $this->assertEqual(xmlsitemap_switch_user($original_user->uid), FALSE);    $this->assertEqual($user->uid, $original_user->uid);    $this->assertEqual(xmlsitemap_restore_user(), FALSE);    $this->assertEqual($user->uid, $original_user->uid);    // Attempt to switch to an invalid user ID.    $invalid_uid = db_query("SELECT MAX(uid) FROM {users}")->fetchField() + 100;    $this->assertEqual(xmlsitemap_switch_user($invalid_uid), FALSE);    $this->assertEqual($user->uid, $original_user->uid);    $this->assertEqual(xmlsitemap_restore_user(), FALSE);    $this->assertEqual($user->uid, $original_user->uid);    // Attempt user switching when the original user is anonymous.    $user = drupal_anonymous_user();    $this->assertEqual(xmlsitemap_switch_user(0), FALSE);    $this->assertEqual($user->uid, 0);    $this->assertEqual(xmlsitemap_restore_user(), FALSE);    $this->assertEqual($user->uid, 0);  }  //function testLoadLink() {  //}  /**   * Tests for xmlsitemap_save_link().   */  function testSaveLink() {    $link = array('type' => 'testing', 'id' => 1, 'loc' => 'testing', 'status' => 1);    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['status'] = 0;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 0.5;    $link['loc'] = 'new_location';    $link['status'] = 1;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 0.0;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 0.1;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 1.0;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 1;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', FALSE);    $link['priority'] = 0;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 0.5;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', TRUE);    $link['priority'] = 0.5;    $link['priority_override'] = 0;    $link['status'] = 1;    xmlsitemap_save_link($link);    $this->assertFlag('regenerate_needed', FALSE);  }  /**   * Tests for xmlsitemap_delete_link().   */  function testDeleteLink() {    // Add our testing data.    $link1 = $this->addSitemapLink(array('loc' => 'testing1', 'status' => 0));    $link2 = $this->addSitemapLink(array('loc' => 'testing1', 'status' => 1));    $link3 = $this->addSitemapLink(array('status' => 0));    variable_set('xmlsitemap_regenerate_needed', FALSE);    // Test delete multiple links.    // Test that the regenerate flag is set when visible links are deleted.    $deleted = xmlsitemap_delete_link(array('loc' => 'testing1'));    $this->assertEqual($deleted, 2);    $this->assertFalse(xmlsitemap_load_link(array('type' => $link1['type'], 'id' => $link1['id'])));    $this->assertFalse(xmlsitemap_load_link(array('type' => $link2['type'], 'id' => $link2['id'])));    $this->assertTrue(xmlsitemap_load_link(array('type' => $link3['type'], 'id' => $link3['id'])));    $this->assertFlag('regenerate_needed', TRUE);    $deleted = xmlsitemap_delete_link(array('type' => $link3['type'], 'id' => $link3['id']));    $this->assertEqual($deleted, 1);    $this->assertFalse(xmlsitemap_load_link(array('type' => $link3['type'], 'id' => $link3['id'])));    $this->assertFlag('regenerate_needed', FALSE);  }  /**   * Tests for xmlsitemap_update_links().   */  function testUpdateLinks() {    // Add our testing data.    $link1 = $this->addSitemapLink(array('subtype' => 'group1'));    $link2 = $this->addSitemapLink(array('subtype' => 'group1'));    $link3 = $this->addSitemapLink(array('subtype' => 'group2'));    variable_set('xmlsitemap_regenerate_needed', FALSE);    // id | type    | subtype | language | access | status | priority    // 1  | testing | group1  | ''       | 1      | 1      | 0.5    // 2  | testing | group1  | ''       | 1      | 1      | 0.5    // 3  | testing | group2  | ''       | 1      | 1      | 0.5    $updated = xmlsitemap_update_links(array('status' => 0), array('type' => 'testing', 'subtype' => 'group1', 'status_override' => 0));    $this->assertEqual($updated, 2);    $this->assertFlag('regenerate_needed', TRUE);    // id | type    | subtype | language | status | priority    // 1  | testing | group1  | ''       | 0      | 0.5    // 2  | testing | group1  | ''       | 0      | 0.5    // 3  | testing | group2  | ''       | 1      | 0.5    $updated = xmlsitemap_update_links(array('priority' => 0.0), array('type' => 'testing', 'subtype' => 'group1', 'priority_override' => 0));    $this->assertEqual($updated, 2);    $this->assertFlag('regenerate_needed', FALSE);    // id | type    | subtype | language | status | priority    // 1  | testing | group1  | ''       | 0      | 0.0    // 2  | testing | group1  | ''       | 0      | 0.0    // 3  | testing | group2  | ''       | 1      | 0.5    $updated = xmlsitemap_update_links(array('subtype' => 'group2'), array('type' => 'testing', 'subtype' => 'group1'));    $this->assertEqual($updated, 2);    $this->assertFlag('regenerate_needed', FALSE);    // id | type    | subtype | language | status | priority    // 1  | testing | group2  | ''       | 0      | 0.0    // 2  | testing | group2  | ''       | 0      | 0.0    // 3  | testing | group2  | ''       | 1      | 0.5    $updated = xmlsitemap_update_links(array('status' => 1), array('type' => 'testing', 'subtype' => 'group2', 'status_override' => 0, 'status' => 0));    $this->assertEqual($updated, 2);    $this->assertFlag('regenerate_needed', TRUE);    // id | type    | subtype | language | status | priority    // 1  | testing | group2  | ''       | 1      | 0.0    // 2  | testing | group2  | ''       | 1      | 0.0    // 3  | testing | group2  | ''       | 1      | 0.5  }}class XMLSitemapFunctionalTest extends XMLSitemapTestHelper {  public static function getInfo() {    return array(      'name' => 'XML sitemap interface tests',      'description' => 'Functional tests for the XML sitemap module.',      'group' => 'XML sitemap',    );  }  function setUp() {    parent::setUp('path');    $this->admin_user = $this->drupalCreateUser(array('access content', 'administer site configuration', 'administer xmlsitemap'));    $this->drupalLogin($this->admin_user);  }  /**   * Test the sitemap file caching.   */  function testSitemapCaching() {    $this->drupalGetSitemap(LANGUAGE_NONE, TRUE);    $this->assertResponse(200);    $etag = $this->drupalGetHeader('etag');    $last_modified = $this->drupalGetHeader('last-modified');    $this->assertTrue($etag, t('Etag header found.'));    $this->assertTrue($last_modified, t('Last-modified header found.'));    $this->drupalGet('sitemap.xml', array(), array('If-Modified-Since: ' . $last_modified, 'If-None-Match: ' . $etag));    $this->assertResponse(304);  }  /**   * Test that the sitemap will not be genereated before the lifetime expires.   */  function testMinimumLifetime() {    $this->regenerateSitemap();    $edit = array('xmlsitemap_minimum_lifetime' => 300);    $this->drupalPost('admin/config/search/xmlsitemap', $edit, t('Save configuration'));    $this->assertText(t('The configuration options have been saved.'));    $link = $this->addSitemapLink(array('loc' => 'lifetime-test'));    drupal_cron_run();    $this->drupalGetSitemap();    $this->assertNoRaw('lifetime-test');    variable_set('xmlsitemap_generated_last', REQUEST_TIME - 300);    drupal_cron_run();    $this->drupalGetSitemap();    $this->assertRaw('lifetime-test');    xmlsitemap_delete_link(array('type' => $link['type'], 'id' => $link['id']));    drupal_cron_run();    $this->drupalGetSitemap();    $this->assertRaw('lifetime-test');    $this->drupalGetSitemap(LANGUAGE_NONE, TRUE);    $this->assertNoRaw('lifetime-test');  }  /**   * Test base URL functionality.   */  function testBaseURL() {    $edit = array('xmlsitemap_base_url' => '');    $this->drupalPost('admin/config/search/xmlsitemap', $edit, t('Save configuration'));    $this->assertText(t('Base URL field is required.'));    $edit = array('xmlsitemap_base_url' => 'invalid');    $this->drupalPost('admin/config/search/xmlsitemap', $edit, t('Save configuration'));    $this->assertText(t('Invalid base URL.'));    $edit = array('xmlsitemap_base_url' => 'http://example.com/ ');    $this->drupalPost('admin/config/search/xmlsitemap', $edit, t('Save configuration'));    $this->assertText(t('Invalid base URL.'));    $edit = array('xmlsitemap_base_url' => 'http://example.com/');    $this->drupalPost('admin/config/search/xmlsitemap', $edit, t('Save configuration'));    $this->assertText(t('The configuration options have been saved.'));    $this->drupalGetSitemap(LANGUAGE_NONE, TRUE);    $this->assertRaw('<loc>http://example.com/</loc>');  }  /**   * Test that configuration problems are reported properly in the status report.   */  function testStatusReport() {    // Test the rebuild flag.    variable_set('xmlsitemap_generated_last', REQUEST_TIME);    variable_set('xmlsitemap_rebuild_needed', TRUE);    $this->assertXMLSitemapProblems(t('The XML sitemap data is out of sync and needs to be completely rebuilt.'));    $this->clickLink(t('completely rebuilt'));    $this->assertResponse(200);    variable_set('xmlsitemap_rebuild_needed', FALSE);    $this->assertNoXMLSitemapProblems();    // Test the regenerate flag (and cron hasn't run in a while).    variable_set('xmlsitemap_regenerate_needed', TRUE);    variable_set('xmlsitemap_generated_last', REQUEST_TIME - variable_get('cron_threshold_warning', 172800) - 100);    $this->assertXMLSitemapProblems(t('The XML cached files are out of date and need to be regenerated. You can run cron manually to regenerate the sitemap files.'));    $this->clickLink(t('run cron manually'));    $this->assertResponse(200);    $this->assertNoXMLSitemapProblems();    // Test anonymous users access to sitemap.xml.    user_role_revoke_permissions(DRUPAL_ANONYMOUS_RID, array('access content'));    $this->assertXMLSitemapProblems(t('In order to allow search engines to view the XML sitemap and content on your site, the anonymous user role must have the access content permission.'));    user_role_grant_permissions(DRUPAL_ANONYMOUS_RID, array('access content'));    $this->assertNoXMLSitemapProblems();    // Test chunk count > 1000.    // Test directory not writable.  }  /**   * Test that duplicate paths are skipped during generation.   */  function testDuplicatePaths() {    $link1 = $this->addSitemapLink(array('loc' => 'duplicate'));    $link2 = $this->addSitemapLink(array('loc' => 'duplicate'));    $this->drupalGetSitemap(LANGUAGE_NONE, TRUE);    $this->assertUniqueText('duplicate');  }}class XMLSitemapRobotsTxtIntegrationTest extends XMLSitemapTestHelper {  public static function getInfo() {    return array(      'name' => 'XML sitemap robots.txt',      'description' => 'Integration tests for the XML sitemap and robots.txt module.',      'group' => 'XML sitemap',      'dependencies' => array('robotstxt'),    );  }  function setUp() {    parent::setUp('xmlsitemap', 'robotstxt');  }  function testRobotsTxt() {    // Request the un-clean robots.txt path so this will work in case there is    // still the robots.txt file in the root directory.    $this->drupalGet('', array('query' => array('q' => 'robots.txt')));    $this->assertRaw('Sitemap: ' . url('sitemap.xml', array('absolute' => TRUE)));  }}
 |