Use doctrine entity in posts test

[MAILPOET-3027]
This commit is contained in:
Pavel Dohnal
2021-03-11 10:30:00 +01:00
committed by Veljko V
parent caad80a09c
commit 82bf183a6c
3 changed files with 30 additions and 21 deletions

View File

@@ -48,6 +48,7 @@ class Posts {
$newsletterPost = new NewsletterPostEntity($parent, $postId);
$this->newsletterPostRepository->persist($newsletterPost);
}
$this->newsletterPostRepository->flush();
$this->loggerFactory->getLogger(LoggerFactory::TOPIC_POST_NOTIFICATIONS)->addInfo(
'extract and save posts - after',
['newsletter_id' => $newsletter->getId(), 'matched_posts_ids' => $matchedPostsIds]

View File

@@ -3,8 +3,10 @@
namespace MailPoet\Test\Cron\Workers\SendingQueue\Tasks;
use MailPoet\Cron\Workers\SendingQueue\Tasks\Posts as PostsTask;
use MailPoet\DI\ContainerWrapper;
use MailPoet\Entities\NewsletterEntity;
use MailPoet\Entities\NewsletterPostEntity;
use MailPoet\Models\Newsletter;
use MailPoet\Newsletter\NewsletterPostsRepository;
class PostsTest extends \MailPoetTest {
@@ -17,10 +19,9 @@ class PostsTest extends \MailPoetTest {
}
public function testItFailsWhenNoPostsArePresent() {
$newsletter = (object)[
'id' => 1,
'type' => Newsletter::TYPE_NOTIFICATION_HISTORY,
];
$newsletter = new NewsletterEntity();
$newsletter->setType(NewsletterEntity::TYPE_NOTIFICATION_HISTORY);
$newsletter->setId(1);
$renderedNewsletter = [
'html' => 'Sample newsletter',
];
@@ -28,34 +29,42 @@ class PostsTest extends \MailPoetTest {
}
public function testItCanExtractAndSavePosts() {
$parent = new NewsletterEntity();
$parent->setType(NewsletterEntity::TYPE_NOTIFICATION);
$parent->setSubject('xx');
$newsletter = new NewsletterEntity();
$newsletter->setType(NewsletterEntity::TYPE_NOTIFICATION_HISTORY);
$newsletter->setSubject('xx');
$newsletter->setId(2);
$newsletter->setParent($parent);
$this->entityManager->persist($parent);
$this->entityManager->persist($newsletter);
$this->entityManager->flush();
$postId = 10;
$newsletter = (object)[
'id' => 2,
'parentId' => 1,
'type' => Newsletter::TYPE_NOTIFICATION_HISTORY,
];
$renderedNewsletter = [
'html' => '<a data-post-id="' . $postId . '" href="#">sample post</a>',
];
expect($this->postsTask->extractAndSave($renderedNewsletter, $newsletter))->equals(true);
$newsletterPost = NewsletterPost::where('newsletter_id', $newsletter->parentId)
->findOne();
assert($newsletterPost instanceof NewsletterPost);
expect($newsletterPost->postId)->equals($postId);
$newsletterPostRepository = ContainerWrapper::getInstance()->get(NewsletterPostsRepository::class);
$newsletterPost = $newsletterPostRepository->findOneBy(['newsletter' => $parent]);
expect($newsletterPost)->isInstanceOf(NewsletterPostEntity::class);
expect($newsletterPost->getPostId())->equals($postId);
}
public function testItDoesNotSavePostsWhenNewsletterIsNotANotificationHistory() {
$postId = 10;
$newsletter = (object)[
'id' => 2,
'parentId' => 1,
'type' => Newsletter::TYPE_WELCOME,
];
$parent = new NewsletterEntity();
$parent->setType(NewsletterEntity::TYPE_WELCOME);
$newsletter = new NewsletterEntity();
$newsletter->setType(NewsletterEntity::TYPE_WELCOME);
$newsletter->setId(2);
$newsletter->setParent($parent);
$renderedNewsletter = [
'html' => '<a data-post-id="' . $postId . '" href="#">sample post</a>',
];
expect($this->postsTask->extractAndSave($renderedNewsletter, $newsletter))->equals(false);
$newsletter->type = Newsletter::TYPE_STANDARD;
$newsletter->setType(NewsletterEntity::TYPE_STANDARD);
expect($this->postsTask->extractAndSave($renderedNewsletter, $newsletter))->equals(false);
}

View File

@@ -25,7 +25,6 @@ $models = [
'Newsletter',
'NewsletterLink',
'NewsletterLink',
'NewsletterPost',
'NewsletterSegment',
'NewsletterOption',
'NewsletterOptionField',