mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-07 05:11:05 +01:00
Add an "--importing" flag to bin/repository reparse
Summary: Fixes T6839. Sometimes, worker tasks go astray for whatever reason. This automates the step of `bin/repository importing | xargs | mangle mangle | bin/repostiory reparse`. Test Plan: Ran various flavors of the command, got good looking results. Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T6839 Differential Revision: https://secure.phabricator.com/D13362
This commit is contained in:
parent
85083c88c1
commit
04516d256b
2 changed files with 114 additions and 24 deletions
|
@ -17,6 +17,9 @@ final class DiffusionCommitQuery
|
||||||
private $auditorPHIDs;
|
private $auditorPHIDs;
|
||||||
private $auditAwaitingUser;
|
private $auditAwaitingUser;
|
||||||
private $auditStatus;
|
private $auditStatus;
|
||||||
|
private $epochMin;
|
||||||
|
private $epochMax;
|
||||||
|
private $importing;
|
||||||
|
|
||||||
const AUDIT_STATUS_ANY = 'audit-status-any';
|
const AUDIT_STATUS_ANY = 'audit-status-any';
|
||||||
const AUDIT_STATUS_OPEN = 'audit-status-open';
|
const AUDIT_STATUS_OPEN = 'audit-status-open';
|
||||||
|
@ -141,6 +144,17 @@ final class DiffusionCommitQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function withEpochRange($min, $max) {
|
||||||
|
$this->epochMin = $min;
|
||||||
|
$this->epochMax = $max;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function withImporting($importing) {
|
||||||
|
$this->importing = $importing;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getIdentifierMap() {
|
public function getIdentifierMap() {
|
||||||
if ($this->identifierMap === null) {
|
if ($this->identifierMap === null) {
|
||||||
throw new Exception(
|
throw new Exception(
|
||||||
|
@ -329,6 +343,36 @@ final class DiffusionCommitQuery
|
||||||
$this->authorPHIDs);
|
$this->authorPHIDs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->epochMin !== null) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'commit.epoch >= %d',
|
||||||
|
$this->epochMin);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->epochMax !== null) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'commit.epoch <= %d',
|
||||||
|
$this->epochMax);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->importing !== null) {
|
||||||
|
if ($this->importing) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'(commit.importStatus & %d) != %d',
|
||||||
|
PhabricatorRepositoryCommit::IMPORTED_ALL,
|
||||||
|
PhabricatorRepositoryCommit::IMPORTED_ALL);
|
||||||
|
} else {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'(commit.importStatus & %d) = %d',
|
||||||
|
PhabricatorRepositoryCommit::IMPORTED_ALL,
|
||||||
|
PhabricatorRepositoryCommit::IMPORTED_ALL);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if ($this->identifiers !== null) {
|
if ($this->identifiers !== null) {
|
||||||
$min_unqualified = PhabricatorRepository::MINIMUM_UNQUALIFIED_HASH;
|
$min_unqualified = PhabricatorRepository::MINIMUM_UNQUALIFIED_HASH;
|
||||||
$min_qualified = PhabricatorRepository::MINIMUM_QUALIFIED_HASH;
|
$min_qualified = PhabricatorRepository::MINIMUM_QUALIFIED_HASH;
|
||||||
|
|
|
@ -83,12 +83,17 @@ final class PhabricatorRepositoryManagementReparseWorkflow
|
||||||
'instead of deferring them to taskmaster daemons.',
|
'instead of deferring them to taskmaster daemons.',
|
||||||
'--all'),
|
'--all'),
|
||||||
),
|
),
|
||||||
|
array(
|
||||||
|
'name' => 'importing',
|
||||||
|
'help' => pht(
|
||||||
|
'Reparse all steps which have not yet completed.'),
|
||||||
|
),
|
||||||
array(
|
array(
|
||||||
'name' => 'force-autoclose',
|
'name' => 'force-autoclose',
|
||||||
'help' => pht(
|
'help' => pht(
|
||||||
'Only used with __%s, use this to make sure any '.
|
'Only used with __%s__, use this to make sure any '.
|
||||||
'pertinent diffs are closed regardless of configuration.',
|
'pertinent diffs are closed regardless of configuration.',
|
||||||
'--message__'),
|
'--message'),
|
||||||
),
|
),
|
||||||
));
|
));
|
||||||
|
|
||||||
|
@ -106,6 +111,7 @@ final class PhabricatorRepositoryManagementReparseWorkflow
|
||||||
$force = $args->getArg('force');
|
$force = $args->getArg('force');
|
||||||
$force_local = $args->getArg('force-local');
|
$force_local = $args->getArg('force-local');
|
||||||
$min_date = $args->getArg('min-date');
|
$min_date = $args->getArg('min-date');
|
||||||
|
$importing = $args->getArg('importing');
|
||||||
|
|
||||||
if (!$all_from_repo && !$reparse_what) {
|
if (!$all_from_repo && !$reparse_what) {
|
||||||
throw new PhutilArgumentUsageException(
|
throw new PhutilArgumentUsageException(
|
||||||
|
@ -123,11 +129,26 @@ final class PhabricatorRepositoryManagementReparseWorkflow
|
||||||
$commits));
|
$commits));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$reparse_message && !$reparse_change && !$reparse_herald &&
|
$any_step = ($reparse_message ||
|
||||||
!$reparse_owners) {
|
$reparse_change ||
|
||||||
|
$reparse_herald ||
|
||||||
|
$reparse_owners);
|
||||||
|
|
||||||
|
if ($any_step && $importing) {
|
||||||
throw new PhutilArgumentUsageException(
|
throw new PhutilArgumentUsageException(
|
||||||
pht(
|
pht(
|
||||||
'Specify what information to reparse with %s, %s, %s, and/or %s.',
|
'Choosing steps with %s conflicts with flags which select '.
|
||||||
|
'specific steps.',
|
||||||
|
'--importing'));
|
||||||
|
} else if ($any_step) {
|
||||||
|
// OK.
|
||||||
|
} else if ($importing) {
|
||||||
|
// OK.
|
||||||
|
} else if (!$any_step && !$importing) {
|
||||||
|
throw new PhutilArgumentUsageException(
|
||||||
|
pht(
|
||||||
|
'Specify which steps to reparse with %s, or %s, %s, %s, or %s.',
|
||||||
|
'--importing',
|
||||||
'--message',
|
'--message',
|
||||||
'--change',
|
'--change',
|
||||||
'--herald',
|
'--herald',
|
||||||
|
@ -179,26 +200,27 @@ final class PhabricatorRepositoryManagementReparseWorkflow
|
||||||
throw new PhutilArgumentUsageException(
|
throw new PhutilArgumentUsageException(
|
||||||
pht('Unknown repository %s!', $all_from_repo));
|
pht('Unknown repository %s!', $all_from_repo));
|
||||||
}
|
}
|
||||||
$constraint = '';
|
|
||||||
|
|
||||||
|
$query = id(new DiffusionCommitQuery())
|
||||||
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
||||||
|
->withRepository($repository);
|
||||||
|
|
||||||
if ($min_timestamp) {
|
if ($min_timestamp) {
|
||||||
$console->writeOut("%s\n", pht(
|
$query->withEpochRange($min_timestamp, null);
|
||||||
'Excluding entries before UNIX timestamp: %s',
|
|
||||||
$min_timestamp));
|
|
||||||
$table = new PhabricatorRepositoryCommit();
|
|
||||||
$conn_r = $table->establishConnection('r');
|
|
||||||
$constraint = qsprintf(
|
|
||||||
$conn_r,
|
|
||||||
'AND epoch >= %d',
|
|
||||||
$min_timestamp);
|
|
||||||
}
|
}
|
||||||
$commits = id(new PhabricatorRepositoryCommit())->loadAllWhere(
|
|
||||||
'repositoryID = %d %Q',
|
if ($importing) {
|
||||||
$repository->getID(),
|
$query->withImporting(true);
|
||||||
$constraint);
|
}
|
||||||
|
|
||||||
|
$commits = $query->execute();
|
||||||
|
|
||||||
$callsign = $repository->getCallsign();
|
$callsign = $repository->getCallsign();
|
||||||
if (!$commits) {
|
if (!$commits) {
|
||||||
throw new PhutilArgumentUsageException(pht(
|
throw new PhutilArgumentUsageException(
|
||||||
"No commits have been discovered in %s repository!\n",
|
pht(
|
||||||
|
'No commits have been discovered in %s repository!',
|
||||||
$callsign));
|
$callsign));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -250,6 +272,26 @@ final class PhabricatorRepositoryManagementReparseWorkflow
|
||||||
|
|
||||||
$tasks = array();
|
$tasks = array();
|
||||||
foreach ($commits as $commit) {
|
foreach ($commits as $commit) {
|
||||||
|
if ($importing) {
|
||||||
|
$status = $commit->getImportStatus();
|
||||||
|
// Find the first missing import step and queue that up.
|
||||||
|
$reparse_message = false;
|
||||||
|
$reparse_change = false;
|
||||||
|
$reparse_owners = false;
|
||||||
|
$reparse_herald = false;
|
||||||
|
if (!($status & PhabricatorRepositoryCommit::IMPORTED_MESSAGE)) {
|
||||||
|
$reparse_message = true;
|
||||||
|
} else if (!($status & PhabricatorRepositoryCommit::IMPORTED_CHANGE)) {
|
||||||
|
$reparse_change = true;
|
||||||
|
} else if (!($status & PhabricatorRepositoryCommit::IMPORTED_OWNERS)) {
|
||||||
|
$reparse_owners = true;
|
||||||
|
} else if (!($status & PhabricatorRepositoryCommit::IMPORTED_HERALD)) {
|
||||||
|
$reparse_herald = true;
|
||||||
|
} else {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$classes = array();
|
$classes = array();
|
||||||
switch ($repository->getVersionControlSystem()) {
|
switch ($repository->getVersionControlSystem()) {
|
||||||
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
|
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
|
||||||
|
@ -287,9 +329,13 @@ final class PhabricatorRepositoryManagementReparseWorkflow
|
||||||
$classes[] = 'PhabricatorRepositoryCommitOwnersWorker';
|
$classes[] = 'PhabricatorRepositoryCommitOwnersWorker';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NOTE: With "--importing", we queue the first unparsed step and let
|
||||||
|
// it queue the other ones normally. Without "--importing", we queue
|
||||||
|
// all the requested steps explicitly.
|
||||||
|
|
||||||
$spec = array(
|
$spec = array(
|
||||||
'commitID' => $commit->getID(),
|
'commitID' => $commit->getID(),
|
||||||
'only' => true,
|
'only' => !$importing,
|
||||||
'forceAutoclose' => $args->getArg('force-autoclose'),
|
'forceAutoclose' => $args->getArg('force-autoclose'),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue