public function ClassifiedNotificationsTest::test1441396 in Classified Ads 6.3
Issue #1441396.
Half-life notification emails continue every notification run.
Full test of all notifications.
File
- tests/
classified_notifications.test, line 45
Class
Code
public function test1441396() {
$this->group = 'setup';
$this
->createUsers(array(
'creator',
));
// 1. Build an ad node expiring in 14 days, grace 7 days (default)
$settings = array(
'uid' => $this->creatorUser->uid,
);
$node = $this
->createNode($settings);
$lifetime = _classified_get('lifetimes');
$lifetime = reset($lifetime);
$grace = _classified_get('grace');
$this
->pass(t('Lifetime %lifetime, grace %grace', array(
'%lifetime' => $lifetime,
'%grace' => $grace,
)), $this->group);
$t0 = time() + 1;
// 2. Cron at t0: nothing should happen.
classified_cron($t0);
$this
->assertFalse($this
->queueGetSize(), t('No initial mail queued.'), $this->group);
$this
->queueFlush();
// 3. Half-life mails.
$this->group = 'half-life';
// 3.1 Cron at t0 + 6 days: nothing should happen.
classified_cron($t0 + ($lifetime / 2 - 1) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('No mail before half-life.'), $this->group);
$this
->queueFlush();
// 3.2 Cron at t0 + 7 days: HL notification should be sent.
classified_cron($t0 + $lifetime / 2 * 86400);
$this
->assertTrue($this
->queueGetSize(), t('Half-life mail queued.'), $this->group);
$this
->queueFlush();
$node2 = node_load($node->nid, NULL, TRUE);
$this
->assertEqual($node2->status, 1, t('Ad still published at half-life.'), $this->group);
// 3.3 Cron in the post-half-life period: nothing should happen.
classified_cron($t0 + $lifetime / 2 * 86400 + 5);
$this
->assertFalse($this
->queueGetSize(), t('Half-life mail not requeued 5 minutes later.'), $this->group);
$this
->queueFlush();
classified_cron($t0 + ($lifetime / 2 + 1) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('Half-life mail not requeued 1 day later.'), $this->group);
$this
->queueFlush();
classified_cron($t0 + ($lifetime / 2 + 1) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('Half-life mail not requeued 1 day and 5 minutes later.'), $this->group);
$this
->queueFlush();
// 4. Expiration mails.
$this->group = 'expiration';
// 4.1. Cron at t0 + 13 days: 1 day to expire notification should be sent.
classified_cron($t0 + ($lifetime - 1) * 86400);
$this
->assertTrue($this
->queueGetSize(), t('Pre-expiration mail queued.'), $this->group);
$this
->queueFlush();
// 4.2. Cron at t0 + 13.5 days: nothing should happen.
classified_cron($t0 + ($lifetime - 1 + 0.6) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('Pre-expiration mail not requeued.'), $this->group);
$this
->queueFlush();
// 4.3. Cron at t0 + 14 days: expiration notification should be sent, ad
// should be unpublished.
classified_cron($t0 + $lifetime * 86400);
$this
->assertTrue($this
->queueGetSize(), t('Expiration mail queued.'), $this->group);
$this
->queueFlush();
$node2 = node_load($node->nid, NULL, TRUE);
$this
->assertEqual($node2->status, 0, t('Ad no longer published after expiration.'), $this->group);
// 4.4. Cron at t0 + 15 days: nothing should happen.
classified_cron($t0 + ($lifetime + 1) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('Expiration mail not requeued.'), $this->group);
$this
->queueFlush();
// 5. Purge mails
$this->group = 'purge';
// 5.1 Cron at t0 + 20 days: 1 days to purge notification should be sent.
classified_cron($t0 + ($lifetime + $grace - 1) * 86400);
$this
->assertTrue($this
->queueGetSize(), t('Pre-purge mail queued.'), $this->group);
$this
->queueFlush();
// 5.2 Cron at t0 + 20.5 days: nothing should happen
classified_cron($t0 + ($lifetime + $grace - 1 + 0.6) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('Pre-purge mail not requeued.'), $this->group);
$this
->queueFlush();
// 5.3 Cron at t0 + 21 days: purge notification should be sent, ad should be
// deleted.
classified_cron($t0 + ($lifetime + $grace) * 86400);
$this
->assertTrue($this
->queueGetSize(), t('Purge mail queued.'), $this->group);
$this
->queueFlush();
$node2 = node_load($node->nid, NULL, TRUE);
$this
->assertFalse($node2, t('Ad deleted after purge.'), $this->group);
// 5.4 Cron at t0 + 22 days: ad is deleted, nothing should happen.
classified_cron($t0 + ($lifetime + $grace + 1) * 86400);
$this
->assertFalse($this
->queueGetSize(), t('Purge mail not requeued.'), $this->group);
$this
->queueFlush();
}