You are here

class HttpFetcherTest in Feeds 8.3

Same name in this branch
  1. 8.3 tests/src/Functional/Feeds/Fetcher/HttpFetcherTest.php \Drupal\Tests\feeds\Functional\Feeds\Fetcher\HttpFetcherTest
  2. 8.3 tests/src/Unit/Feeds/Fetcher/HttpFetcherTest.php \Drupal\Tests\feeds\Unit\Feeds\Fetcher\HttpFetcherTest

@coversDefaultClass \Drupal\feeds\Feeds\Fetcher\HttpFetcher @group feeds

Hierarchy

Expanded class hierarchy of HttpFetcherTest

File

tests/src/Unit/Feeds/Fetcher/HttpFetcherTest.php, line 26

Namespace

Drupal\Tests\feeds\Unit\Feeds\Fetcher
View source
class HttpFetcherTest extends FeedsUnitTestCase {

  /**
   * The feed entity.
   *
   * @var \Drupal\feeds\FeedInterface
   */
  protected $feed;

  /**
   * The Feeds fetcher plugin under test.
   *
   * @var \Drupal\feeds\Feeds\Fetcher\HttpFetcher
   */
  protected $fetcher;

  /**
   * A mocked HTTP handler to use within the handler stack.
   *
   * @var \GuzzleHttp\Handler\MockHandler
   */
  protected $mockHandler;

  /**
   * {@inheritdoc}
   */
  public function setUp() {
    parent::setUp();
    $feed_type = $this
      ->createMock(FeedTypeInterface::class);
    $this->mockHandler = new MockHandler();
    $client = new Client([
      'handler' => HandlerStack::create($this->mockHandler),
    ]);
    $cache = $this
      ->createMock(CacheBackendInterface::class);
    $file_system = $this
      ->prophesize(FileSystemInterface::class);
    $file_system
      ->tempnam(Argument::type('string'), Argument::type('string'))
      ->will(function ($args) {

      // We suppress any notices as since PHP 7.1, this results into a warning
      // when the temporary directory is not configured in php.ini. We are not
      // interested in that artefact for this test.
      return @tempnam($args[0], $args[1]);
    });
    $file_system
      ->realpath(Argument::type('string'))
      ->will(function ($args) {
      return realpath($args[0]);
    });
    $this->fetcher = new HttpFetcher([
      'feed_type' => $feed_type,
    ], 'http', [], $client, $cache, $file_system
      ->reveal());
    $this->fetcher
      ->setStringTranslation($this
      ->getStringTranslationStub());
    $this->feed = $this
      ->prophesize(FeedInterface::class);
    $this->feed
      ->id()
      ->willReturn(1);
    $this->feed
      ->getSource()
      ->willReturn('http://example.com');
  }

  /**
   * Tests a successful fetch from a HTTP source.
   *
   * @covers ::fetch
   */
  public function testFetch() {
    $this->mockHandler
      ->append(new Response(200, [], 'test data'));
    $result = $this->fetcher
      ->fetch($this->feed
      ->reveal(), new State());
    $this
      ->assertSame('test data', $result
      ->getRaw());
  }

  /**
   * Tests fetching from a HTTP source that returns a 304 (not modified).
   *
   * @covers ::fetch
   */
  public function testFetch304() {
    $this->mockHandler
      ->append(new Response(304));
    $this
      ->expectException(EmptyFeedException::class);
    $this->fetcher
      ->fetch($this->feed
      ->reveal(), new State());
  }

  /**
   * Tests fetching from a HTTP source that returns a 404 (not found).
   *
   * @covers ::fetch
   */
  public function testFetch404() {
    $this->mockHandler
      ->append(new Response(404));
    $this
      ->expectException(RuntimeException::class);
    $this->fetcher
      ->fetch($this->feed
      ->reveal(), new State());
  }

  /**
   * Tests a fetch that fails.
   *
   * @covers ::fetch
   */
  public function testFetchError() {
    $this->mockHandler
      ->append(new RequestException('', new Request('GET', 'http://google.com')));
    $this
      ->expectException(RuntimeException::class);
    $this->fetcher
      ->fetch($this->feed
      ->reveal(), new State());
  }

  /**
   * @covers ::onFeedDeleteMultiple
   */
  public function testOnFeedDeleteMultiple() {
    $feed = $this
      ->createMock(FeedInterface::class);
    $feed
      ->expects($this
      ->exactly(3))
      ->method('getSource')
      ->will($this
      ->returnValue('http://example.com'));
    $feeds = [
      $feed,
      $feed,
      $feed,
    ];
    $this->fetcher
      ->onFeedDeleteMultiple($feeds, new State());
  }

}

Members

Namesort descending Modifiers Type Description Overrides
FeedsMockingTrait::getMockAccount protected function Mocks an account object.
FeedsMockingTrait::getMockedAccountSwitcher protected function Returns a mocked AccountSwitcher object.
FeedsMockingTrait::getMockFeed protected function Returns a mocked feed entity.
FeedsMockingTrait::getMockFeedType protected function Returns a mocked feed type entity.
FeedsMockingTrait::getMockFieldDefinition protected function Mocks a field definition. 1
FeedsMockingTrait::getMockFileSystem protected function Mocks the file system.
FeedsReflectionTrait::callProtectedMethod protected function Calls a protected method on the given object.
FeedsReflectionTrait::getMethod protected function Gets a ReflectionMethod for a class method.
FeedsReflectionTrait::getProtectedClosure protected function Returns a dynamically created closure for the object's method.
FeedsReflectionTrait::setProtectedProperty protected function Sets a protected property.
FeedsUnitTestCase::absolutePath protected function Returns the absolute directory path of the Feeds module.
FeedsUnitTestCase::defineConstants protected function Defines stub constants.
FeedsUnitTestCase::getMockStreamWrapperManager protected function Returns a mock stream wrapper manager.
FeedsUnitTestCase::resourcesPath protected function Returns the absolute directory path of the resources folder.
HttpFetcherTest::$feed protected property The feed entity.
HttpFetcherTest::$fetcher protected property The Feeds fetcher plugin under test.
HttpFetcherTest::$mockHandler protected property A mocked HTTP handler to use within the handler stack.
HttpFetcherTest::setUp public function Overrides FeedsUnitTestCase::setUp
HttpFetcherTest::testFetch public function Tests a successful fetch from a HTTP source.
HttpFetcherTest::testFetch304 public function Tests fetching from a HTTP source that returns a 304 (not modified).
HttpFetcherTest::testFetch404 public function Tests fetching from a HTTP source that returns a 404 (not found).
HttpFetcherTest::testFetchError public function Tests a fetch that fails.
HttpFetcherTest::testOnFeedDeleteMultiple public function @covers ::onFeedDeleteMultiple
PhpunitCompatibilityTrait::getMock Deprecated public function Returns a mock object for the specified class using the available method.
PhpunitCompatibilityTrait::setExpectedException Deprecated public function Compatibility layer for PHPUnit 6 to support PHPUnit 4 code.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
UnitTestCase::assertArrayEquals protected function Asserts if two arrays are equal by sorting them first.
UnitTestCase::getBlockMockWithMachineName Deprecated protected function Mocks a block with a block plugin. 1
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.