1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 23:31:03 +01:00

Refine error behavior of bin/search index

Summary: Fixes T5991. If //all requested documents// failed to index, consider this a catastrophic failure and exit with an error code.

Test Plan:
  - Ran `bin/search index --type TASK`, observed successful exit despite a small number of un-indexable documents.
  - Ran `bin/search index PHID-TASK-xxx` for an invalid task, observed exception on exit after complete failure.
  - Ran normal indexing through daemons.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T5991

Differential Revision: https://secure.phabricator.com/D14174
This commit is contained in:
epriestley 2015-09-27 13:11:11 -07:00
parent c99508cfe2
commit 24845c70b9
3 changed files with 52 additions and 49 deletions

View file

@ -42,7 +42,6 @@ abstract class PhabricatorSearchDocumentIndexer extends Phobject {
} }
public function indexDocumentByPHID($phid, $context) { public function indexDocumentByPHID($phid, $context) {
try {
$this->setContext($context); $this->setContext($context);
$document = $this->buildAbstractDocumentByPHID($phid); $document = $this->buildAbstractDocumentByPHID($phid);
@ -70,26 +69,9 @@ abstract class PhabricatorSearchDocumentIndexer extends Phobject {
} }
$engine = PhabricatorSearchEngine::loadEngine(); $engine = PhabricatorSearchEngine::loadEngine();
try {
$engine->reindexAbstractDocument($document); $engine->reindexAbstractDocument($document);
} catch (Exception $ex) {
phlog(
pht(
'Unable to index document %s with engine %s.',
$document->getPHID(),
get_class($engine)));
phlog($ex);
}
$this->dispatchDidUpdateIndexEvent($phid, $document); $this->dispatchDidUpdateIndexEvent($phid, $document);
} catch (Exception $ex) {
phlog(
pht(
'Unable to build document %s with indexer %s.',
$phid,
get_class($this)));
phlog($ex);
}
return $this; return $this;
} }

View file

@ -93,13 +93,26 @@ final class PhabricatorSearchManagementIndexWorkflow
$bar = id(new PhutilConsoleProgressBar()) $bar = id(new PhutilConsoleProgressBar())
->setTotal(count($phids)); ->setTotal(count($phids));
$any_success = false;
$indexer = new PhabricatorSearchIndexer(); $indexer = new PhabricatorSearchIndexer();
foreach ($phids as $phid) { foreach ($phids as $phid) {
try {
$indexer->queueDocumentForIndexing($phid); $indexer->queueDocumentForIndexing($phid);
$any_success = true;
} catch (Exception $ex) {
phlog($ex);
}
$bar->update(1); $bar->update(1);
} }
$bar->done(); $bar->done();
if (!$any_success) {
throw new Exception(
pht('Failed to rebuild search index for any documents.'));
}
} }
private function loadPHIDsByNames(array $names) { private function loadPHIDsByNames(array $names) {

View file

@ -8,8 +8,16 @@ final class PhabricatorSearchWorker extends PhabricatorWorker {
$phid = idx($data, 'documentPHID'); $phid = idx($data, 'documentPHID');
$context = idx($data, 'context'); $context = idx($data, 'context');
try {
id(new PhabricatorSearchIndexer()) id(new PhabricatorSearchIndexer())
->indexDocumentByPHID($phid, $context); ->indexDocumentByPHID($phid, $context);
} catch (Exception $ex) {
throw new PhabricatorWorkerPermanentFailureException(
pht(
'Failed to update search index for document "%s": %s',
$phid,
$ex->getMessage()));
}
} }
} }