| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-01 21:27:35 +02:00
										 |  |  | namespace Tests\Wallabag\ImportBundle\Import; | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-27 23:32:55 +02:00
										 |  |  | use Wallabag\ImportBundle\Import\WallabagV1Import; | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  | use Wallabag\UserBundle\Entity\User; | 
					
						
							| 
									
										
										
										
											2016-03-27 20:35:56 +02:00
										 |  |  | use Wallabag\CoreBundle\Entity\Entry; | 
					
						
							| 
									
										
										
										
											2016-09-09 21:02:03 +02:00
										 |  |  | use Wallabag\ImportBundle\Redis\Producer; | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  | use Monolog\Logger; | 
					
						
							|  |  |  | use Monolog\Handler\TestHandler; | 
					
						
							| 
									
										
										
										
											2016-09-09 21:02:03 +02:00
										 |  |  | use Simpleue\Queue\RedisQueue; | 
					
						
							|  |  |  | use M6Web\Component\RedisMock\RedisMockFactory; | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | class WallabagV1ImportTest extends \PHPUnit_Framework_TestCase | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     protected $user; | 
					
						
							|  |  |  |     protected $em; | 
					
						
							|  |  |  |     protected $logHandler; | 
					
						
							| 
									
										
										
										
											2016-02-11 13:27:17 +01:00
										 |  |  |     protected $contentProxy; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 07:10:23 +01:00
										 |  |  |     private function getWallabagV1Import($unsetUser = false, $dispatched = 0) | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $this->user = new User(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->em = $this->getMockBuilder('Doctrine\ORM\EntityManager') | 
					
						
							|  |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-25 11:26:15 +02:00
										 |  |  |         $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([]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 13:27:17 +01:00
										 |  |  |         $this->contentProxy = $this->getMockBuilder('Wallabag\CoreBundle\Helper\ContentProxy') | 
					
						
							|  |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 07:10:23 +01:00
										 |  |  |         $dispatcher = $this->getMockBuilder('Symfony\Component\EventDispatcher\EventDispatcher') | 
					
						
							|  |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $dispatcher | 
					
						
							|  |  |  |             ->expects($this->exactly($dispatched)) | 
					
						
							|  |  |  |             ->method('dispatch'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $wallabag = new WallabagV1Import($this->em, $this->contentProxy, $dispatcher); | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->logHandler = new TestHandler(); | 
					
						
							| 
									
										
										
										
											2016-04-12 11:36:01 +02:00
										 |  |  |         $logger = new Logger('test', [$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()); | 
					
						
							| 
									
										
										
										
											2016-03-09 08:59:08 +01:00
										 |  |  |         $this->assertEquals('import.wallabag_v1.description', $wallabagV1Import->getDescription()); | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testImport() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-11-02 07:10:23 +01:00
										 |  |  |         $wallabagV1Import = $this->getWallabagV1Import(false, 3); | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  |         $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 | 
					
						
							| 
									
										
										
										
											2016-03-27 20:35:56 +02:00
										 |  |  |             ->expects($this->exactly(3)) | 
					
						
							| 
									
										
										
										
											2016-02-11 15:48:20 +01:00
										 |  |  |             ->method('updateEntry') | 
					
						
							|  |  |  |             ->willReturn($entry); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  |         $res = $wallabagV1Import->import(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertTrue($res); | 
					
						
							| 
									
										
										
										
											2016-09-13 21:09:05 +02:00
										 |  |  |         $this->assertEquals(['skipped' => 1, 'imported' => 3, 'queued' => 0], $wallabagV1Import->getSummary()); | 
					
						
							| 
									
										
										
										
											2016-03-04 10:04:51 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testImportAndMarkAllAsRead() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-11-02 07:10:23 +01:00
										 |  |  |         $wallabagV1Import = $this->getWallabagV1Import(false, 3); | 
					
						
							| 
									
										
										
										
											2016-03-04 10:04:51 +01: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 20:35:56 +02:00
										 |  |  |         $this->contentProxy | 
					
						
							|  |  |  |             ->expects($this->exactly(3)) | 
					
						
							|  |  |  |             ->method('updateEntry') | 
					
						
							|  |  |  |             ->willReturn(new Entry($this->user)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-04 10:04:51 +01:00
										 |  |  |         // 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); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-13 21:09:05 +02:00
										 |  |  |         $this->assertEquals(['skipped' => 0, 'imported' => 3, 'queued' => 0], $wallabagV1Import->getSummary()); | 
					
						
							| 
									
										
										
										
											2016-09-09 18:02:29 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function testImportWithRabbit() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $wallabagV1Import = $this->getWallabagV1Import(); | 
					
						
							|  |  |  |         $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()) | 
					
						
							|  |  |  |             ->method('updateEntry'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $producer = $this->getMockBuilder('OldSound\RabbitMqBundle\RabbitMq\Producer') | 
					
						
							|  |  |  |             ->disableOriginalConstructor() | 
					
						
							|  |  |  |             ->getMock(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $producer | 
					
						
							|  |  |  |             ->expects($this->exactly(4)) | 
					
						
							|  |  |  |             ->method('publish'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-09 21:02:03 +02:00
										 |  |  |         $wallabagV1Import->setProducer($producer); | 
					
						
							| 
									
										
										
										
											2016-09-09 18:02:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $res = $wallabagV1Import->setMarkAsRead(true)->import(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->assertTrue($res); | 
					
						
							| 
									
										
										
										
											2016-09-13 21:09:05 +02:00
										 |  |  |         $this->assertEquals(['skipped' => 0, 'imported' => 0, 'queued' => 4], $wallabagV1Import->getSummary()); | 
					
						
							| 
									
										
										
										
											2015-12-30 13:26:30 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-09 21:02:03 +02:00
										 |  |  |     public function testImportWithRedis() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $wallabagV1Import = $this->getWallabagV1Import(); | 
					
						
							|  |  |  |         $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()) | 
					
						
							|  |  |  |             ->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); | 
					
						
							| 
									
										
										
										
											2016-09-13 21:09:05 +02:00
										 |  |  |         $this->assertEquals(['skipped' => 0, 'imported' => 0, 'queued' => 4], $wallabagV1Import->getSummary()); | 
					
						
							| 
									
										
										
										
											2016-09-09 21:02:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->assertNotEmpty($redisMock->lpop('wallabag_v1')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |