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:
parent
c99508cfe2
commit
24845c70b9
3 changed files with 52 additions and 49 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue