wallabag/tests/Wallabag/ImportBundle/Import/WallabagV1ImportTest.php

272 lines
8.9 KiB
PHP
Raw Normal View History

2015-12-30 12:26:30 +00:00
<?php
2016-06-01 19:27:35 +00:00
namespace Tests\Wallabag\ImportBundle\Import;
2015-12-30 12:26:30 +00:00
2017-07-01 07:52:38 +00:00
use M6Web\Component\RedisMock\RedisMockFactory;
2015-12-30 12:26:30 +00:00
use Monolog\Handler\TestHandler;
2017-07-01 07:52:38 +00:00
use Monolog\Logger;
2017-12-16 21:17:42 +00:00
use PHPUnit\Framework\TestCase;
use Simpleue\Queue\RedisQueue;
2017-07-01 07:52:38 +00:00
use Wallabag\CoreBundle\Entity\Entry;
use Wallabag\ImportBundle\Import\WallabagV1Import;
use Wallabag\ImportBundle\Redis\Producer;
use Wallabag\UserBundle\Entity\User;
2015-12-30 12:26:30 +00:00
2017-12-16 21:17:42 +00:00
class WallabagV1ImportTest extends TestCase
2015-12-30 12:26:30 +00:00
{
protected $user;
protected $em;
protected $logHandler;
protected $contentProxy;
protected $tagsAssigner;
protected $uow;
protected $fetchingErrorMessageTitle = 'No title found';
protected $fetchingErrorMessage = 'wallabag can\'t retrieve contents for this article. Please <a href="http://doc.wallabag.org/en/master/user/errors_during_fetching.html#how-can-i-help-to-fix-that">troubleshoot this issue</a>.';
2015-12-30 12:26:30 +00:00
public function testInit()
{
$wallabagV1Import = $this->getWallabagV1Import();
2017-07-01 07:52:38 +00:00
$this->assertSame('wallabag v1', $wallabagV1Import->getName());
$this->assertNotEmpty($wallabagV1Import->getUrl());
2017-07-01 07:52:38 +00:00
$this->assertSame('import.wallabag_v1.description', $wallabagV1Import->getDescription());
2015-12-30 12:26:30 +00:00
}
public function testImport()
{
$wallabagV1Import = $this->getWallabagV1Import(false, 1);
2017-07-01 07:52:38 +00:00
$wallabagV1Import->setFilepath(__DIR__ . '/../fixtures/wallabag-v1.json');
2015-12-30 12:26:30 +00:00
$entryRepo = $this->getMockBuilder('Wallabag\CoreBundle\Repository\EntryRepository')
->disableOriginalConstructor()
->getMock();
$entryRepo->expects($this->exactly(2))
->method('findByUrlAndUserId')
2016-02-11 14:48:20 +00:00
->will($this->onConsecutiveCalls(false, true, false, false));
2015-12-30 12:26:30 +00:00
$this->em
->expects($this->any())
->method('getRepository')
->willReturn($entryRepo);
2016-02-11 14:48:20 +00:00
$entry = $this->getMockBuilder('Wallabag\CoreBundle\Entity\Entry')
->disableOriginalConstructor()
->getMock();
$this->contentProxy
->expects($this->exactly(1))
2017-06-01 09:31:45 +00:00
->method('updateEntry')
2016-02-11 14:48:20 +00:00
->willReturn($entry);
2015-12-30 12:26:30 +00:00
$res = $wallabagV1Import->import();
$this->assertTrue($res);
2017-07-01 07:52:38 +00:00
$this->assertSame(['skipped' => 1, 'imported' => 1, 'queued' => 0], $wallabagV1Import->getSummary());
}
public function testImportAndMarkAllAsRead()
{
2016-11-02 06:10:23 +00:00
$wallabagV1Import = $this->getWallabagV1Import(false, 3);
2017-07-01 07:52:38 +00:00
$wallabagV1Import->setFilepath(__DIR__ . '/../fixtures/wallabag-v1-read.json');
$entryRepo = $this->getMockBuilder('Wallabag\CoreBundle\Repository\EntryRepository')
->disableOriginalConstructor()
->getMock();
$entryRepo->expects($this->exactly(3))
->method('findByUrlAndUserId')
->will($this->onConsecutiveCalls(false, false, false));
$this->em
->expects($this->any())
->method('getRepository')
->willReturn($entryRepo);
2016-03-27 18:35:56 +00:00
$this->contentProxy
->expects($this->exactly(3))
2017-06-01 09:31:45 +00:00
->method('updateEntry')
2016-03-27 18:35:56 +00:00
->willReturn(new Entry($this->user));
// check that every entry persisted are archived
$this->em
->expects($this->any())
->method('persist')
2016-03-08 14:22:35 +00:00
->with($this->callback(function ($persistedEntry) {
2020-06-15 11:37:50 +00:00
return (bool) $persistedEntry->isArchived();
}));
$res = $wallabagV1Import->setMarkAsRead(true)->import();
$this->assertTrue($res);
2017-07-01 07:52:38 +00:00
$this->assertSame(['skipped' => 0, 'imported' => 3, 'queued' => 0], $wallabagV1Import->getSummary());
}
public function testImportWithRabbit()
{
$wallabagV1Import = $this->getWallabagV1Import();
2017-07-01 07:52:38 +00:00
$wallabagV1Import->setFilepath(__DIR__ . '/../fixtures/wallabag-v1.json');
$entryRepo = $this->getMockBuilder('Wallabag\CoreBundle\Repository\EntryRepository')
->disableOriginalConstructor()
->getMock();
$entryRepo->expects($this->never())
->method('findByUrlAndUserId');
$this->em
->expects($this->never())
->method('getRepository');
$entry = $this->getMockBuilder('Wallabag\CoreBundle\Entity\Entry')
->disableOriginalConstructor()
->getMock();
$this->contentProxy
->expects($this->never())
2017-06-01 09:31:45 +00:00
->method('updateEntry');
$producer = $this->getMockBuilder('OldSound\RabbitMqBundle\RabbitMq\Producer')
->disableOriginalConstructor()
->getMock();
$producer
->expects($this->exactly(2))
->method('publish');
$wallabagV1Import->setProducer($producer);
$res = $wallabagV1Import->setMarkAsRead(true)->import();
$this->assertTrue($res);
2017-07-01 07:52:38 +00:00
$this->assertSame(['skipped' => 0, 'imported' => 0, 'queued' => 2], $wallabagV1Import->getSummary());
2015-12-30 12:26:30 +00:00
}
public function testImportWithRedis()
{
$wallabagV1Import = $this->getWallabagV1Import();
2017-07-01 07:52:38 +00:00
$wallabagV1Import->setFilepath(__DIR__ . '/../fixtures/wallabag-v1.json');
$entryRepo = $this->getMockBuilder('Wallabag\CoreBundle\Repository\EntryRepository')
->disableOriginalConstructor()
->getMock();
$entryRepo->expects($this->never())
->method('findByUrlAndUserId');
$this->em
->expects($this->never())
->method('getRepository');
$entry = $this->getMockBuilder('Wallabag\CoreBundle\Entity\Entry')
->disableOriginalConstructor()
->getMock();
$this->contentProxy
->expects($this->never())
2017-06-01 09:31:45 +00:00
->method('updateEntry');
$factory = new RedisMockFactory();
$redisMock = $factory->getAdapter('Predis\Client', true);
$queue = new RedisQueue($redisMock, 'wallabag_v1');
$producer = new Producer($queue);
$wallabagV1Import->setProducer($producer);
$res = $wallabagV1Import->setMarkAsRead(true)->import();
$this->assertTrue($res);
2017-07-01 07:52:38 +00:00
$this->assertSame(['skipped' => 0, 'imported' => 0, 'queued' => 2], $wallabagV1Import->getSummary());
$this->assertNotEmpty($redisMock->lpop('wallabag_v1'));
}
2015-12-30 12:26:30 +00:00
public function testImportBadFile()
{
$wallabagV1Import = $this->getWallabagV1Import();
2017-07-01 07:52:38 +00:00
$wallabagV1Import->setFilepath(__DIR__ . '/../fixtures/wallabag-v1.jsonx');
2015-12-30 12:26:30 +00:00
$res = $wallabagV1Import->import();
$this->assertFalse($res);
$records = $this->logHandler->getRecords();
2020-06-15 11:37:50 +00:00
$this->assertStringContainsString('WallabagImport: unable to read file', $records[0]['message']);
2017-07-01 07:52:38 +00:00
$this->assertSame('ERROR', $records[0]['level_name']);
2015-12-30 12:26:30 +00:00
}
public function testImportUserNotDefined()
{
$wallabagV1Import = $this->getWallabagV1Import(true);
2017-07-01 07:52:38 +00:00
$wallabagV1Import->setFilepath(__DIR__ . '/../fixtures/wallabag-v1.json');
2015-12-30 12:26:30 +00:00
$res = $wallabagV1Import->import();
$this->assertFalse($res);
$records = $this->logHandler->getRecords();
2020-06-15 11:37:50 +00:00
$this->assertStringContainsString('WallabagImport: user is not defined', $records[0]['message']);
2017-07-01 07:52:38 +00:00
$this->assertSame('ERROR', $records[0]['level_name']);
}
private function getWallabagV1Import($unsetUser = false, $dispatched = 0)
{
$this->user = new User();
$this->em = $this->getMockBuilder('Doctrine\ORM\EntityManager')
->disableOriginalConstructor()
->getMock();
$this->uow = $this->getMockBuilder('Doctrine\ORM\UnitOfWork')
->disableOriginalConstructor()
->getMock();
$this->em
->expects($this->any())
->method('getUnitOfWork')
->willReturn($this->uow);
$this->uow
->expects($this->any())
->method('getScheduledEntityInsertions')
->willReturn([]);
$this->contentProxy = $this->getMockBuilder('Wallabag\CoreBundle\Helper\ContentProxy')
->disableOriginalConstructor()
->getMock();
$this->tagsAssigner = $this->getMockBuilder('Wallabag\CoreBundle\Helper\TagsAssigner')
->disableOriginalConstructor()
->getMock();
$dispatcher = $this->getMockBuilder('Symfony\Component\EventDispatcher\EventDispatcher')
->disableOriginalConstructor()
->getMock();
$dispatcher
->expects($this->exactly($dispatched))
->method('dispatch');
$wallabag = new WallabagV1Import(
$this->em,
$this->contentProxy,
$this->tagsAssigner,
$dispatcher,
$this->fetchingErrorMessageTitle,
$this->fetchingErrorMessage
);
$this->logHandler = new TestHandler();
$logger = new Logger('test', [$this->logHandler]);
$wallabag->setLogger($logger);
if (false === $unsetUser) {
$wallabag->setUser($this->user);
}
return $wallabag;
2015-12-30 12:26:30 +00:00
}
}