mirror of
https://github.com/wallabag/wallabag.git
synced 2025-02-17 03:05:19 +00:00
Merge pull request #6629 from wallabag/fix-6330
Fix duplicate tags creation when assigning search results to tag
This commit is contained in:
commit
633122cfb8
2 changed files with 15 additions and 3 deletions
|
@ -247,11 +247,16 @@ class TagController extends AbstractController
|
||||||
$filter
|
$filter
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->entityManager->persist($entry);
|
// check to avoid duplicate tags creation
|
||||||
|
foreach ($this->entityManager->getUnitOfWork()->getScheduledEntityInsertions() as $entity) {
|
||||||
|
if ($entity instanceof Tag && strtolower($entity->getLabel()) === strtolower($filter)) {
|
||||||
|
continue 2;
|
||||||
|
}
|
||||||
|
$this->entityManager->persist($entry);
|
||||||
|
}
|
||||||
|
$this->entityManager->flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->entityManager->flush();
|
|
||||||
|
|
||||||
return $this->redirect($this->redirectHelper->to($request->headers->get('referer'), '', true));
|
return $this->redirect($this->redirectHelper->to($request->headers->get('referer'), '', true));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -560,5 +560,12 @@ class TagControllerTest extends WallabagCoreTestCase
|
||||||
|
|
||||||
$this->assertContains('title', $tags);
|
$this->assertContains('title', $tags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$tag = $client->getContainer()
|
||||||
|
->get(EntityManagerInterface::class)
|
||||||
|
->getRepository(Tag::class)
|
||||||
|
->findByLabelsAndUser(['title'], $this->getLoggedInUserId());
|
||||||
|
|
||||||
|
$this->assertCount(1, $tag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue