You are here

class QueryPathXmlParserTest in Feeds extensible parsers 8

Same name in this branch
  1. 8 tests/src/Functional/Feeds/Parser/QueryPathXmlParserTest.php \Drupal\Tests\feeds_ex\Functional\Feeds\Parser\QueryPathXmlParserTest
  2. 8 tests/src/FunctionalJavascript/Feeds/Parser/QueryPathXmlParserTest.php \Drupal\Tests\feeds_ex\FunctionalJavascript\Feeds\Parser\QueryPathXmlParserTest
  3. 8 tests/src/Unit/Feeds/Parser/QueryPathXmlParserTest.php \Drupal\Tests\feeds_ex\Unit\Feeds\Parser\QueryPathXmlParserTest

@coversDefaultClass \Drupal\feeds_ex\Feeds\Parser\QueryPathXmlParser @group feeds_ex

Hierarchy

Expanded class hierarchy of QueryPathXmlParserTest

File

tests/src/Unit/Feeds/Parser/QueryPathXmlParserTest.php, line 14

Namespace

Drupal\Tests\feeds_ex\Unit\Feeds\Parser
View source
class QueryPathXmlParserTest extends ParserTestBase {

  /**
   * {@inheritdoc}
   */
  public function setUp() {
    parent::setUp();
    $configuration = [
      'feed_type' => $this->feedType,
    ];
    $utility = new XmlUtility();
    $utility
      ->setStringTranslation($this
      ->getStringTranslationStub());
    $this->parser = new QueryPathXmlParser($configuration, 'querypathxml', [], $utility);
    $this->parser
      ->setStringTranslation($this
      ->getStringTranslationStub());
    $this->parser
      ->setFeedsExMessenger(new TestMessenger());
  }

  /**
   * Tests simple parsing.
   */
  public function testSimpleParsing() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => '',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
        ],
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(3, $result);
    foreach ($result as $delta => $item) {
      $this
        ->assertSame('I am a title' . $delta, $item
        ->get('title'));
      $this
        ->assertSame('I am a description' . $delta, $item
        ->get('description'));
    }
  }

  /**
   * Tests raw parsing.
   */
  public function testRaw() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => '',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
          'raw' => TRUE,
        ],
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(3, $result);
    foreach ($result as $delta => $item) {
      $this
        ->assertSame('I am a title' . $delta, $item
        ->get('title'));
      $this
        ->assertXmlStringEqualsXmlString('<description><text>I am a description' . $delta . '</text></description>', $item
        ->get('description'));
    }
  }

  /**
   * Tests inner xml.
   */
  public function testInner() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => '',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
          'raw' => TRUE,
          'inner' => TRUE,
        ],
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(3, $result);
    foreach ($result as $delta => $item) {
      $this
        ->assertSame('I am a title' . $delta, $item
        ->get('title'));
      $this
        ->assertXmlStringEqualsXmlString('<text>I am a description' . $delta . '</text>', $item
        ->get('description'));
    }
  }

  /**
   * Tests grabbing an attribute.
   */
  public function testAttributeParsing() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => 'attr',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
        ],
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(3, $result);
    foreach ($result as $delta => $item) {
      $this
        ->assertSame('attribute' . $delta, $item
        ->get('title'));
      $this
        ->assertSame('I am a description' . $delta, $item
        ->get('description'));
    }
  }

  /**
   * Tests grabbing multiple attributes.
   */
  public function testMultipleAttributeParsing() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items thing',
      ],
      'sources' => [
        'url' => [
          'name' => 'URL',
          'value' => 'img',
          'attribute' => 'src',
        ],
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(1, $result);
    $url = $result[0]
      ->get('url');
    $this
      ->assertCount(2, $url);
    $this
      ->assertSame($url[0], 'http://drupal.org');
    $this
      ->assertSame($url[1], 'http://drupal.org/project/feeds_ex');
  }

  /**
   * Tests parsing a CP866 (Russian) encoded file.
   */
  public function testCp866Encoded() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test_ru.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => '',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
        ],
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(3, $result);
    foreach ($result as $delta => $item) {
      $this
        ->assertSame('Я название' . $delta, $item
        ->get('title'));
      $this
        ->assertSame('Я описание' . $delta, $item
        ->get('description'));
    }
  }

  /**
   * Tests a EUC-JP (Japanese) encoded file without the encoding declaration.
   *
   * This implicitly tests Base's encoding conversion.
   */
  public function testEucJpEncodedNoDeclaration() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test_jp.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => '',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
        ],
      ],
      'source_encoding' => [
        'EUC-JP',
      ],
    ];
    $this->parser
      ->setConfiguration($config);
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(3, $result);
    foreach ($result as $delta => $item) {
      $this
        ->assertSame('私はタイトルです' . $delta, $item
        ->get('title'));
      $this
        ->assertSame('私が説明してい' . $delta, $item
        ->get('description'));
    }
  }

  /**
   * Tests that batch parsing works.
   */
  public function testBatchParsing() {
    $fetcher_result = new RawFetcherResult(file_get_contents($this->moduleDir . '/tests/resources/test.xml'), $this->fileSystem);
    $config = [
      'context' => [
        'value' => 'items item',
      ],
      'sources' => [
        'title' => [
          'name' => 'Title',
          'value' => 'title',
          'attribute' => '',
        ],
        'description' => [
          'name' => 'Title',
          'value' => 'description',
          'attribute' => '',
        ],
      ],
      'line_limit' => 1,
    ];
    $this->parser
      ->setConfiguration($config);
    foreach (range(0, 2) as $delta) {
      $result = $this->parser
        ->parse($this->feed, $fetcher_result, $this->state);
      $this
        ->assertCount(1, $result);
      $this
        ->assertSame('I am a title' . $delta, $result[0]
        ->get('title'));
      $this
        ->assertSame('I am a description' . $delta, $result[0]
        ->get('description'));
    }
    $result = $this->parser
      ->parse($this->feed, $fetcher_result, $this->state);
    $this
      ->assertCount(0, $result);
  }

  /**
   * Tests QueryPath validation.
   */
  public function testValidateExpression() {

    // Invalid expression.
    $expression = '!! ';
    $this
      ->assertSame('CSS selector is not well formed.', (string) $this
      ->invokeMethod($this->parser, 'validateExpression', [
      &$expression,
    ]));

    // Test that value was trimmed.
    $this
      ->assertSame($expression, '!!', 'Value was trimmed.');

    // Empty.
    $empty = '';
    $this
      ->assertSame(NULL, $this
      ->invokeMethod($this->parser, 'validateExpression', [
      &$empty,
    ]));
  }

  /**
   * Tests empty feed handling.
   */
  public function testEmptyFeed() {
    $this->parser
      ->parse($this->feed, new RawFetcherResult(' ', $this->fileSystem), $this->state);
    $this
      ->assertEmptyFeedMessage($this->parser
      ->getMessenger()
      ->getMessages());
  }

}

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.
ParserTestBase::$feed protected property The feed entity.
ParserTestBase::$feedType protected property The feed type entity.
ParserTestBase::$parser protected property The Feeds parser plugin.
ParserTestBase::$state protected property The state object.
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.
QueryPathXmlParserTest::setUp public function Overrides ParserTestBase::setUp
QueryPathXmlParserTest::testAttributeParsing public function Tests grabbing an attribute.
QueryPathXmlParserTest::testBatchParsing public function Tests that batch parsing works.
QueryPathXmlParserTest::testCp866Encoded public function Tests parsing a CP866 (Russian) encoded file.
QueryPathXmlParserTest::testEmptyFeed public function Tests empty feed handling.
QueryPathXmlParserTest::testEucJpEncodedNoDeclaration public function Tests a EUC-JP (Japanese) encoded file without the encoding declaration.
QueryPathXmlParserTest::testInner public function Tests inner xml.
QueryPathXmlParserTest::testMultipleAttributeParsing public function Tests grabbing multiple attributes.
QueryPathXmlParserTest::testRaw public function Tests raw parsing.
QueryPathXmlParserTest::testSimpleParsing public function Tests simple parsing.
QueryPathXmlParserTest::testValidateExpression public function Tests QueryPath validation.
UnitTestBase::$fileSystem protected property A mocked file system.
UnitTestBase::$moduleDir protected property The module directory.
UnitTestBase::assertEmptyFeedMessage protected function Asserts that the empty message is correct.
UnitTestBase::invokeMethod protected function Calls a private or protected method on an object.
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.