UpdateFeedItemTest.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. <?php
  2. namespace Drupal\Tests\aggregator\Functional;
  3. use Drupal\Component\Render\FormattableMarkup;
  4. use Drupal\aggregator\Entity\Feed;
  5. use Drupal\aggregator\Entity\Item;
  6. /**
  7. * Update feed items from a feed.
  8. *
  9. * @group aggregator
  10. */
  11. class UpdateFeedItemTest extends AggregatorTestBase {
  12. /**
  13. * {@inheritdoc}
  14. */
  15. protected $defaultTheme = 'stark';
  16. /**
  17. * Tests running "update items" from 'admin/config/services/aggregator' page.
  18. */
  19. public function testUpdateFeedItem() {
  20. $this->createSampleNodes();
  21. // Create a feed and test updating feed items if possible.
  22. $feed = $this->createFeed();
  23. if (!empty($feed)) {
  24. $this->updateFeedItems($feed, $this->getDefaultFeedItemCount());
  25. $this->deleteFeedItems($feed);
  26. }
  27. // Delete feed.
  28. $this->deleteFeed($feed);
  29. // Test updating feed items without valid timestamp information.
  30. $edit = [
  31. 'title[0][value]' => "Feed without publish timestamp",
  32. 'url[0][value]' => $this->getRSS091Sample(),
  33. ];
  34. $this->drupalGet($edit['url[0][value]']);
  35. $this->assertSession()->statusCodeEquals(200);
  36. $this->drupalPostForm('aggregator/sources/add', $edit, t('Save'));
  37. $this->assertText(t('The feed @name has been added.', ['@name' => $edit['title[0][value]']]), new FormattableMarkup('The feed @name has been added.', ['@name' => $edit['title[0][value]']]));
  38. // Verify that the creation message contains a link to a feed.
  39. $view_link = $this->xpath('//div[@class="messages"]//a[contains(@href, :href)]', [':href' => 'aggregator/sources/']);
  40. $this->assert(isset($view_link), 'The message area contains a link to a feed');
  41. $fids = \Drupal::entityQuery('aggregator_feed')->condition('url', $edit['url[0][value]'])->execute();
  42. $feed = Feed::load(array_values($fids)[0]);
  43. $feed->refreshItems();
  44. $item_ids = \Drupal::entityQuery('aggregator_item')->condition('fid', $feed->id())->execute();
  45. $before = Item::load(array_values($item_ids)[0])->getPostedTime();
  46. // Sleep for 3 second.
  47. sleep(3);
  48. $feed
  49. ->setLastCheckedTime(0)
  50. ->setHash('')
  51. ->setEtag('')
  52. ->setLastModified(0)
  53. ->save();
  54. $feed->refreshItems();
  55. $after = Item::load(array_values($item_ids)[0])->getPostedTime();
  56. $this->assertTrue($before === $after, new FormattableMarkup('Publish timestamp of feed item was not updated (@before === @after)', ['@before' => $before, '@after' => $after]));
  57. // Make sure updating items works even after uninstalling a module
  58. // that provides the selected plugins.
  59. $this->enableTestPlugins();
  60. $this->container->get('module_installer')->uninstall(['aggregator_test']);
  61. $this->updateFeedItems($feed);
  62. $this->assertSession()->statusCodeEquals(200);
  63. }
  64. }