Refactor test
[MAILPOET-2653]
This commit is contained in:
@@ -7,6 +7,8 @@ use MailPoet\Doctrine\EntityTraits\AutoincrementedIdTrait;
|
|||||||
use MailPoet\Doctrine\EntityTraits\CreatedAtTrait;
|
use MailPoet\Doctrine\EntityTraits\CreatedAtTrait;
|
||||||
use MailPoet\Doctrine\EntityTraits\DeletedAtTrait;
|
use MailPoet\Doctrine\EntityTraits\DeletedAtTrait;
|
||||||
use MailPoet\Doctrine\EntityTraits\UpdatedAtTrait;
|
use MailPoet\Doctrine\EntityTraits\UpdatedAtTrait;
|
||||||
|
use MailPoetVendor\Doctrine\Common\Collections\ArrayCollection;
|
||||||
|
use MailPoetVendor\Doctrine\Common\Collections\Collection;
|
||||||
use MailPoetVendor\Doctrine\ORM\Mapping as ORM;
|
use MailPoetVendor\Doctrine\ORM\Mapping as ORM;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -116,6 +118,17 @@ class SubscriberEntity {
|
|||||||
*/
|
*/
|
||||||
private $linkToken;
|
private $linkToken;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\OneToMany(targetEntity="MailPoet\Entities\SubscriberSegmentEntity", mappedBy="subscriber")
|
||||||
|
* @var iterable<SubscriberSegmentEntity>&Collection
|
||||||
|
*/
|
||||||
|
private $subscriberSegments;
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
$this->subscriberSegments = new ArrayCollection();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return int|null
|
* @return int|null
|
||||||
*/
|
*/
|
||||||
@@ -346,4 +359,19 @@ class SubscriberEntity {
|
|||||||
public function setLinkToken($linkToken) {
|
public function setLinkToken($linkToken) {
|
||||||
$this->linkToken = $linkToken;
|
$this->linkToken = $linkToken;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Collection
|
||||||
|
*/
|
||||||
|
public function getSubscriberSegments() {
|
||||||
|
return $this->subscriberSegments;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getSegments() {
|
||||||
|
return $this->subscriberSegments->map(function (SubscriberSegmentEntity $subscriberSegment) {
|
||||||
|
return $subscriberSegment->getSegment();
|
||||||
|
})->filter(function ($segment) {
|
||||||
|
return $segment !== null;
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -4,8 +4,18 @@ namespace MailPoet\Test\API\JSON\v1;
|
|||||||
|
|
||||||
use Codeception\Util\Fixtures;
|
use Codeception\Util\Fixtures;
|
||||||
use MailPoet\API\JSON\Response as APIResponse;
|
use MailPoet\API\JSON\Response as APIResponse;
|
||||||
|
use MailPoet\API\JSON\ResponseBuilders\SubscribersResponseBuilder;
|
||||||
use MailPoet\API\JSON\v1\Subscribers;
|
use MailPoet\API\JSON\v1\Subscribers;
|
||||||
use MailPoet\DI\ContainerWrapper;
|
use MailPoet\DI\ContainerWrapper;
|
||||||
|
use MailPoet\Entities\CustomFieldEntity;
|
||||||
|
use MailPoet\Entities\FormEntity;
|
||||||
|
use MailPoet\Entities\NewsletterEntity;
|
||||||
|
use MailPoet\Entities\NewsletterOptionEntity;
|
||||||
|
use MailPoet\Entities\NewsletterOptionFieldEntity;
|
||||||
|
use MailPoet\Entities\SegmentEntity;
|
||||||
|
use MailPoet\Entities\SendingQueueEntity;
|
||||||
|
use MailPoet\Entities\SubscriberEntity;
|
||||||
|
use MailPoet\Entities\SubscriberSegmentEntity;
|
||||||
use MailPoet\Form\Util\FieldNameObfuscator;
|
use MailPoet\Form\Util\FieldNameObfuscator;
|
||||||
use MailPoet\Listing\BulkActionController;
|
use MailPoet\Listing\BulkActionController;
|
||||||
use MailPoet\Listing\Handler;
|
use MailPoet\Listing\Handler;
|
||||||
@@ -22,13 +32,13 @@ use MailPoet\Models\SubscriberSegment;
|
|||||||
use MailPoet\Segments\SubscribersListings;
|
use MailPoet\Segments\SubscribersListings;
|
||||||
use MailPoet\Settings\SettingsController;
|
use MailPoet\Settings\SettingsController;
|
||||||
use MailPoet\Settings\SettingsRepository;
|
use MailPoet\Settings\SettingsRepository;
|
||||||
use MailPoet\Statistics\StatisticsUnsubscribesRepository;
|
|
||||||
use MailPoet\Statistics\Track\Unsubscribes;
|
use MailPoet\Statistics\Track\Unsubscribes;
|
||||||
use MailPoet\Subscribers\ConfirmationEmailMailer;
|
use MailPoet\Subscribers\ConfirmationEmailMailer;
|
||||||
use MailPoet\Subscribers\LinkTokens;
|
use MailPoet\Subscribers\LinkTokens;
|
||||||
use MailPoet\Subscribers\RequiredCustomFieldValidator;
|
use MailPoet\Subscribers\RequiredCustomFieldValidator;
|
||||||
use MailPoet\Subscribers\Source;
|
use MailPoet\Subscribers\Source;
|
||||||
use MailPoet\Subscribers\SubscriberActions;
|
use MailPoet\Subscribers\SubscriberActions;
|
||||||
|
use MailPoet\Subscribers\SubscribersRepository;
|
||||||
use MailPoet\Subscription\Captcha;
|
use MailPoet\Subscription\Captcha;
|
||||||
use MailPoet\Subscription\CaptchaSession;
|
use MailPoet\Subscription\CaptchaSession;
|
||||||
use MailPoet\Subscription\SubscriptionUrlFactory;
|
use MailPoet\Subscription\SubscriptionUrlFactory;
|
||||||
@@ -37,11 +47,22 @@ use MailPoetVendor\Carbon\Carbon;
|
|||||||
use MailPoetVendor\Idiorm\ORM;
|
use MailPoetVendor\Idiorm\ORM;
|
||||||
|
|
||||||
class SubscribersTest extends \MailPoetTest {
|
class SubscribersTest extends \MailPoetTest {
|
||||||
|
|
||||||
|
/** @var FormEntity */
|
||||||
public $form;
|
public $form;
|
||||||
|
|
||||||
|
/** @var SubscriberEntity */
|
||||||
public $subscriber2;
|
public $subscriber2;
|
||||||
|
|
||||||
|
/** @var SubscriberEntity */
|
||||||
public $subscriber1;
|
public $subscriber1;
|
||||||
|
|
||||||
|
/** @var SegmentEntity */
|
||||||
public $segment2;
|
public $segment2;
|
||||||
|
|
||||||
|
/** @var SegmentEntity */
|
||||||
public $segment1;
|
public $segment1;
|
||||||
|
|
||||||
public $obfuscatedSegments;
|
public $obfuscatedSegments;
|
||||||
public $obfuscatedEmail;
|
public $obfuscatedEmail;
|
||||||
|
|
||||||
@@ -75,44 +96,58 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$container->get(ConfirmationEmailMailer::class),
|
$container->get(ConfirmationEmailMailer::class),
|
||||||
new SubscriptionUrlFactory($wp, $settings, new LinkTokens),
|
new SubscriptionUrlFactory($wp, $settings, new LinkTokens),
|
||||||
$container->get(Unsubscribes::class),
|
$container->get(Unsubscribes::class),
|
||||||
$container->get(StatisticsUnsubscribesRepository::class),
|
$container->get(SubscribersRepository::class),
|
||||||
|
$container->get(SubscribersResponseBuilder::class),
|
||||||
$obfuscator
|
$obfuscator
|
||||||
);
|
);
|
||||||
$this->obfuscatedEmail = $obfuscator->obfuscate('email');
|
$this->obfuscatedEmail = $obfuscator->obfuscate('email');
|
||||||
$this->obfuscatedSegments = $obfuscator->obfuscate('segments');
|
$this->obfuscatedSegments = $obfuscator->obfuscate('segments');
|
||||||
$this->segment1 = Segment::createOrUpdate(['name' => 'Segment 1']);
|
$this->segment1 = new SegmentEntity();
|
||||||
$this->segment2 = Segment::createOrUpdate(['name' => 'Segment 2']);
|
$this->segment1->setName('Segment 1');
|
||||||
|
$this->segment1->setDescription('Segment 1');
|
||||||
|
$this->segment1->setType(SegmentEntity::TYPE_DEFAULT);
|
||||||
|
$this->segment2 = new SegmentEntity();
|
||||||
|
$this->segment2->setName('Segment 2');
|
||||||
|
$this->segment2->setDescription('Segment 2');
|
||||||
|
$this->segment2->setType(SegmentEntity::TYPE_DEFAULT);
|
||||||
|
$this->entityManager->persist($this->segment1);
|
||||||
|
$this->entityManager->persist($this->segment2);
|
||||||
|
|
||||||
$this->subscriber1 = Subscriber::createOrUpdate([
|
|
||||||
'email' => 'john@mailpoet.com',
|
|
||||||
'first_name' => 'John',
|
|
||||||
'last_name' => 'Doe',
|
|
||||||
'status' => Subscriber::STATUS_UNCONFIRMED,
|
|
||||||
'source' => Source::API,
|
|
||||||
]);
|
|
||||||
$this->subscriber2 = Subscriber::createOrUpdate([
|
|
||||||
'email' => 'jane@mailpoet.com',
|
|
||||||
'first_name' => 'Jane',
|
|
||||||
'last_name' => 'Doe',
|
|
||||||
'status' => Subscriber::STATUS_SUBSCRIBED,
|
|
||||||
'segments' => [
|
|
||||||
$this->segment1->id,
|
|
||||||
$this->segment2->id,
|
|
||||||
],
|
|
||||||
'source' => Source::API,
|
|
||||||
]);
|
|
||||||
|
|
||||||
$this->form = Form::createOrUpdate([
|
$this->subscriber1 = new SubscriberEntity();
|
||||||
'name' => 'My Form',
|
$this->subscriber1->setEmail('john@mailpoet.com');
|
||||||
'body' => Fixtures::get('form_body_template'),
|
$this->subscriber1->setFirstName('John');
|
||||||
'settings' => [
|
$this->subscriber1->setLastName('Doe');
|
||||||
|
$this->subscriber1->setStatus(SubscriberEntity::STATUS_UNCONFIRMED);
|
||||||
|
$this->subscriber1->setSource(Source::API);
|
||||||
|
$this->entityManager->persist($this->subscriber1);
|
||||||
|
|
||||||
|
$this->subscriber2 = new SubscriberEntity();
|
||||||
|
$this->subscriber2->setEmail('jane@mailpoet.com');
|
||||||
|
$this->subscriber2->setFirstName('Jane');
|
||||||
|
$this->subscriber2->setLastName('Doe');
|
||||||
|
$this->subscriber2->setStatus(SubscriberEntity::STATUS_SUBSCRIBED);
|
||||||
|
$this->subscriber2->setSource(Source::API);
|
||||||
|
$this->entityManager->persist($this->subscriber2);
|
||||||
|
$this->entityManager->flush();
|
||||||
|
|
||||||
|
$this->entityManager->persist(
|
||||||
|
new SubscriberSegmentEntity($this->segment1, $this->subscriber2, SubscriberEntity::STATUS_SUBSCRIBED)
|
||||||
|
);
|
||||||
|
$this->entityManager->persist(
|
||||||
|
new SubscriberSegmentEntity($this->segment2, $this->subscriber2, SubscriberEntity::STATUS_SUBSCRIBED)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->form = new FormEntity('My Form');
|
||||||
|
$this->form->setBody(Fixtures::get('form_body_template'));
|
||||||
|
$this->form->setSettings([
|
||||||
'segments_selected_by' => 'user',
|
'segments_selected_by' => 'user',
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
$this->segment2->id,
|
$this->segment2->getId(),
|
||||||
],
|
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
$this->entityManager->persist($this->form);
|
||||||
|
|
||||||
$this->settings = SettingsController::getInstance();
|
$this->settings = SettingsController::getInstance();
|
||||||
// setup mailer
|
// setup mailer
|
||||||
@@ -120,6 +155,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'address' => 'sender@mailpoet.com',
|
'address' => 'sender@mailpoet.com',
|
||||||
'name' => 'Sender',
|
'name' => 'Sender',
|
||||||
]);
|
]);
|
||||||
|
$this->entityManager->flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanGetASubscriber() {
|
public function testItCanGetASubscriber() {
|
||||||
@@ -135,11 +171,11 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'This subscriber does not exist.'
|
'This subscriber does not exist.'
|
||||||
);
|
);
|
||||||
|
|
||||||
$response = $this->endpoint->get(['id' => $this->subscriber1->id]);
|
$response = $this->endpoint->get(['id' => $this->subscriber1->getId()]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->data['id'])->equals($this->subscriber1->id);
|
expect($response->data['id'])->equals($this->subscriber1->getId());
|
||||||
expect($response->data['first_name'])->equals($this->subscriber1->first_name);
|
expect($response->data['first_name'])->equals($this->subscriber1->getFirstName());
|
||||||
expect($response->data['email'])->equals($this->subscriber1->email);
|
expect($response->data['email'])->equals($this->subscriber1->getEmail());
|
||||||
expect($response->data['unsubscribes'])->equals([]);
|
expect($response->data['unsubscribes'])->equals([]);
|
||||||
expect($response->data['subscriptions'])->equals([]);
|
expect($response->data['subscriptions'])->equals([]);
|
||||||
}
|
}
|
||||||
@@ -150,24 +186,23 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'first_name' => 'Raul',
|
'first_name' => 'Raul',
|
||||||
'last_name' => 'Doe',
|
'last_name' => 'Doe',
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
$this->segment2->id,
|
$this->segment2->getId(),
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
$response = $this->endpoint->save($validData);
|
$response = $this->endpoint->save($validData);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->data)->equals(
|
$subscriberRepository = $this->diContainer->get(SubscribersRepository::class);
|
||||||
Subscriber::where('email', 'raul.doe@mailpoet.com')
|
$subscriber = $subscriberRepository->findOneBy(['email' => 'raul.doe@mailpoet.com']);
|
||||||
->findOne()
|
expect($response->data['email'])->equals('raul.doe@mailpoet.com');
|
||||||
->asArray()
|
expect($response->data['id'])->equals($subscriber->getId());
|
||||||
);
|
expect($response->data['status'])->equals($subscriber->getStatus());
|
||||||
|
|
||||||
$subscriber = Subscriber::where('email', 'raul.doe@mailpoet.com')->findOne();
|
$subscriberSegments = $subscriber->getSegments();
|
||||||
$subscriberSegments = $subscriber->segments()->findMany();
|
expect($subscriberSegments->count())->equals(2);
|
||||||
expect($subscriberSegments)->count(2);
|
expect($subscriberSegments->get(0)->getName())->equals($this->segment1->getName());
|
||||||
expect($subscriberSegments[0]->name)->equals($this->segment1->name);
|
expect($subscriberSegments->get(1)->getName())->equals($this->segment2->getName());
|
||||||
expect($subscriberSegments[1]->name)->equals($this->segment2->name);
|
|
||||||
|
|
||||||
$response = $this->endpoint->save(/* missing data */);
|
$response = $this->endpoint->save(/* missing data */);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
@@ -182,64 +217,73 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
expect($response->errors[0]['message'])
|
expect($response->errors[0]['message'])
|
||||||
->equals('Your email address is invalid!');
|
->equals('Your email address is invalid!');
|
||||||
expect($subscriber->source)->equals('administrator');
|
expect($subscriber->getSource())->equals('administrator');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanSaveAnExistingSubscriber() {
|
public function testItCanSaveAnExistingSubscriber() {
|
||||||
$subscriberData = $this->subscriber2->asArray();
|
$subscriberData = [
|
||||||
unset($subscriberData['created_at']);
|
'email' => 'jane@mailpoet.com',
|
||||||
$subscriberData['segments'] = [$this->segment1->id];
|
'first_name' => 'Super Jane',
|
||||||
$subscriberData['first_name'] = 'Super Jane';
|
'last_name' => 'Doe',
|
||||||
|
'status' => Subscriber::STATUS_SUBSCRIBED,
|
||||||
|
'segments' => [$this->segment1->getId()],
|
||||||
|
'source' => Source::API,
|
||||||
|
];
|
||||||
|
|
||||||
$response = $this->endpoint->save($subscriberData);
|
$response = $this->endpoint->save($subscriberData);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->data)->equals(
|
expect($response->data)->equals(
|
||||||
Subscriber::findOne($this->subscriber2->id)->asArray()
|
Subscriber::findOne($this->subscriber2->getId())->asArray()
|
||||||
);
|
);
|
||||||
expect($response->data['first_name'])->equals('Super Jane');
|
expect($response->data['first_name'])->equals('Super Jane');
|
||||||
expect($response->data['source'])->equals('api');
|
expect($response->data['source'])->equals('api');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanRemoveListsFromAnExistingSubscriber() {
|
public function testItCanRemoveListsFromAnExistingSubscriber() {
|
||||||
$subscriberData = $this->subscriber2->asArray();
|
$subscriberData = [
|
||||||
unset($subscriberData['created_at']);
|
'email' => 'jane@mailpoet.com',
|
||||||
unset($subscriberData['segments']);
|
'first_name' => 'Super Jane',
|
||||||
|
'last_name' => 'Doe',
|
||||||
|
'status' => Subscriber::STATUS_SUBSCRIBED,
|
||||||
|
'source' => Source::API,
|
||||||
|
];
|
||||||
|
|
||||||
$response = $this->endpoint->save($subscriberData);
|
$response = $this->endpoint->save($subscriberData);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->data)->equals(
|
expect($response->data)->equals(
|
||||||
Subscriber::findOne($this->subscriber2->id)->asArray()
|
Subscriber::findOne($this->subscriber2->getId())->asArray()
|
||||||
);
|
);
|
||||||
expect($this->subscriber2->segments()->findArray())->count(0);
|
expect($this->subscriber2->getSegments()->count())->equals(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanRestoreASubscriber() {
|
public function testItCanRestoreASubscriber() {
|
||||||
$this->subscriber1->trash();
|
$this->subscriber1->setDeletedAt(new \DateTime());
|
||||||
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$trashedSubscriber = Subscriber::findOne($this->subscriber1->id);
|
$response = $this->endpoint->restore(['id' => $this->subscriber1->getId()]);
|
||||||
expect($trashedSubscriber->deletedAt)->notNull();
|
|
||||||
|
|
||||||
$response = $this->endpoint->restore(['id' => $this->subscriber1->id]);
|
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->data)->equals(
|
$subscriberRepository = $this->diContainer->get(SubscribersRepository::class);
|
||||||
Subscriber::findOne($this->subscriber1->id)->asArray()
|
$subscriber = $subscriberRepository->findOneById($this->subscriber1->getId());
|
||||||
);
|
expect($response->data['id'])->equals($subscriber->getId());
|
||||||
|
expect($response->data['email'])->equals($subscriber->getEmail());
|
||||||
|
expect($response->data['status'])->equals($subscriber->getStatus());
|
||||||
expect($response->data['deleted_at'])->null();
|
expect($response->data['deleted_at'])->null();
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanTrashASubscriber() {
|
public function testItCanTrashASubscriber() {
|
||||||
$response = $this->endpoint->trash(['id' => $this->subscriber2->id]);
|
$response = $this->endpoint->trash(['id' => $this->subscriber2->getId()]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->data)->equals(
|
expect($response->data)->equals(
|
||||||
Subscriber::findOne($this->subscriber2->id)->asArray()
|
Subscriber::findOne($this->subscriber2->getId())->asArray()
|
||||||
);
|
);
|
||||||
expect($response->data['deleted_at'])->notNull();
|
expect($response->data['deleted_at'])->notNull();
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanDeleteASubscriber() {
|
public function testItCanDeleteASubscriber() {
|
||||||
$response = $this->endpoint->delete(['id' => $this->subscriber1->id]);
|
$response = $this->endpoint->delete(['id' => $this->subscriber1->getId()]);
|
||||||
expect($response->data)->isEmpty();
|
expect($response->data)->isEmpty();
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
@@ -259,22 +303,22 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
// filter by 1st segment
|
// filter by 1st segment
|
||||||
$response = $this->endpoint->listing([
|
$response = $this->endpoint->listing([
|
||||||
'filter' => [
|
'filter' => [
|
||||||
'segment' => $this->segment1->id,
|
'segment' => $this->segment1->getId(),
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
expect($response->data[0]['email'])->equals($this->subscriber2->email);
|
expect($response->data[0]['email'])->equals($this->subscriber2->getEmail());
|
||||||
|
|
||||||
// filter by 2nd segment
|
// filter by 2nd segment
|
||||||
$response = $this->endpoint->listing([
|
$response = $this->endpoint->listing([
|
||||||
'filter' => [
|
'filter' => [
|
||||||
'segment' => $this->segment2->id,
|
'segment' => $this->segment2->getId(),
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
expect($response->data[0]['email'])->equals($this->subscriber2->email);
|
expect($response->data[0]['email'])->equals($this->subscriber2->getEmail());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanAddSegmentsUsingHooks() {
|
public function testItCanAddSegmentsUsingHooks() {
|
||||||
@@ -284,18 +328,21 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
add_filter('mailpoet_subscribers_listings_filters_segments', $addSegment);
|
add_filter('mailpoet_subscribers_listings_filters_segments', $addSegment);
|
||||||
$response = $this->endpoint->listing([
|
$response = $this->endpoint->listing([
|
||||||
'filter' => [
|
'filter' => [
|
||||||
'segment' => $this->segment2->id,
|
'segment' => $this->segment2->getId(),
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
expect($response->meta['filters']['segment'])->equals('segment');
|
expect($response->meta['filters']['segment'])->equals('segment');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanSearchListing() {
|
public function testItCanSearchListing() {
|
||||||
$newSubscriber = Subscriber::createOrUpdate([
|
$newSubscriber = new SubscriberEntity();
|
||||||
'email' => 'search.me@find.me',
|
$newSubscriber->setEmail('search.me@find.me');
|
||||||
'first_name' => 'Billy Bob',
|
$newSubscriber->setFirstName('Billy Bob');
|
||||||
'last_name' => 'Thornton',
|
$newSubscriber->setLastName('Thornton');
|
||||||
]);
|
$newSubscriber->setStatus(SubscriberEntity::STATUS_SUBSCRIBED);
|
||||||
|
$newSubscriber->setSource(Source::API);
|
||||||
|
$this->entityManager->persist($newSubscriber);
|
||||||
|
$this->entityManager->flush();
|
||||||
|
|
||||||
// empty search returns everything
|
// empty search returns everything
|
||||||
$response = $this->endpoint->listing([
|
$response = $this->endpoint->listing([
|
||||||
@@ -308,22 +355,22 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'search' => '.me',
|
'search' => '.me',
|
||||||
]);
|
]);
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
expect($response->data[0]['email'])->equals($newSubscriber->email);
|
expect($response->data[0]['email'])->equals($newSubscriber->getEmail());
|
||||||
|
|
||||||
// search by last name
|
// search by last name
|
||||||
$response = $this->endpoint->listing([
|
$response = $this->endpoint->listing([
|
||||||
'search' => 'doe',
|
'search' => 'doe',
|
||||||
]);
|
]);
|
||||||
expect($response->meta['count'])->equals(2);
|
expect($response->meta['count'])->equals(2);
|
||||||
expect($response->data[0]['email'])->equals($this->subscriber1->email);
|
expect($response->data[0]['email'])->equals($this->subscriber1->getEmail());
|
||||||
expect($response->data[1]['email'])->equals($this->subscriber2->email);
|
expect($response->data[1]['email'])->equals($this->subscriber2->getEmail());
|
||||||
|
|
||||||
// search by first name
|
// search by first name
|
||||||
$response = $this->endpoint->listing([
|
$response = $this->endpoint->listing([
|
||||||
'search' => 'billy',
|
'search' => 'billy',
|
||||||
]);
|
]);
|
||||||
expect($response->meta['count'])->equals(1);
|
expect($response->meta['count'])->equals(1);
|
||||||
expect($response->data[0]['email'])->equals($newSubscriber->email);
|
expect($response->data[0]['email'])->equals($newSubscriber->getEmail());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanGroupListing() {
|
public function testItCanGroupListing() {
|
||||||
@@ -332,7 +379,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
]);
|
]);
|
||||||
expect($subscribedGroup->meta['count'])->equals(1);
|
expect($subscribedGroup->meta['count'])->equals(1);
|
||||||
expect($subscribedGroup->data[0]['email'])->equals(
|
expect($subscribedGroup->data[0]['email'])->equals(
|
||||||
$this->subscriber2->email
|
$this->subscriber2->getEmail()
|
||||||
);
|
);
|
||||||
|
|
||||||
$unsubscribedGroup = $this->endpoint->listing([
|
$unsubscribedGroup = $this->endpoint->listing([
|
||||||
@@ -345,7 +392,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
]);
|
]);
|
||||||
expect($unconfirmedGroup->meta['count'])->equals(1);
|
expect($unconfirmedGroup->meta['count'])->equals(1);
|
||||||
expect($unconfirmedGroup->data[0]['email'])->equals(
|
expect($unconfirmedGroup->data[0]['email'])->equals(
|
||||||
$this->subscriber1->email
|
$this->subscriber1->getEmail()
|
||||||
);
|
);
|
||||||
|
|
||||||
$trashedGroup = $this->endpoint->listing([
|
$trashedGroup = $this->endpoint->listing([
|
||||||
@@ -354,14 +401,15 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
expect($trashedGroup->meta['count'])->equals(0);
|
expect($trashedGroup->meta['count'])->equals(0);
|
||||||
|
|
||||||
// trash 1st subscriber
|
// trash 1st subscriber
|
||||||
$this->subscriber1->trash();
|
$this->subscriber1->setDeletedAt(new \DateTime());
|
||||||
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$trashedGroup = $this->endpoint->listing([
|
$trashedGroup = $this->endpoint->listing([
|
||||||
'group' => 'trash',
|
'group' => 'trash',
|
||||||
]);
|
]);
|
||||||
expect($trashedGroup->meta['count'])->equals(1);
|
expect($trashedGroup->meta['count'])->equals(1);
|
||||||
expect($trashedGroup->data[0]['email'])->equals(
|
expect($trashedGroup->data[0]['email'])->equals(
|
||||||
$this->subscriber1->email
|
$this->subscriber1->getEmail()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -400,7 +448,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
expect($response->meta['count'])->equals(2);
|
expect($response->meta['count'])->equals(2);
|
||||||
expect($response->data)->count(1);
|
expect($response->data)->count(1);
|
||||||
expect($response->data[0]['email'])->equals(
|
expect($response->data[0]['email'])->equals(
|
||||||
$this->subscriber2->email
|
$this->subscriber2->getEmail()
|
||||||
);
|
);
|
||||||
|
|
||||||
// get 1st page (limit items per page to 1)
|
// get 1st page (limit items per page to 1)
|
||||||
@@ -414,7 +462,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
expect($response->meta['count'])->equals(2);
|
expect($response->meta['count'])->equals(2);
|
||||||
expect($response->data)->count(1);
|
expect($response->data)->count(1);
|
||||||
expect($response->data[0]['email'])->equals(
|
expect($response->data[0]['email'])->equals(
|
||||||
$this->subscriber1->email
|
$this->subscriber1->getEmail()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -424,7 +472,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
$selectionIds = [
|
$selectionIds = [
|
||||||
$this->subscriber1->id,
|
$this->subscriber1->getId(),
|
||||||
$deletableSubscriber->id,
|
$deletableSubscriber->id,
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -439,7 +487,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
expect($response->meta['count'])->equals(count($selectionIds));
|
expect($response->meta['count'])->equals(count($selectionIds));
|
||||||
|
|
||||||
$isSubscriber1Deleted = (
|
$isSubscriber1Deleted = (
|
||||||
Subscriber::findOne($this->subscriber1->id) === false
|
Subscriber::findOne($this->subscriber1->getId()) === false
|
||||||
);
|
);
|
||||||
$isDeletableSubscriberDeleted = (
|
$isDeletableSubscriberDeleted = (
|
||||||
Subscriber::findOne($deletableSubscriber->id) === false
|
Subscriber::findOne($deletableSubscriber->id) === false
|
||||||
@@ -483,7 +531,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
|
|
||||||
public function testItFailsWithEmailFilled() {
|
public function testItFailsWithEmailFilled() {
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
'email' => 'toto@mailpoet.com',
|
'email' => 'toto@mailpoet.com',
|
||||||
// no form ID specified
|
// no form ID specified
|
||||||
]);
|
]);
|
||||||
@@ -505,7 +553,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
public function testItCannotSubscribeWithoutSegmentsIfTheyAreSelectedByUser() {
|
public function testItCannotSubscribeWithoutSegmentsIfTheyAreSelectedByUser() {
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
// no segments specified
|
// no segments specified
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@@ -516,9 +564,10 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
public function testItCanSubscribe() {
|
public function testItCanSubscribe() {
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -526,8 +575,8 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$this->settings->set('captcha', ['type' => Captcha::TYPE_RECAPTCHA]);
|
$this->settings->set('captcha', ['type' => Captcha::TYPE_RECAPTCHA]);
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
expect($response->errors[0]['message'])->equals('Please check the CAPTCHA.');
|
expect($response->errors[0]['message'])->equals('Please check the CAPTCHA.');
|
||||||
@@ -543,8 +592,8 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$subscriber->save();
|
$subscriber->save();
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => $email,
|
$this->obfuscatedEmail => $email,
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
expect($response->errors[0]['message'])->equals('Please fill in the CAPTCHA.');
|
expect($response->errors[0]['message'])->equals('Please fill in the CAPTCHA.');
|
||||||
@@ -564,9 +613,9 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$this->captchaSession->setCaptchaHash($captchaValue);
|
$this->captchaSession->setCaptchaHash($captchaValue);
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => $email,
|
$this->obfuscatedEmail => $email,
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
'captcha_session_id' => $captchaSessionId,
|
'captcha_session_id' => $captchaSessionId,
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
'captcha' => $captchaValue,
|
'captcha' => $captchaValue,
|
||||||
]);
|
]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
@@ -594,42 +643,43 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $form->id,
|
'form_id' => $form->id,
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanSubscribeWithoutSegmentsIfTheyAreSelectedByAdmin() {
|
public function testItCanSubscribeWithoutSegmentsIfTheyAreSelectedByAdmin() {
|
||||||
$form = $this->form->asArray();
|
$settings = $this->form->getSettings();
|
||||||
$form['settings']['segments_selected_by'] = 'admin';
|
$settings['segments_selected_by'] = 'admin';
|
||||||
$this->form->settings = $form['settings'];
|
$this->form->setSettings($settings);
|
||||||
$this->form->save();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
// no segments specified
|
// no segments specified
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
$subscriber = Subscriber::where('email', 'toto@mailpoet.com')->findOne();
|
$subscriberRepository = $this->diContainer->get(SubscribersRepository::class);
|
||||||
$subscriberSegments = $subscriber->segments()->findArray();
|
$subscriber = $subscriberRepository->findOneBy(['email' => 'toto@mailpoet.com']);
|
||||||
expect($subscriberSegments)->count(2);
|
$segments = $subscriber->getSegments();
|
||||||
expect($subscriberSegments[0]['id'])->equals($form['settings']['segments'][0]);
|
expect($segments->count())->equals(2);
|
||||||
expect($subscriberSegments[1]['id'])->equals($form['settings']['segments'][1]);
|
expect($segments->get(0)->getId())->equals($settings['segments'][0]);
|
||||||
|
expect($segments->get(1)->getId())->equals($settings['segments'][1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCannotSubscribeIfFormHasNoSegmentsDefined() {
|
public function testItCannotSubscribeIfFormHasNoSegmentsDefined() {
|
||||||
$form = $this->form->asArray();
|
$settings = $this->form->getSettings();
|
||||||
$form['settings']['segments_selected_by'] = 'admin';
|
$settings['segments_selected_by'] = 'admin';
|
||||||
unset($form['settings']['segments']);
|
$settings['segments'] = [];
|
||||||
$this->form->settings = $form['settings'];
|
$this->form->setSettings($settings);
|
||||||
$this->form->save();
|
$this->entityManager->flush();
|
||||||
|
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
@@ -641,14 +691,14 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
|
|
||||||
$this->endpoint->subscribe([
|
$this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'tata@mailpoet.com',
|
$this->obfuscatedEmail => 'tata@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
@@ -660,8 +710,8 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
|
|
||||||
$this->endpoint->subscribe([
|
$this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
$this->obfuscatedEmail => 'toto@mailpoet.com',
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// Try to resubscribe an existing subscriber that was updated just now
|
// Try to resubscribe an existing subscriber that was updated just now
|
||||||
@@ -672,8 +722,8 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
|
|
||||||
$response = $this->endpoint->subscribe([
|
$response = $this->endpoint->subscribe([
|
||||||
$this->obfuscatedEmail => $subscriber->email,
|
$this->obfuscatedEmail => $subscriber->email,
|
||||||
'form_id' => $this->form->id,
|
'form_id' => $this->form->getId(),
|
||||||
$this->obfuscatedSegments => [$this->segment1->id, $this->segment2->id],
|
$this->obfuscatedSegments => [$this->segment1->getId(), $this->segment2->getId()],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
expect($response->status)->equals(APIResponse::STATUS_BAD_REQUEST);
|
||||||
@@ -687,7 +737,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'first_name' => 'Raul',
|
'first_name' => 'Raul',
|
||||||
'last_name' => 'Doe',
|
'last_name' => 'Doe',
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -702,7 +752,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'first_name' => 'Raul',
|
'first_name' => 'Raul',
|
||||||
'last_name' => 'Doe',
|
'last_name' => 'Doe',
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment2->id,
|
$this->segment2->getId(),
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -710,7 +760,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$this->endpoint->save($subscriberData);
|
$this->endpoint->save($subscriberData);
|
||||||
expect(SendingQueue::findMany())->isEmpty();
|
expect(SendingQueue::findMany())->isEmpty();
|
||||||
|
|
||||||
$subscriberData['segments'] = [$this->segment1->id];
|
$subscriberData['segments'] = [$this->segment1->getId()];
|
||||||
$this->endpoint->save($subscriberData);
|
$this->endpoint->save($subscriberData);
|
||||||
expect(SendingQueue::findMany())->count(1);
|
expect(SendingQueue::findMany())->count(1);
|
||||||
}
|
}
|
||||||
@@ -723,7 +773,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'last_name' => 'Doe',
|
'last_name' => 'Doe',
|
||||||
'status' => Subscriber::STATUS_SUBSCRIBED,
|
'status' => Subscriber::STATUS_SUBSCRIBED,
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
],
|
],
|
||||||
'source' => Source::IMPORTED,
|
'source' => Source::IMPORTED,
|
||||||
]);
|
]);
|
||||||
@@ -733,7 +783,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'first_name' => 'Raul',
|
'first_name' => 'Raul',
|
||||||
'last_name' => 'Doe',
|
'last_name' => 'Doe',
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -745,13 +795,13 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$response = $this->endpoint->sendConfirmationEmail(['id' => 'non_existent']);
|
$response = $this->endpoint->sendConfirmationEmail(['id' => 'non_existent']);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_NOT_FOUND);
|
expect($response->status)->equals(APIResponse::STATUS_NOT_FOUND);
|
||||||
|
|
||||||
$response = $this->endpoint->sendConfirmationEmail(['id' => $this->subscriber1->id()]);
|
$response = $this->endpoint->sendConfirmationEmail(['id' => $this->subscriber1->getId()]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_OK);
|
expect($response->status)->equals(APIResponse::STATUS_OK);
|
||||||
|
|
||||||
wp_set_current_user(0);
|
wp_set_current_user(0);
|
||||||
$this->subscriber1->count_confirmations = ConfirmationEmailMailer::MAX_CONFIRMATION_EMAILS;
|
$this->subscriber1->setConfirmationsCount(ConfirmationEmailMailer::MAX_CONFIRMATION_EMAILS);
|
||||||
$this->subscriber1->save();
|
$this->entityManager->flush();
|
||||||
$response = $this->endpoint->sendConfirmationEmail(['id' => $this->subscriber1->id()]);
|
$response = $this->endpoint->sendConfirmationEmail(['id' => $this->subscriber1->getId()]);
|
||||||
expect($response->status)->equals(APIResponse::STATUS_NOT_FOUND);
|
expect($response->status)->equals(APIResponse::STATUS_NOT_FOUND);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -766,7 +816,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'last_name' => 'Commerce',
|
'last_name' => 'Commerce',
|
||||||
'status' => Subscriber::STATUS_SUBSCRIBED,
|
'status' => Subscriber::STATUS_SUBSCRIBED,
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
$wcSegment->id,
|
$wcSegment->id,
|
||||||
],
|
],
|
||||||
]);
|
]);
|
||||||
@@ -776,15 +826,16 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
'first_name' => 'Woo',
|
'first_name' => 'Woo',
|
||||||
'last_name' => 'Commerce',
|
'last_name' => 'Commerce',
|
||||||
'segments' => [
|
'segments' => [
|
||||||
$this->segment1->id,
|
$this->segment1->getId(),
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
$this->endpoint->save($subscriberData);
|
$this->endpoint->save($subscriberData);
|
||||||
|
|
||||||
$subscriber = Subscriber::findOne($subscriber->id);
|
$subscriberRepository = $this->diContainer->get(SubscribersRepository::class);
|
||||||
$subscriberSegments = $subscriber->segments()->findArray();
|
$subscriber = $subscriberRepository->findOneById($subscriber->id);
|
||||||
expect($subscriberSegments[0]['id'])->equals($this->segment1->id);
|
$segments = $subscriber->getSegments();
|
||||||
expect($subscriberSegments[1]['id'])->equals($wcSegment->id);
|
expect($segments->get(0)->getId())->equals($this->segment1->getId());
|
||||||
|
expect($segments->get(1)->getId())->equals($wcSegment->id);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function _createWelcomeNewsletter() {
|
private function _createWelcomeNewsletter() {
|
||||||
@@ -796,7 +847,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
|
|
||||||
$welcomeNewsletterOptions = [
|
$welcomeNewsletterOptions = [
|
||||||
'event' => 'segment',
|
'event' => 'segment',
|
||||||
'segment' => $this->segment1->id,
|
'segment' => $this->segment1->getId(),
|
||||||
'schedule' => '* * * * *',
|
'schedule' => '* * * * *',
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -810,7 +861,7 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
$newsletterOption = NewsletterOption::create();
|
$newsletterOption = NewsletterOption::create();
|
||||||
$newsletterOption->optionFieldId = (int)$newsletterOptionField->id;
|
$newsletterOption->optionFieldId = (int)$newsletterOptionField->id;
|
||||||
$newsletterOption->newsletterId = $welcomeNewsletter->id;
|
$newsletterOption->newsletterId = $welcomeNewsletter->id;
|
||||||
$newsletterOption->value = $value;
|
$newsletterOption->value = (string)$value;
|
||||||
$newsletterOption->save();
|
$newsletterOption->save();
|
||||||
expect($newsletterOption->getErrors())->false();
|
expect($newsletterOption->getErrors())->false();
|
||||||
}
|
}
|
||||||
@@ -821,15 +872,15 @@ class SubscribersTest extends \MailPoetTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private function cleanup() {
|
private function cleanup() {
|
||||||
ORM::raw_execute('TRUNCATE ' . Newsletter::$_table);
|
$this->truncateEntity(NewsletterEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . NewsletterOption::$_table);
|
$this->truncateEntity(NewsletterOptionEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . NewsletterOptionField::$_table);
|
$this->truncateEntity(NewsletterOptionFieldEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . Segment::$_table);
|
$this->truncateEntity(SegmentEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . SendingQueue::$_table);
|
$this->truncateEntity(SendingQueueEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . Subscriber::$_table);
|
$this->truncateEntity(SubscriberEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . SubscriberSegment::$_table);
|
$this->truncateEntity(SubscriberSegmentEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . SubscriberIP::$_table);
|
$this->truncateEntity(CustomFieldEntity::class);
|
||||||
ORM::raw_execute('TRUNCATE ' . CustomField::$_table);
|
|
||||||
$this->diContainer->get(SettingsRepository::class)->truncate();
|
$this->diContainer->get(SettingsRepository::class)->truncate();
|
||||||
|
ORM::raw_execute('TRUNCATE ' . SubscriberIP::$_table);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user