class LazySubscriberTest in Feeds 8.3
@coversDefaultClass \Drupal\feeds\EventSubscriber\LazySubscriber @group feeds
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\feeds\Unit\FeedsUnitTestCase uses FeedsMockingTrait, FeedsReflectionTrait
- class \Drupal\Tests\feeds\Unit\EventSubscriber\LazySubscriberTest
- class \Drupal\Tests\feeds\Unit\FeedsUnitTestCase uses FeedsMockingTrait, FeedsReflectionTrait
Expanded class hierarchy of LazySubscriberTest
File
- tests/
src/ Unit/ EventSubscriber/ LazySubscriberTest.php, line 22
Namespace
Drupal\Tests\feeds\Unit\EventSubscriberView source
class LazySubscriberTest extends FeedsUnitTestCase {
/**
* The event dispatcher.
*
* @var \Symfony\Component\EventDispatcher\EventDispatcher
*/
protected $dispatcher;
/**
* A second event dispatcher.
*
* @var \Symfony\Component\EventDispatcher\EventDispatcherInterface
*/
protected $explodingDispatcher;
/**
* The feed entity.
*
* @var \Drupal\feeds\FeedInterface
*/
protected $feed;
/**
* The state object.
*
* @var \Drupal\feeds\StateInterface
*/
protected $state;
/**
* The feed type entity.
*
* @var \Drupal\feeds\FeedTypeInterface
*/
protected $feedType;
/**
* The Feeds fetcher plugin.
*
* @var \Drupal\feeds\Plugin\Type\Fetcher\FetcherInterface
*/
protected $fetcher;
/**
* The Feeds parser plugin.
*
* @var \Drupal\feeds\Plugin\Type\Parser\ParserInterface
*/
protected $parser;
/**
* The Feeds processor plugin.
*
* @var \Drupal\feeds\Plugin\Type\Processor\ProcessorInterface
*/
protected $processor;
/**
* {@inheritdoc}
*/
public function setUp() {
parent::setUp();
$this->dispatcher = new EventDispatcher();
// Dispatcher used to verify things only get called once.
$this->explodingDispatcher = $this
->createMock('Symfony\\Component\\EventDispatcher\\EventDispatcherInterface');
$this->explodingDispatcher
->expects($this
->any())
->method('addListener')
->will($this
->throwException(new \Exception()));
$this->state = $this
->createMock('Drupal\\feeds\\StateInterface');
$this->feed = $this
->createMock('Drupal\\feeds\\FeedInterface');
$this->feed
->expects($this
->any())
->method('getState')
->will($this
->returnValue($this->state));
$this->feedType = $this
->createMock('Drupal\\feeds\\FeedTypeInterface');
$this->feedType
->expects($this
->any())
->method('getMappedSources')
->will($this
->returnValue([]));
$this->fetcher = $this
->createMock('Drupal\\feeds\\Plugin\\Type\\Fetcher\\FetcherInterface');
$this->parser = $this
->createMock('Drupal\\feeds\\Plugin\\Type\\Parser\\ParserInterface');
$this->processor = $this
->createMock('Drupal\\feeds\\Plugin\\Type\\Processor\\ProcessorInterface');
$this->feed
->expects($this
->any())
->method('getType')
->will($this
->returnValue($this->feedType));
}
/**
* @covers ::getSubscribedEvents
*/
public function testGetSubscribedEvents() {
$events = LazySubscriber::getSubscribedEvents();
$this
->assertSame(3, count($events));
}
/**
* @covers ::onInitImport
*/
public function testOnInitImport() {
$fetcher_result = $this
->createMock('Drupal\\feeds\\Result\\FetcherResultInterface');
$parser_result = new ParserResult();
$parser_result
->addItem(new DynamicItem());
$this->fetcher
->expects($this
->once())
->method('fetch')
->with($this->feed, $this->state)
->will($this
->returnValue($fetcher_result));
$this->parser
->expects($this
->once())
->method('parse')
->with($this->feed, $fetcher_result, $this->state)
->will($this
->returnValue($parser_result));
$this->processor
->expects($this
->once())
->method('process');
$this->feedType
->expects($this
->once())
->method('getFetcher')
->will($this
->returnValue($this->fetcher));
$this->feedType
->expects($this
->once())
->method('getParser')
->will($this
->returnValue($this->parser));
$this->feedType
->expects($this
->once())
->method('getProcessor')
->will($this
->returnValue($this->processor));
$subscriber = new LazySubscriber();
// Fetch.
$subscriber
->onInitImport(new InitEvent($this->feed, 'fetch'), FeedsEvents::INIT_IMPORT, $this->dispatcher);
$fetch_event = $this->dispatcher
->dispatch(FeedsEvents::FETCH, new FetchEvent($this->feed));
$this
->assertSame($fetcher_result, $fetch_event
->getFetcherResult());
// Parse.
$subscriber
->onInitImport(new InitEvent($this->feed, 'parse'), FeedsEvents::INIT_IMPORT, $this->dispatcher);
$parse_event = $this->dispatcher
->dispatch(FeedsEvents::PARSE, new ParseEvent($this->feed, $fetcher_result));
$this
->assertSame($parser_result, $parse_event
->getParserResult());
// Process.
$subscriber
->onInitImport(new InitEvent($this->feed, 'process'), FeedsEvents::INIT_IMPORT, $this->dispatcher);
foreach ($parse_event
->getParserResult() as $item) {
$this->dispatcher
->dispatch(FeedsEvents::PROCESS, new ProcessEvent($this->feed, $item));
}
// Call again.
$subscriber
->onInitImport(new InitEvent($this->feed, 'fetch'), FeedsEvents::INIT_IMPORT, $this->explodingDispatcher);
}
/**
* @covers ::onInitClear
*/
public function testOnInitClear() {
$clearable = $this
->createMock('Drupal\\feeds\\Plugin\\Type\\ClearableInterface');
$clearable
->expects($this
->exactly(2))
->method('clear')
->with($this->feed);
$this->feedType
->expects($this
->once())
->method('getPlugins')
->will($this
->returnValue([
$clearable,
$this->dispatcher,
$clearable,
]));
$subscriber = new LazySubscriber();
$subscriber
->onInitClear(new InitEvent($this->feed), FeedsEvents::INIT_CLEAR, $this->dispatcher);
$this->dispatcher
->dispatch(FeedsEvents::CLEAR, new ClearEvent($this->feed));
// Call again.
$subscriber
->onInitClear(new InitEvent($this->feed), FeedsEvents::INIT_CLEAR, $this->explodingDispatcher);
}
/**
* @covers ::onInitExpire
*/
public function testOnInitExpire() {
$this->feedType
->expects($this
->once())
->method('getProcessor')
->will($this
->returnValue($this->processor));
$this->processor
->expects($this
->once())
->method('expireItem')
->with($this->feed);
$subscriber = new LazySubscriber();
$subscriber
->onInitExpire(new InitEvent($this->feed), FeedsEvents::INIT_IMPORT, $this->dispatcher);
$this->dispatcher
->dispatch(FeedsEvents::EXPIRE, new ExpireEvent($this->feed, 1234));
// Call again.
$subscriber
->onInitExpire(new InitEvent($this->feed), FeedsEvents::INIT_IMPORT, $this->explodingDispatcher);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
FeedsMockingTrait:: |
protected | function | Mocks an account object. | |
FeedsMockingTrait:: |
protected | function | Returns a mocked AccountSwitcher object. | |
FeedsMockingTrait:: |
protected | function | Returns a mocked feed entity. | |
FeedsMockingTrait:: |
protected | function | Returns a mocked feed type entity. | |
FeedsMockingTrait:: |
protected | function | Mocks a field definition. | 1 |
FeedsMockingTrait:: |
protected | function | Mocks the file system. | |
FeedsReflectionTrait:: |
protected | function | Calls a protected method on the given object. | |
FeedsReflectionTrait:: |
protected | function | Gets a ReflectionMethod for a class method. | |
FeedsReflectionTrait:: |
protected | function | Returns a dynamically created closure for the object's method. | |
FeedsReflectionTrait:: |
protected | function | Sets a protected property. | |
FeedsUnitTestCase:: |
protected | function | Returns the absolute directory path of the Feeds module. | |
FeedsUnitTestCase:: |
protected | function | Defines stub constants. | |
FeedsUnitTestCase:: |
protected | function | Returns a mock stream wrapper manager. | |
FeedsUnitTestCase:: |
protected | function | Returns the absolute directory path of the resources folder. | |
LazySubscriberTest:: |
protected | property | The event dispatcher. | |
LazySubscriberTest:: |
protected | property | A second event dispatcher. | |
LazySubscriberTest:: |
protected | property | The feed entity. | |
LazySubscriberTest:: |
protected | property | The feed type entity. | |
LazySubscriberTest:: |
protected | property | The Feeds fetcher plugin. | |
LazySubscriberTest:: |
protected | property | The Feeds parser plugin. | |
LazySubscriberTest:: |
protected | property | The Feeds processor plugin. | |
LazySubscriberTest:: |
protected | property | The state object. | |
LazySubscriberTest:: |
public | function |
Overrides FeedsUnitTestCase:: |
|
LazySubscriberTest:: |
public | function | @covers ::getSubscribedEvents | |
LazySubscriberTest:: |
public | function | @covers ::onInitClear | |
LazySubscriberTest:: |
public | function | @covers ::onInitExpire | |
LazySubscriberTest:: |
public | function | @covers ::onInitImport | |
PhpunitCompatibilityTrait:: |
public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait:: |
public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | 1 |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Mocks a block with a block plugin. | 1 |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed array. | |
UnitTestCase:: |
public | function | Returns a stub config storage that returns the supplied configuration. | |
UnitTestCase:: |
protected | function | Sets up a container with a cache tags invalidator. | |
UnitTestCase:: |
protected | function | Gets the random generator for the utility methods. | |
UnitTestCase:: |
public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase:: |
public | function | Generates a unique random string containing letters and numbers. |