- added default values to not null columns - fixed passing by reference issue on MailChimp->getDataCenter - fixed a couple unit tests
206 lines
6.4 KiB
PHP
206 lines
6.4 KiB
PHP
<?php
|
|
use \MailPoet\Router\Newsletters;
|
|
use \MailPoet\Models\Newsletter;
|
|
use \MailPoet\Models\NewsletterSegment;
|
|
use \MailPoet\Models\NewsletterTemplate;
|
|
use \MailPoet\Models\Segment;
|
|
|
|
class NewslettersTest extends MailPoetTest {
|
|
function _before() {
|
|
$this->newsletter = Newsletter::createOrUpdate(array(
|
|
'subject' => 'My Standard Newsletter',
|
|
'type' => 'standard'
|
|
));
|
|
|
|
$this->post_notification = Newsletter::createOrUpdate(array(
|
|
'subject' => 'My Post Notification',
|
|
'type' => 'notification'
|
|
));
|
|
}
|
|
|
|
function testItCanGetANewsletter() {
|
|
$router = new Newsletters();
|
|
|
|
$response = $router->get($this->newsletter->id());
|
|
expect($response['id'])->equals($this->newsletter->id());
|
|
|
|
$response = $router->get('not_an_id');
|
|
expect($response)->false();
|
|
|
|
$response = $router->get(/* missing argument */);
|
|
expect($response)->false();
|
|
}
|
|
|
|
function testItCanSaveANewNewsletter() {
|
|
$valid_data = array(
|
|
'subject' => 'My First Newsletter',
|
|
'type' => 'standard'
|
|
);
|
|
|
|
$router = new Newsletters();
|
|
$response = $router->save($valid_data);
|
|
expect($response['result'])->true();
|
|
expect($response)->hasntKey('errors');
|
|
|
|
$invalid_data = array(
|
|
'subject' => 'Missing newsletter type'
|
|
);
|
|
|
|
$response = $router->save($invalid_data);
|
|
expect($response['result'])->false();
|
|
expect($response['errors'][0])->equals('You need to specify a type.');
|
|
}
|
|
|
|
function testItCanSaveAnExistingNewsletter() {
|
|
$router = new Newsletters();
|
|
$newsletter_data = array(
|
|
'id' => $this->newsletter->id,
|
|
'subject' => 'My Updated Newsletter'
|
|
);
|
|
|
|
$response = $router->save($newsletter_data);
|
|
expect($response['result'])->true();
|
|
|
|
$updated_newsletter = Newsletter::findOne($this->newsletter->id());
|
|
expect($updated_newsletter->subject)->equals('My Updated Newsletter');
|
|
}
|
|
|
|
function testItCanRestoreANewsletter() {
|
|
$this->newsletter->trash();
|
|
|
|
expect($this->newsletter->deleted_at)->notNull();
|
|
|
|
$router = new Newsletters();
|
|
$router->restore($this->newsletter->id());
|
|
|
|
$restored_subscriber = Newsletter::findOne($this->newsletter->id());
|
|
expect($restored_subscriber->deleted_at)->null();
|
|
}
|
|
|
|
function testItCanTrashANewsletter() {
|
|
$router = new Newsletters();
|
|
$response = $router->trash($this->newsletter->id());
|
|
expect($response)->true();
|
|
|
|
$trashed_subscriber = Newsletter::findOne($this->newsletter->id());
|
|
expect($trashed_subscriber->deleted_at)->notNull();
|
|
}
|
|
|
|
function testItCanDeleteANewsletter() {
|
|
$router = new Newsletters();
|
|
$response = $router->delete($this->newsletter->id());
|
|
expect($response)->equals(1);
|
|
|
|
expect(Newsletter::findOne($this->newsletter->id()))->false();
|
|
}
|
|
|
|
function testItCanDuplicateANewsletter() {
|
|
$router = new Newsletters();
|
|
$response = $router->duplicate($this->newsletter->id());
|
|
expect($response['subject'])->equals('Copy of My Standard Newsletter');
|
|
expect($response['type'])->equals('standard');
|
|
expect($response['body'])->equals($this->newsletter->body);
|
|
|
|
$response = $router->duplicate($this->post_notification->id());
|
|
expect($response['subject'])->equals('Copy of My Post Notification');
|
|
expect($response['type'])->equals('notification');
|
|
expect($response['body'])->equals($this->post_notification->body);
|
|
}
|
|
|
|
function testItCanCreateANewsletter() {
|
|
$data = array(
|
|
'subject' => 'My New Newsletter',
|
|
'type' => 'standard'
|
|
);
|
|
$router = new Newsletters();
|
|
$response = $router->create($data);
|
|
expect($response['result'])->true();
|
|
expect($response['newsletter']['id'] > 0)->true();
|
|
expect($response['newsletter']['subject'])->equals('My New Newsletter');
|
|
expect($response['newsletter']['type'])->equals('standard');
|
|
expect($response['newsletter']['body'])->equals(array());
|
|
expect($response)->hasntKey('errors');
|
|
|
|
$response = $router->create();
|
|
expect($response['result'])->false();
|
|
expect($response['errors'][0])->equals('You need to specify a type.');
|
|
}
|
|
|
|
function testItCanGetListingData() {
|
|
$segment_1 = Segment::createOrUpdate(array('name' => 'Segment 1'));
|
|
$segment_2 = Segment::createOrUpdate(array('name' => 'Segment 2'));
|
|
|
|
$newsletter_segment = NewsletterSegment::create();
|
|
$newsletter_segment->hydrate(array(
|
|
'newsletter_id' => $this->newsletter->id(),
|
|
'segment_id' => $segment_1->id()
|
|
));
|
|
$newsletter_segment->save();
|
|
|
|
$newsletter_segment = NewsletterSegment::create();
|
|
$newsletter_segment->hydrate(array(
|
|
'newsletter_id' => $this->newsletter->id(),
|
|
'segment_id' => $segment_2->id()
|
|
));
|
|
$newsletter_segment->save();
|
|
|
|
$newsletter_segment = NewsletterSegment::create();
|
|
$newsletter_segment->hydrate(array(
|
|
'newsletter_id' => $this->post_notification->id(),
|
|
'segment_id' => $segment_2->id()
|
|
));
|
|
$newsletter_segment->save();
|
|
|
|
$router = new Newsletters();
|
|
$response = $router->listing();
|
|
|
|
expect($response)->hasKey('filters');
|
|
expect($response)->hasKey('groups');
|
|
|
|
expect($response['count'])->equals(2);
|
|
expect($response['items'])->count(2);
|
|
|
|
expect($response['items'][0]['subject'])->equals('My Standard Newsletter');
|
|
expect($response['items'][1]['subject'])->equals('My Post Notification');
|
|
|
|
// 1st subscriber has 2 segments
|
|
expect($response['items'][0]['segments'])->count(2);
|
|
expect($response['items'][0]['segments'][0]['id'])
|
|
->equals($segment_1->id);
|
|
expect($response['items'][0]['segments'][1]['id'])
|
|
->equals($segment_2->id);
|
|
|
|
// 2nd subscriber has 1 segment
|
|
expect($response['items'][1]['segments'])->count(1);
|
|
expect($response['items'][1]['segments'][0]['id'])
|
|
->equals($segment_2->id);
|
|
}
|
|
|
|
function testItCanBulkDeleteNewsletters() {
|
|
expect(Newsletter::count())->equals(2);
|
|
|
|
$newsletters = Newsletter::findMany();
|
|
foreach($newsletters as $newsletter) {
|
|
$newsletter->trash();
|
|
}
|
|
|
|
$router = new Newsletters();
|
|
$response = $router->bulkAction(array(
|
|
'action' => 'delete',
|
|
'listing' => array('group' => 'trash')
|
|
));
|
|
expect($response)->equals(2);
|
|
|
|
$response = $router->bulkAction(array(
|
|
'action' => 'delete',
|
|
'listing' => array('group' => 'trash')
|
|
));
|
|
expect($response)->equals(0);
|
|
}
|
|
|
|
function _after() {
|
|
Newsletter::deleteMany();
|
|
NewsletterSegment::deleteMany();
|
|
Segment::deleteMany();
|
|
}
|
|
} |