mirror of
https://github.com/shlinkio/shlink.git
synced 2024-11-22 08:56:42 -06:00
Improved TagServiceTest
This commit is contained in:
parent
963d26f59b
commit
286c24f8c0
@ -7,6 +7,7 @@ use Prophecy\Argument;
|
|||||||
use Prophecy\Prophecy\MethodProphecy;
|
use Prophecy\Prophecy\MethodProphecy;
|
||||||
use Prophecy\Prophecy\ObjectProphecy;
|
use Prophecy\Prophecy\ObjectProphecy;
|
||||||
use Shlinkio\Shlink\Core\Entity\Tag;
|
use Shlinkio\Shlink\Core\Entity\Tag;
|
||||||
|
use Shlinkio\Shlink\Core\Exception\EntityDoesNotExistException;
|
||||||
use Shlinkio\Shlink\Core\Repository\TagRepository;
|
use Shlinkio\Shlink\Core\Repository\TagRepository;
|
||||||
use Shlinkio\Shlink\Core\Service\Tag\TagService;
|
use Shlinkio\Shlink\Core\Service\Tag\TagService;
|
||||||
use PHPUnit\Framework\TestCase;
|
use PHPUnit\Framework\TestCase;
|
||||||
@ -88,4 +89,46 @@ class TagServiceTest extends TestCase
|
|||||||
$persist->shouldHaveBeenCalledTimes(2);
|
$persist->shouldHaveBeenCalledTimes(2);
|
||||||
$flush->shouldHaveBeenCalled();
|
$flush->shouldHaveBeenCalled();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function renameInvalidTagThrowsException()
|
||||||
|
{
|
||||||
|
$repo = $this->prophesize(TagRepository::class);
|
||||||
|
/** @var MethodProphecy $find */
|
||||||
|
$find = $repo->findOneBy(Argument::cetera())->willReturn(null);
|
||||||
|
/** @var MethodProphecy $getRepo */
|
||||||
|
$getRepo = $this->em->getRepository(Tag::class)->willReturn($repo->reveal());
|
||||||
|
|
||||||
|
$find->shouldBeCalled();
|
||||||
|
$getRepo->shouldBeCalled();
|
||||||
|
$this->expectException(EntityDoesNotExistException::class);
|
||||||
|
|
||||||
|
$this->service->renameTag('foo', 'bar');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function renameValidTagChangesItsName()
|
||||||
|
{
|
||||||
|
$expected = new Tag();
|
||||||
|
|
||||||
|
$repo = $this->prophesize(TagRepository::class);
|
||||||
|
/** @var MethodProphecy $find */
|
||||||
|
$find = $repo->findOneBy(Argument::cetera())->willReturn($expected);
|
||||||
|
/** @var MethodProphecy $getRepo */
|
||||||
|
$getRepo = $this->em->getRepository(Tag::class)->willReturn($repo->reveal());
|
||||||
|
/** @var MethodProphecy $flush */
|
||||||
|
$flush = $this->em->flush($expected)->willReturn(null);
|
||||||
|
|
||||||
|
$tag = $this->service->renameTag('foo', 'bar');
|
||||||
|
|
||||||
|
$this->assertSame($expected, $tag);
|
||||||
|
$this->assertEquals('bar', $tag->getName());
|
||||||
|
$find->shouldHaveBeenCalled();
|
||||||
|
$getRepo->shouldHaveBeenCalled();
|
||||||
|
$flush->shouldHaveBeenCalled();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user