2015-12-30 13:26:30 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Wallabag\ImportBundle\Tests\Import;
|
|
|
|
|
|
|
|
use Wallabag\UserBundle\Entity\User;
|
|
|
|
use Wallabag\ImportBundle\Import\WallabagV1Import;
|
|
|
|
use Monolog\Logger;
|
|
|
|
use Monolog\Handler\TestHandler;
|
|
|
|
|
|
|
|
class WallabagV1ImportTest extends \PHPUnit_Framework_TestCase
|
|
|
|
{
|
|
|
|
protected $user;
|
|
|
|
protected $em;
|
|
|
|
protected $logHandler;
|
2016-02-11 13:27:17 +01:00
|
|
|
protected $contentProxy;
|
|
|
|
|
2015-12-30 13:26:30 +01:00
|
|
|
private function getWallabagV1Import($unsetUser = false)
|
|
|
|
{
|
|
|
|
$this->user = new User();
|
|
|
|
|
|
|
|
$this->em = $this->getMockBuilder('Doctrine\ORM\EntityManager')
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
2016-02-11 13:27:17 +01:00
|
|
|
$this->contentProxy = $this->getMockBuilder('Wallabag\CoreBundle\Helper\ContentProxy')
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
2016-02-11 13:39:21 +01:00
|
|
|
$wallabag = new WallabagV1Import($this->em, $this->contentProxy);
|
2015-12-30 13:26:30 +01:00
|
|
|
|
|
|
|
$this->logHandler = new TestHandler();
|
|
|
|
$logger = new Logger('test', array($this->logHandler));
|
2016-01-20 14:37:01 +01:00
|
|
|
$wallabag->setLogger($logger);
|
2015-12-30 13:26:30 +01:00
|
|
|
|
|
|
|
if (false === $unsetUser) {
|
2016-01-20 14:37:01 +01:00
|
|
|
$wallabag->setUser($this->user);
|
2015-12-30 13:26:30 +01:00
|
|
|
}
|
|
|
|
|
2016-01-20 14:37:01 +01:00
|
|
|
return $wallabag;
|
2015-12-30 13:26:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testInit()
|
|
|
|
{
|
|
|
|
$wallabagV1Import = $this->getWallabagV1Import();
|
|
|
|
|
2016-01-06 06:34:57 +01:00
|
|
|
$this->assertEquals('wallabag v1', $wallabagV1Import->getName());
|
2015-12-31 11:24:46 +01:00
|
|
|
$this->assertNotEmpty($wallabagV1Import->getUrl());
|
|
|
|
$this->assertContains('This importer will import all your wallabag v1 articles.', $wallabagV1Import->getDescription());
|
2015-12-30 13:26:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testImport()
|
|
|
|
{
|
|
|
|
$wallabagV1Import = $this->getWallabagV1Import();
|
|
|
|
$wallabagV1Import->setFilepath(__DIR__.'/../fixtures/wallabag-v1.json');
|
|
|
|
|
|
|
|
$entryRepo = $this->getMockBuilder('Wallabag\CoreBundle\Repository\EntryRepository')
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
2016-02-11 15:48:20 +01:00
|
|
|
$entryRepo->expects($this->exactly(4))
|
2016-01-15 15:28:22 +01:00
|
|
|
->method('findByUrlAndUserId')
|
2016-02-11 15:48:20 +01:00
|
|
|
->will($this->onConsecutiveCalls(false, true, false, false));
|
2015-12-30 13:26:30 +01:00
|
|
|
|
|
|
|
$this->em
|
|
|
|
->expects($this->any())
|
|
|
|
->method('getRepository')
|
|
|
|
->willReturn($entryRepo);
|
|
|
|
|
2016-02-11 15:48:20 +01:00
|
|
|
$entry = $this->getMockBuilder('Wallabag\CoreBundle\Entity\Entry')
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
|
|
|
$this->contentProxy
|
|
|
|
->expects($this->once())
|
|
|
|
->method('updateEntry')
|
|
|
|
->willReturn($entry);
|
|
|
|
|
2015-12-30 13:26:30 +01:00
|
|
|
$res = $wallabagV1Import->import();
|
|
|
|
|
|
|
|
$this->assertTrue($res);
|
2016-02-11 15:48:20 +01:00
|
|
|
$this->assertEquals(['skipped' => 1, 'imported' => 3], $wallabagV1Import->getSummary());
|
2016-03-04 10:04:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testImportAndMarkAllAsRead()
|
|
|
|
{
|
|
|
|
$wallabagV1Import = $this->getWallabagV1Import();
|
|
|
|
$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);
|
|
|
|
|
|
|
|
// check that every entry persisted are archived
|
|
|
|
$this->em
|
|
|
|
->expects($this->any())
|
|
|
|
->method('persist')
|
2016-03-08 15:22:35 +01:00
|
|
|
->with($this->callback(function ($persistedEntry) {
|
2016-03-04 10:04:51 +01:00
|
|
|
return $persistedEntry->isArchived();
|
|
|
|
}));
|
|
|
|
|
|
|
|
$res = $wallabagV1Import->setMarkAsRead(true)->import();
|
|
|
|
|
|
|
|
$this->assertTrue($res);
|
|
|
|
|
|
|
|
$this->assertEquals(['skipped' => 0, 'imported' => 3], $wallabagV1Import->getSummary());
|
2015-12-30 13:26:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testImportBadFile()
|
|
|
|
{
|
|
|
|
$wallabagV1Import = $this->getWallabagV1Import();
|
|
|
|
$wallabagV1Import->setFilepath(__DIR__.'/../fixtures/wallabag-v1.jsonx');
|
|
|
|
|
|
|
|
$res = $wallabagV1Import->import();
|
|
|
|
|
|
|
|
$this->assertFalse($res);
|
|
|
|
|
|
|
|
$records = $this->logHandler->getRecords();
|
2016-01-20 14:37:01 +01:00
|
|
|
$this->assertContains('WallabagImport: unable to read file', $records[0]['message']);
|
2015-12-30 13:26:30 +01:00
|
|
|
$this->assertEquals('ERROR', $records[0]['level_name']);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testImportUserNotDefined()
|
|
|
|
{
|
|
|
|
$wallabagV1Import = $this->getWallabagV1Import(true);
|
|
|
|
$wallabagV1Import->setFilepath(__DIR__.'/../fixtures/wallabag-v1.json');
|
|
|
|
|
|
|
|
$res = $wallabagV1Import->import();
|
|
|
|
|
|
|
|
$this->assertFalse($res);
|
|
|
|
|
|
|
|
$records = $this->logHandler->getRecords();
|
2016-01-20 14:37:01 +01:00
|
|
|
$this->assertContains('WallabagImport: user is not defined', $records[0]['message']);
|
2015-12-30 13:26:30 +01:00
|
|
|
$this->assertEquals('ERROR', $records[0]['level_name']);
|
|
|
|
}
|
|
|
|
}
|