Tests that populator method is not run for versions below

3.0.0-beta.36.2.1
This commit is contained in:
Vlad
2017-07-11 09:12:43 -04:00
committed by pavel-mailpoet
parent b626c7ea3c
commit 7a2aaa86cf
2 changed files with 20 additions and 4 deletions

View File

@ -340,7 +340,7 @@ class Populator {
if(!version_compare(get_option('mailpoet_db_version'), '3.0.0-beta.32', '<=')) {
// Data conversion should only be performed only once, when migrating from
// older version
return;
return false;
}
$source_charset = $wpdb->get_var('SELECT @@GLOBAL.character_set_connection');
@ -389,6 +389,8 @@ class Populator {
implode(' AND ', $where_query)
));
}
return true;
}
/*
@ -401,7 +403,7 @@ class Populator {
// perform once for versions below 3.0.0-beta.36.2.1
if(version_compare(get_option('mailpoet_db_version'), '3.0.0-beta.36.2.1', '>=')) {
return;
return false;
}
$column_list = array(
@ -439,6 +441,8 @@ class Populator {
MP_SENDING_QUEUES_TABLE,
'`type` IN("' . join('" , "', $task_types) . '")'
));
return true;
}
/*
@ -452,7 +456,7 @@ class Populator {
// perform once for versions below 3.0.0-beta.36.2.1
if(version_compare(get_option('mailpoet_db_version'), '3.0.0-beta.36.2.1', '>=')) {
return;
return false;
}
$query = "UPDATE `%s` newsletters JOIN `%s` queues ON newsletters.id = queues.newsletter_id SET newsletters.sent_at = queues.processed_at";
@ -461,5 +465,7 @@ class Populator {
Newsletter::$_table,
SendingQueue::$_table
));
return true;
}
}

View File

@ -1,5 +1,6 @@
<?php
use MailPoet\Config\Env;
use MailPoet\Config\Populator;
use MailPoet\Models\Newsletter;
use MailPoet\Models\SendingQueue;
@ -7,6 +8,9 @@ use MailPoet\Models\SendingQueue;
class PopulatorTest extends MailPoetTest {
function testItPopulatesNewslettersTableSentAtColumn() {
// TODO: remove in final release
// run for versions <= 3.0.0-beta.36.2.0
update_option('mailpoet_db_version', '3.0.0-beta.36.2.0');
$newsletters = array();
for($i = 1; $i <= 3; $i++) {
$newsletters[$i] = Newsletter::create();
@ -21,13 +25,19 @@ class PopulatorTest extends MailPoetTest {
$sending_queue->save();
$populator = new Populator();
$populator->populateNewsletterSentAtField();
expect($populator->populateNewsletterSentAtField())->true();
expect(Newsletter::whereNull('sent_at')->findMany())->count(2);
expect(Newsletter::whereNotNull('sent_at')->findMany())->count(1);
// do not run for versions >= 3.0.0-beta.36.2.1
update_option('mailpoet_db_version', '3.0.0-beta.36.2.1');
$populator = new Populator();
expect($populator->populateNewsletterSentAtField())->false();
}
function _after() {
ORM::raw_execute('TRUNCATE ' . Newsletter::$_table);
ORM::raw_execute('TRUNCATE ' . SendingQueue::$_table);
update_option('mailpoet_db_version', Env::$version);
}
}