Files
piratepoet/mailpoet/tests/integration/Statistics/Track/OpensTest.php
Rostislav Wolny 5fdba0e170 Replace current_time usage in tests
[MAILPOET-6142]
2024-08-19 15:29:42 +02:00

423 lines
18 KiB
PHP

<?php declare(strict_types = 1);
namespace MailPoet\Test\Statistics\Track;
use Codeception\Stub;
use Codeception\Stub\Expected;
use MailPoet\Cron\Workers\SendingQueue\SendingQueue;
use MailPoet\Entities\NewsletterEntity;
use MailPoet\Entities\ScheduledTaskEntity;
use MailPoet\Entities\SendingQueueEntity;
use MailPoet\Entities\StatisticsOpenEntity;
use MailPoet\Entities\SubscriberEntity;
use MailPoet\Entities\UserAgentEntity;
use MailPoet\Statistics\StatisticsOpensRepository;
use MailPoet\Statistics\Track\Opens;
use MailPoet\Statistics\UserAgentsRepository;
use MailPoet\Subscribers\LinkTokens;
use MailPoet\Subscribers\SubscribersRepository;
use MailPoetVendor\Carbon\Carbon;
class OpensTest extends \MailPoetTest {
/** @var Opens */
public $opens;
/** @var \stdClass */
public $trackData;
/** @var SendingQueueEntity */
public $queue;
/** @var SubscriberEntity */
public $subscriber;
/** @var NewsletterEntity */
public $newsletter;
/** @var StatisticsOpensRepository */
private $statisticsOpensRepository;
public function _before() {
parent::_before();
// create newsletter
$newsletter = new NewsletterEntity();
$newsletter->setType('type');
$newsletter->setSubject('subject');
$this->entityManager->persist($newsletter);
$this->newsletter = $newsletter;
// create subscriber
$subscriber = new SubscriberEntity();
$subscriber->setEmail('test@example.com');
$subscriber->setFirstName('First');
$subscriber->setLastName('Last');
$subscriber->setLinkToken('token');
$this->subscriber = $subscriber;
$this->entityManager->persist($subscriber);
// create queue
$task = new ScheduledTaskEntity();
$task->setType(SendingQueue::TASK_TYPE);
$task->setStatus(ScheduledTaskEntity::STATUS_COMPLETED);
$this->entityManager->persist($task);
$queue = new SendingQueueEntity();
$queue->setNewsletter($newsletter);
$queue->setTask($task);
$newsletter->getQueues()->add($queue);
$this->entityManager->persist($queue);
$this->entityManager->flush();
$this->queue = $queue;
$linkTokens = $this->diContainer->get(LinkTokens::class);
// build track data
$this->trackData = (object)[
'queue' => $queue,
'subscriber' => $subscriber,
'newsletter' => $newsletter,
'subscriber_token' => $linkTokens->getToken($subscriber),
'preview' => false,
];
// instantiate class
$this->statisticsOpensRepository = $this->diContainer->get(StatisticsOpensRepository::class);
$this->opens = new Opens(
$this->statisticsOpensRepository,
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class)
);
}
public function testItReturnsImageWhenTrackDataIsEmpty() {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => Expected::exactly(1),
], $this);
$opens->track(false);
verify($this->statisticsOpensRepository->findAll())->empty();
}
public function testItDoesNotTrackOpenEventFromWpUserWhenPreviewIsEnabled() {
$data = $this->trackData;
$data->subscriber->setWpUserId(99);
$data->preview = true;
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($data);
verify($this->statisticsOpensRepository->findAll())->empty();
}
public function testItReturnsNothingWhenImageDisplayIsDisabled() {
verify($this->opens->track($this->trackData, $displayImage = false))->empty();
}
public function testItTracksOpenEvent() {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($this->trackData);
verify($this->statisticsOpensRepository->findAll())->notEmpty();
}
public function testItDoesNotTrackRepeatedOpenEvents() {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
for ($count = 0; $count <= 2; $count++) {
$opens->track($this->trackData);
}
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
}
public function testItReturnsImageAfterTracking() {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => Expected::exactly(1),
], $this);
$opens->track($this->trackData);
}
public function testItSavesNewUserAgent() {
$this->trackData->userAgent = 'User agent';
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($this->trackData);
$opens = $this->statisticsOpensRepository->findAll();
verify($opens)->arrayCount(1);
$open = $opens[0];
$userAgent = $open->getUserAgent();
verify($userAgent)->notNull();
}
public function testItSavesOpenWithExistingUserAgent() {
$this->entityManager->persist(new UserAgentEntity('User agent1'));
$this->entityManager->flush();
$this->trackData->userAgent = 'User agent1';
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($this->trackData);
$opens = $this->statisticsOpensRepository->findAll();
verify($opens)->arrayCount(1);
$open = $opens[0];
$userAgent = $open->getUserAgent();
verify($userAgent)->notNull();
$uaRepository = $this->diContainer->get(UserAgentsRepository::class);
$userAgents = $uaRepository->findBy(['userAgent' => 'User agent1']);
verify($userAgents)->arrayCount(1);
}
public function testItOverridesOldUserAgent() {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$this->trackData->userAgent = 'User agent2';
$opens->track($this->trackData);
$this->trackData->userAgent = 'User agent3';
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$opens = $this->statisticsOpensRepository->findAll();
verify($opens)->arrayCount(1);
$open = $opens[0];
$userAgent = $open->getUserAgent();
$this->assertInstanceOf(UserAgentEntity::class, $userAgent);
verify($userAgent->getUserAgent())->equals('User agent3');
}
public function testItDoesNotOverrideHumanUserAgentWithMachine(): void {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
// Track Human User Agent
$humanUserAgentName = 'Human User Agent';
$this->trackData->userAgent = $humanUserAgentName;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
$userAgent = $openEntity->getUserAgent();
$this->assertInstanceOf(UserAgentEntity::class, $userAgent);
verify($userAgent->getUserAgent())->equals($humanUserAgentName);
verify($userAgent->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
// Track Machine User Agent
$machineUserAgentName = UserAgentEntity::MACHINE_USER_AGENTS[0];
$this->trackData->userAgent = $machineUserAgentName;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
$userAgent = $openEntity->getUserAgent();
$this->assertInstanceOf(UserAgentEntity::class, $userAgent);
verify($userAgent->getUserAgent())->equals($humanUserAgentName);
verify($userAgent->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
}
public function testItOverridesMachineUserAgentWithHuman(): void {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
// Track Machine User Agent
$machineUserAgentName = UserAgentEntity::MACHINE_USER_AGENTS[0];
$this->trackData->userAgent = $machineUserAgentName;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
$userAgent = $openEntity->getUserAgent();
$this->assertInstanceOf(UserAgentEntity::class, $userAgent);
verify($userAgent->getUserAgent())->equals($machineUserAgentName);
verify($userAgent->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_MACHINE);
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_MACHINE);
// Track Human User Agent
$humanUserAgentName = 'Human User Agent';
$this->trackData->userAgent = $humanUserAgentName;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
$userAgent = $openEntity->getUserAgent();
$this->assertInstanceOf(UserAgentEntity::class, $userAgent);
verify($userAgent->getUserAgent())->equals($humanUserAgentName);
verify($userAgent->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
}
public function testItDoesNotOverrideUnknownUserAgentWithMachine(): void {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
// Track Unknown User Agent
$this->trackData->userAgent = null;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
verify($openEntity->getUserAgent())->null();
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
// Track Machine User Agent
$machineUserAgentName = UserAgentEntity::MACHINE_USER_AGENTS[0];
$this->trackData->userAgent = $machineUserAgentName;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
verify($openEntity->getUserAgent())->null();
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
}
public function testItOverridesUnknownUserAgentWithHuman(): void {
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
// Track Unknown User Agent
$this->trackData->userAgent = null;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
verify($openEntity->getUserAgent())->null();
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
// Track Human User Agent
$humanUserAgentName = 'User Agent';
$this->trackData->userAgent = $humanUserAgentName;
$opens->track($this->trackData);
verify(count($this->statisticsOpensRepository->findAll()))->equals(1);
$openEntities = $this->statisticsOpensRepository->findAll();
verify($openEntities)->arrayCount(1);
$openEntity = reset($openEntities);
$this->assertInstanceOf(StatisticsOpenEntity::class, $openEntity);
$userAgent = $openEntity->getUserAgent();
$this->assertInstanceOf(UserAgentEntity::class, $userAgent);
verify($userAgent->getUserAgent())->equals($humanUserAgentName);
verify($userAgent->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
verify($openEntity->getUserAgentType())->equals(UserAgentEntity::USER_AGENT_TYPE_HUMAN);
}
public function testItUpdatesSubscriberEngagementForHumanAgent() {
$now = Carbon::now();
Carbon::setTestNow($now);
$this->trackData->userAgent = 'User agent';
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($this->trackData);
$savedEngagementTime = $this->subscriber->getLastEngagementAt();
$savedOpenTime = $this->subscriber->getLastOpenAt();
$this->assertInstanceOf(\DateTimeInterface::class, $savedEngagementTime);
$this->assertInstanceOf(\DateTimeInterface::class, $savedOpenTime);
verify($savedEngagementTime->getTimestamp())->equals($now->getTimestamp());
verify($savedOpenTime->getTimestamp())->equals($now->getTimestamp());
Carbon::setTestNow();
}
public function testItUpdatesSubscriberEngagementForUnknownAgent() {
$now = Carbon::now();
Carbon::setTestNow($now);
$this->trackData->userAgent = null;
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($this->trackData);
$savedEngagementTime = $this->subscriber->getLastEngagementAt();
$savedOpenTime = $this->subscriber->getLastOpenAt();
$this->assertInstanceOf(\DateTimeInterface::class, $savedEngagementTime);
$this->assertInstanceOf(\DateTimeInterface::class, $savedOpenTime);
verify($savedEngagementTime->getTimestamp())->equals($now->getTimestamp());
verify($savedOpenTime->getTimestamp())->equals($now->getTimestamp());
Carbon::setTestNow();
}
public function testItUpdatesSubscriberTimestampsForMachineAgent() {
$now = Carbon::now();
Carbon::setTestNow($now);
$this->trackData->userAgent = UserAgentEntity::MACHINE_USER_AGENTS[0];
$opens = Stub::construct($this->opens, [
$this->diContainer->get(StatisticsOpensRepository::class),
$this->diContainer->get(UserAgentsRepository::class),
$this->diContainer->get(SubscribersRepository::class),
], [
'returnResponse' => null,
], $this);
$opens->track($this->trackData);
$savedEngagementTime = $this->subscriber->getLastEngagementAt();
$savedOpenTime = $this->subscriber->getLastOpenAt();
$this->assertInstanceOf(\DateTimeInterface::class, $savedEngagementTime);
$this->assertInstanceOf(\DateTimeInterface::class, $savedOpenTime);
verify($savedEngagementTime->getTimestamp())->equals($now->getTimestamp());
verify($savedOpenTime->getTimestamp())->equals($now->getTimestamp());
Carbon::setTestNow();
}
}