Merge pull request #271 from silverstripe/patch/reset-state-on-variant-completion

FIX: #270 - Reset variant state back to original state after processing
This commit is contained in:
Robbie Averill 2020-01-07 22:21:40 -05:00 committed by GitHub
commit 53b373fac8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -99,6 +99,8 @@ abstract class SolrReindexBase implements SolrReindexHandler
$batchSize,
$taskName
) {
// Get current state
$originalState = SearchVariant::current_state();
// Set state
SearchVariant::activate_state($state);
@ -122,6 +124,9 @@ abstract class SolrReindexBase implements SolrReindexHandler
for ($group = 0; $group < $groups; $group++) {
$this->processGroup($logger, $indexInstance, $state, $class, $groups, $group, $taskName);
}
// Reset state to originalState
SearchVariant::activate_state($originalState);
}
/**
@ -168,7 +173,11 @@ abstract class SolrReindexBase implements SolrReindexHandler
) {
// Set time limit and state
Environment::increaseTimeLimitTo();
// Get current state
$originalState = SearchVariant::current_state();
// Set state
SearchVariant::activate_state($state);
$logger->info("Adding $class");
// Prior to adding these records to solr, delete existing solr records
@ -187,6 +196,9 @@ abstract class SolrReindexBase implements SolrReindexHandler
}
$logger->info("Updated " . implode(',', $processed));
// Reset state to originalState
SearchVariant::activate_state($originalState);
// This will slow down things a tiny bit, but it is done so that we don't timeout to the database during a reindex
DB::query('SELECT 1');