mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-05 08:58:22 +02:00
Count and report skipped documents from "bin/search index"
Summary: Ref T12450. There's currently a bad behavior where inserting a document into one search service marks it as up to date everywhere. This isn't nearly as obvious as it should be because `bin/search index` doesn't make it terribly clear when a document was skipped because the index version was already up to date. When running `bin/seach index` without `--force` or `--background`, keep track of updated vs not-updated documents and print out some guidance. In other configurations, try to provide more help too. Test Plan: {F4452134} Reviewers: chad, 20after4 Reviewed By: 20after4 Maniphest Tasks: T12450 Differential Revision: https://secure.phabricator.com/D17597
This commit is contained in:
parent
6d81675032
commit
bd93978200
1 changed files with 76 additions and 2 deletions
|
@ -87,8 +87,9 @@ final class PhabricatorSearchManagementIndexWorkflow
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$is_background) {
|
if (!$is_background) {
|
||||||
$console->writeOut(
|
echo tsprintf(
|
||||||
"%s\n",
|
"**<bg:blue> %s </bg>** %s\n",
|
||||||
|
pht('NOTE'),
|
||||||
pht(
|
pht(
|
||||||
'Run this workflow with "%s" to queue tasks for the daemon workers.',
|
'Run this workflow with "%s" to queue tasks for the daemon workers.',
|
||||||
'--background'));
|
'--background'));
|
||||||
|
@ -109,9 +110,32 @@ final class PhabricatorSearchManagementIndexWorkflow
|
||||||
);
|
);
|
||||||
|
|
||||||
$any_success = false;
|
$any_success = false;
|
||||||
|
|
||||||
|
// If we aren't using "--background" or "--force", track how many objects
|
||||||
|
// we're skipping so we can print this information for the user and give
|
||||||
|
// them a hint that they might want to use "--force".
|
||||||
|
$track_skips = (!$is_background && !$is_force);
|
||||||
|
|
||||||
|
$count_updated = 0;
|
||||||
|
$count_skipped = 0;
|
||||||
|
|
||||||
foreach ($phids as $phid) {
|
foreach ($phids as $phid) {
|
||||||
try {
|
try {
|
||||||
|
if ($track_skips) {
|
||||||
|
$old_versions = $this->loadIndexVersions($phid);
|
||||||
|
}
|
||||||
|
|
||||||
PhabricatorSearchWorker::queueDocumentForIndexing($phid, $parameters);
|
PhabricatorSearchWorker::queueDocumentForIndexing($phid, $parameters);
|
||||||
|
|
||||||
|
if ($track_skips) {
|
||||||
|
$new_versions = $this->loadIndexVersions($phid);
|
||||||
|
if ($old_versions !== $new_versions) {
|
||||||
|
$count_updated++;
|
||||||
|
} else {
|
||||||
|
$count_skipped++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$any_success = true;
|
$any_success = true;
|
||||||
} catch (Exception $ex) {
|
} catch (Exception $ex) {
|
||||||
phlog($ex);
|
phlog($ex);
|
||||||
|
@ -127,6 +151,45 @@ final class PhabricatorSearchManagementIndexWorkflow
|
||||||
pht('Failed to rebuild search index for any documents.'));
|
pht('Failed to rebuild search index for any documents.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($track_skips) {
|
||||||
|
if ($count_updated) {
|
||||||
|
echo tsprintf(
|
||||||
|
"**<bg:green> %s </bg>** %s\n",
|
||||||
|
pht('DONE'),
|
||||||
|
pht(
|
||||||
|
'Updated search indexes for %s document(s).',
|
||||||
|
new PhutilNumber($count_updated)));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($count_skipped) {
|
||||||
|
echo tsprintf(
|
||||||
|
"**<bg:yellow> %s </bg>** %s\n",
|
||||||
|
pht('SKIP'),
|
||||||
|
pht(
|
||||||
|
'Skipped %s documents(s) which have not updated since they were '.
|
||||||
|
'last indexed.',
|
||||||
|
new PhutilNumber($count_skipped)));
|
||||||
|
echo tsprintf(
|
||||||
|
"**<bg:blue> %s </bg>** %s\n",
|
||||||
|
pht('NOTE'),
|
||||||
|
pht(
|
||||||
|
'Use "--force" to force the index to update these documents.'));
|
||||||
|
}
|
||||||
|
} else if ($is_background) {
|
||||||
|
echo tsprintf(
|
||||||
|
"**<bg:green> %s </bg>** %s\n",
|
||||||
|
pht('DONE'),
|
||||||
|
pht(
|
||||||
|
'Queued %s document(s) for background indexing.',
|
||||||
|
new PhutilNumber(count($phids))));
|
||||||
|
} else {
|
||||||
|
echo tsprintf(
|
||||||
|
"**<bg:green> %s </bg>** %s\n",
|
||||||
|
pht('DONE'),
|
||||||
|
pht(
|
||||||
|
'Forced search index updates for %s document(s).',
|
||||||
|
new PhutilNumber(count($phids))));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private function loadPHIDsByNames(array $names) {
|
private function loadPHIDsByNames(array $names) {
|
||||||
|
@ -206,5 +269,16 @@ final class PhabricatorSearchManagementIndexWorkflow
|
||||||
return $phids;
|
return $phids;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function loadIndexVersions($phid) {
|
||||||
|
$table = new PhabricatorSearchIndexVersion();
|
||||||
|
$conn = $table->establishConnection('r');
|
||||||
|
|
||||||
|
return queryfx_all(
|
||||||
|
$conn,
|
||||||
|
'SELECT extensionKey, version FROM %T WHERE objectPHID = %s
|
||||||
|
ORDER BY extensionKey, version',
|
||||||
|
$table->getTableName(),
|
||||||
|
$phid);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue