Prevent duplicate terms being created
Within the `PostFactory` class, ensure that when using the `withTags` method and creating tag terms that an existing term doesn't already exist for a given name before trying to create it. With the previous implementation, there would be multiple terms if the PostFactory was used multiple times with the same tag name. Given that `PostFactory` now has a dependency on `EntityTypeManger`, this has been added as a service within `opdavies_blog_test` and needs to be resolved from the container before trying to use it within a test. This commit also updates the usages in `PostTest` so that those tests continue to work and pass. References #3
This commit is contained in:
parent
b90ca42e87
commit
059e237600
4 changed files with 41 additions and 10 deletions
|
@ -9,16 +9,20 @@ use Drupal\opdavies_blog_test\Factory\PostFactory;
|
|||
|
||||
final class RelatedPostsTest extends PostTestBase {
|
||||
|
||||
private PostFactory $postFactory;
|
||||
|
||||
private RelatedPostsRepository $relatedPostsRepository;
|
||||
|
||||
/** @test */
|
||||
public function it_returns_related_posts(): void {
|
||||
$postA = (new PostFactory())->setTitle('Post A')
|
||||
$postA = $this->postFactory
|
||||
->setTitle('Post A')
|
||||
->withTags(['Drupal 8'])
|
||||
->create();
|
||||
$postA->save();
|
||||
|
||||
$postB = (new PostFactory())->setTitle('Post B')
|
||||
$postB = $this->postFactory
|
||||
->setTitle('Post B')
|
||||
->withTags(['Drupal 8'])
|
||||
->create();
|
||||
$postB->save();
|
||||
|
@ -32,6 +36,7 @@ final class RelatedPostsTest extends PostTestBase {
|
|||
protected function setUp() {
|
||||
parent::setUp();
|
||||
|
||||
$this->postFactory = $this->container->get(PostFactory::class);
|
||||
$this->relatedPostsRepository = $this->container->get(RelatedPostsRepository::class);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue