Show error in form if confirmation email fails

[MAILPOET-4736]
This commit is contained in:
Rostislav Wolny
2022-11-29 15:52:28 +01:00
committed by Aschepikov
parent ee83e4d748
commit 5a53406d33
2 changed files with 29 additions and 1 deletions

View File

@ -151,7 +151,7 @@ class SubscriberSubscribeController {
*/
$this->wp->doAction('mailpoet_subscription_before_subscribe', $data, $segmentIds, $form);
[$subscriber] = $this->subscriberActions->subscribe($data, $segmentIds);
[$subscriber, $subscriptionMeta] = $this->subscriberActions->subscribe($data, $segmentIds);
if (!empty($captchaSettings['type']) && $captchaSettings['type'] === CaptchaConstants::TYPE_BUILTIN) {
// Captcha has been verified, invalidate the session vars
@ -166,6 +166,12 @@ class SubscriberSubscribeController {
// add tags to subscriber if they are filled
$this->addTagsToSubscriber($formSettings['tags'] ?? [], $subscriber);
// Confirmation email failed. We want to show the error message
if ($subscriptionMeta['confirmationEmailResult'] instanceof \Exception) {
$meta['error'] = $subscriptionMeta['confirmationEmailResult']->getMessage();
return $meta;
}
if (!empty($formSettings['on_success'])) {
if ($formSettings['on_success'] === 'page') {
// redirect to a page on a success, pass the page url in the meta

View File

@ -91,6 +91,28 @@ class SubscriberSubscribeControllerTest extends \MailPoetTest {
expect($subscriber->getStatus())->equals(SubscriberEntity::STATUS_UNCONFIRMED);
}
public function testItReturnsInfoAboutErrorWhenConfirmationEmailFails(): void {
$confirmationEmailMailerMock = $this->createMock(ConfirmationEmailMailer::class);
$confirmationEmailMailerMock->method('sendConfirmationEmailOnce')
->willThrowException(new \Exception('Confirmation email error'));
$subscriberActions = $this->getServiceWithOverrides(SubscriberActions::class, ['confirmationEmailMailer' => $confirmationEmailMailerMock]);
$subscriberController = $this->getServiceWithOverrides(SubscriberSubscribeController::class, ['subscriberActions' => $subscriberActions]);
$segment = $this->segmentsRepository->createOrUpdate('Segment 1');
$form = $this->createForm($segment);
$data = [
$this->obfuscatedEmail => 'subscriber' . rand(0, 10000) . '@example.com',
$this->obfuscatedSegments => [$segment->getId()],
'form_id' => $form->getId(),
];
$result = $subscriberController->subscribe($data);
$subscriber = $this->subscribersRepository->findOneBy(['email' => $data[$this->obfuscatedEmail]]);
$this->assertInstanceOf(SubscriberEntity::class, $subscriber);
expect($result)->hasKey('error');
expect($result['error'])->equals('Confirmation email error');
}
public function testItCanSubscribeSubscriberWithCustomField(): void {
$this->settings->set('signup_confirmation.enabled', false);
$segment = $this->segmentsRepository->createOrUpdate('Segment 1');