mirror of
https://github.com/wallabag/wallabag.git
synced 2024-05-20 10:08:04 +00:00
7332d1f4e5
Updating deps - Removing electrolinux/php-html5lib (0.1.0) - Updating doctrine/inflector (1.3.1 => 1.4.3) - Updating doctrine/lexer (1.0.2 => 1.2.1) - Installing symfony/polyfill-php80 (v1.17.0) - Updating symfony/service-contracts (v1.1.8 => v2.1.2) - Installing symfony/deprecation-contracts (v2.1.2) - Updating symfony/mime (v4.4.8 => v5.1.1) - Updating friendsofsymfony/rest-bundle (2.7.4 => 2.8.0) - Updating doctrine/instantiator (1.3.0 => 1.3.1) - Updating ocramius/proxy-manager (2.1.1 => 2.2.3) - Updating php-http/discovery (1.7.4 => 1.8.0) - Updating symfony/http-client-contracts (v1.1.8 => v2.1.2) - Updating symfony/http-client (v4.4.8 => v5.1.1) - Updating php-http/httplug-bundle (1.16.0 => 1.18.0) - Updating symfony/phpunit-bridge (v4.3.11 => v5.1.1) - Updating doctrine/data-fixtures (1.3.3 => 1.4.3) - Updating composer/xdebug-handler (1.4.1 => 1.4.2) - Updating masterminds/html5 (2.7.0 => 2.7.1) - Updating j0k3r/php-readability (1.2.4 => 1.2.5) - Updating phpoption/phpoption (1.7.3 => 1.7.4) - Updating nikic/php-parser (v4.4.0 => v4.5.0) - Installing thecodingmachine/safe (v1.1.1) - Updating spomky-labs/otphp (v9.1.4 => v10.0.1) - Updating pagerfanta/pagerfanta (v2.1.3 => v2.3.0) Package white-october/pagerfanta-bundle is abandoned, you should avoid using it. Use babdev/pagerfanta-bundle instead. - Removing white-october/pagerfanta-bundle (v1.3.2) - Installing babdev/pagerfanta-bundle (v2.4.2) Upgrading PHPStan to 0.12 and use extension installer - Removing phpstan/phpdoc-parser (0.3.5) - Removing nette/utils (v3.1.2) - Removing nette/schema (v1.0.2) - Removing nette/robot-loader (v3.2.3) - Removing nette/php-generator (v3.4.0) - Removing nette/neon (v3.1.2) - Removing nette/finder (v2.5.2) - Removing nette/di (v3.0.4) - Removing nette/bootstrap (v3.0.2) - Updating phpstan/phpstan (0.11.19 => 0.12.29) - Updating phpstan/phpstan-doctrine (0.11.6 => 0.12.16) - Updating phpstan/phpstan-phpunit (0.11.2 => 0.12.11) - Updating phpstan/phpstan-symfony (0.11.6 => 0.12.6) - Installing phpstan/extension-installer (1.0.4) Upgrading jms/serializer-bundle to version 3 (and willdurand/hateoas-bundle to version 2) - Removing phpoption/phpoption (1.7.4) - Removing phpcollection/phpcollection (0.5.0) - Removing jms/parser-lib (1.0.0) - Updating jms/metadata (1.7.0 => 2.3.0) - Updating jms/serializer (1.14.1 => 3.7.0) - Updating jms/serializer-bundle (2.4.4 => 3.6.0) - Updating willdurand/hateoas (2.12.0 => 3.6.0) - Updating willdurand/hateoas-bundle (1.4.0 => 2.1.0) Upgrading dama/doctrine-test-bundle to version 6 - Updating dama/doctrine-test-bundle (v5.0.3 => v6.2.0)
239 lines
6.7 KiB
PHP
239 lines
6.7 KiB
PHP
<?php
|
|
|
|
namespace Tests\Wallabag\CoreBundle\Helper;
|
|
|
|
use Monolog\Handler\TestHandler;
|
|
use Monolog\Logger;
|
|
use PHPUnit\Framework\TestCase;
|
|
use Wallabag\CoreBundle\Entity\Config;
|
|
use Wallabag\CoreBundle\Entity\Entry;
|
|
use Wallabag\CoreBundle\Entity\Tag;
|
|
use Wallabag\CoreBundle\Entity\TaggingRule;
|
|
use Wallabag\CoreBundle\Helper\RuleBasedTagger;
|
|
use Wallabag\UserBundle\Entity\User;
|
|
|
|
class RuleBasedTaggerTest extends TestCase
|
|
{
|
|
private $rulerz;
|
|
private $tagRepository;
|
|
private $entryRepository;
|
|
private $tagger;
|
|
private $logger;
|
|
private $handler;
|
|
|
|
public function setUp(): void
|
|
{
|
|
$this->rulerz = $this->getRulerZMock();
|
|
$this->tagRepository = $this->getTagRepositoryMock();
|
|
$this->entryRepository = $this->getEntryRepositoryMock();
|
|
$this->logger = $this->getLogger();
|
|
$this->handler = new TestHandler();
|
|
$this->logger->pushHandler($this->handler);
|
|
|
|
$this->tagger = new RuleBasedTagger($this->rulerz, $this->tagRepository, $this->entryRepository, $this->logger);
|
|
}
|
|
|
|
public function testTagWithNoRule()
|
|
{
|
|
$entry = new Entry($this->getUser());
|
|
|
|
$this->tagger->tag($entry);
|
|
|
|
$this->assertTrue($entry->getTags()->isEmpty());
|
|
$records = $this->handler->getRecords();
|
|
$this->assertCount(0, $records);
|
|
}
|
|
|
|
public function testTagWithNoMatchingRule()
|
|
{
|
|
$taggingRule = $this->getTaggingRule('rule as string', ['foo', 'bar']);
|
|
$user = $this->getUser([$taggingRule]);
|
|
$entry = new Entry($user);
|
|
|
|
$this->rulerz
|
|
->expects($this->once())
|
|
->method('satisfies')
|
|
->with($entry, 'rule as string')
|
|
->willReturn(false);
|
|
|
|
$this->tagger->tag($entry);
|
|
|
|
$this->assertTrue($entry->getTags()->isEmpty());
|
|
$records = $this->handler->getRecords();
|
|
$this->assertCount(0, $records);
|
|
}
|
|
|
|
public function testTagWithAMatchingRule()
|
|
{
|
|
$taggingRule = $this->getTaggingRule('rule as string', ['foo', 'bar']);
|
|
$user = $this->getUser([$taggingRule]);
|
|
$entry = new Entry($user);
|
|
|
|
$this->rulerz
|
|
->expects($this->once())
|
|
->method('satisfies')
|
|
->with($entry, 'rule as string')
|
|
->willReturn(true);
|
|
|
|
$this->tagger->tag($entry);
|
|
|
|
$this->assertFalse($entry->getTags()->isEmpty());
|
|
|
|
$tags = $entry->getTags();
|
|
$this->assertSame('foo', $tags[0]->getLabel());
|
|
$this->assertSame('bar', $tags[1]->getLabel());
|
|
|
|
$records = $this->handler->getRecords();
|
|
$this->assertCount(1, $records);
|
|
}
|
|
|
|
public function testTagWithAMixOfMatchingRules()
|
|
{
|
|
$taggingRule = $this->getTaggingRule('bla bla', ['hey']);
|
|
$otherTaggingRule = $this->getTaggingRule('rule as string', ['foo']);
|
|
|
|
$user = $this->getUser([$taggingRule, $otherTaggingRule]);
|
|
$entry = new Entry($user);
|
|
|
|
$this->rulerz
|
|
->method('satisfies')
|
|
->will($this->onConsecutiveCalls(false, true));
|
|
|
|
$this->tagger->tag($entry);
|
|
|
|
$this->assertFalse($entry->getTags()->isEmpty());
|
|
|
|
$tags = $entry->getTags();
|
|
$this->assertSame('foo', $tags[0]->getLabel());
|
|
$records = $this->handler->getRecords();
|
|
$this->assertCount(1, $records);
|
|
}
|
|
|
|
public function testWhenTheTagExists()
|
|
{
|
|
$taggingRule = $this->getTaggingRule('rule as string', ['foo']);
|
|
$user = $this->getUser([$taggingRule]);
|
|
$entry = new Entry($user);
|
|
$tag = new Tag();
|
|
|
|
$this->rulerz
|
|
->expects($this->once())
|
|
->method('satisfies')
|
|
->with($entry, 'rule as string')
|
|
->willReturn(true);
|
|
|
|
$this->tagRepository
|
|
->expects($this->once())
|
|
// the method `findOneByLabel` doesn't exist, EntityRepository will then call `_call` method
|
|
// to magically call the `findOneBy` with ['label' => 'foo']
|
|
->method('__call')
|
|
->willReturn($tag);
|
|
|
|
$this->tagger->tag($entry);
|
|
|
|
$this->assertFalse($entry->getTags()->isEmpty());
|
|
|
|
$tags = $entry->getTags();
|
|
$this->assertSame($tag, $tags[0]);
|
|
$records = $this->handler->getRecords();
|
|
$this->assertCount(1, $records);
|
|
}
|
|
|
|
public function testSameTagWithDifferentfMatchingRules()
|
|
{
|
|
$taggingRule = $this->getTaggingRule('bla bla', ['hey']);
|
|
$otherTaggingRule = $this->getTaggingRule('rule as string', ['hey']);
|
|
|
|
$user = $this->getUser([$taggingRule, $otherTaggingRule]);
|
|
$entry = new Entry($user);
|
|
|
|
$this->rulerz
|
|
->method('satisfies')
|
|
->willReturn(true);
|
|
|
|
$this->tagger->tag($entry);
|
|
|
|
$this->assertFalse($entry->getTags()->isEmpty());
|
|
|
|
$tags = $entry->getTags();
|
|
$this->assertCount(1, $tags);
|
|
$records = $this->handler->getRecords();
|
|
$this->assertCount(2, $records);
|
|
}
|
|
|
|
public function testTagAllEntriesForAUser()
|
|
{
|
|
$taggingRule = $this->getTaggingRule('bla bla', ['hey']);
|
|
|
|
$user = $this->getUser([$taggingRule]);
|
|
|
|
$this->rulerz
|
|
->method('satisfies')
|
|
->willReturn(true);
|
|
|
|
$this->rulerz
|
|
->method('filter')
|
|
->willReturn([new Entry($user), new Entry($user)]);
|
|
|
|
$entries = $this->tagger->tagAllForUser($user);
|
|
|
|
$this->assertCount(2, $entries);
|
|
|
|
foreach ($entries as $entry) {
|
|
$tags = $entry->getTags();
|
|
|
|
$this->assertCount(1, $tags);
|
|
$this->assertSame('hey', $tags[0]->getLabel());
|
|
}
|
|
}
|
|
|
|
private function getUser(array $taggingRules = [])
|
|
{
|
|
$user = new User();
|
|
$config = new Config($user);
|
|
|
|
$user->setConfig($config);
|
|
|
|
foreach ($taggingRules as $rule) {
|
|
$config->addTaggingRule($rule);
|
|
}
|
|
|
|
return $user;
|
|
}
|
|
|
|
private function getTaggingRule($rule, array $tags)
|
|
{
|
|
$taggingRule = new TaggingRule();
|
|
$taggingRule->setRule($rule);
|
|
$taggingRule->setTags($tags);
|
|
|
|
return $taggingRule;
|
|
}
|
|
|
|
private function getRulerZMock()
|
|
{
|
|
return $this->getMockBuilder('RulerZ\RulerZ')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
|
|
private function getTagRepositoryMock()
|
|
{
|
|
return $this->getMockBuilder('Wallabag\CoreBundle\Repository\TagRepository')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
|
|
private function getEntryRepositoryMock()
|
|
{
|
|
return $this->getMockBuilder('Wallabag\CoreBundle\Repository\EntryRepository')
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
}
|
|
|
|
private function getLogger()
|
|
{
|
|
return new Logger('foo');
|
|
}
|
|
}
|