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

Remove calls to getCallsign() from repository daemons

Summary: Ref T4245. These are all descriptive or UI-facing.

Test Plan:
- Ran `bin/repository pull ...` with various identifiers.
- Ran `bin/repository mirror ...` with various identifiers.
- Ran `bin/repository discover ...` with various identifiers.
- Ran `bin/phd debug pull X Y --not Z` with various identifiers.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T4245

Differential Revision: https://secure.phabricator.com/D14926
This commit is contained in:
epriestley 2016-01-02 05:53:55 -08:00
parent 1b4f5e38ce
commit d9e034f02c
4 changed files with 44 additions and 30 deletions

View file

@ -6,7 +6,7 @@
* *
* By default, the daemon pulls **every** repository. If you want it to be * By default, the daemon pulls **every** repository. If you want it to be
* responsible for only some repositories, you can launch it with a list of * responsible for only some repositories, you can launch it with a list of
* PHIDs or callsigns: * repositories:
* *
* ./phd launch repositorypulllocal -- X Q Z * ./phd launch repositorypulllocal -- X Q Z
* *
@ -228,9 +228,8 @@ final class PhabricatorRepositoryPullLocalDaemon
$flags[] = '--no-discovery'; $flags[] = '--no-discovery';
} }
$callsign = $repository->getCallsign(); $monogram = $repository->getMonogram();
$future = new ExecFuture('%s update %Ls -- %s', $bin, $flags, $monogram);
$future = new ExecFuture('%s update %Ls -- %s', $bin, $flags, $callsign);
// Sometimes, the underlying VCS commands will hang indefinitely. We've // Sometimes, the underlying VCS commands will hang indefinitely. We've
// observed this occasionally with GitHub, and other users have observed // observed this occasionally with GitHub, and other users have observed
@ -303,30 +302,44 @@ final class PhabricatorRepositoryPullLocalDaemon
->setViewer($this->getViewer()); ->setViewer($this->getViewer());
if ($include) { if ($include) {
$query->withCallsigns($include); $query->withIdentifiers($include);
} }
$repositories = $query->execute(); $repositories = $query->execute();
$repositories = mpull($repositories, null, 'getPHID');
if ($include) { if ($include) {
$by_callsign = mpull($repositories, null, 'getCallsign'); $map = $query->getIdentifierMap();
foreach ($include as $name) { foreach ($include as $identifier) {
if (empty($by_callsign[$name])) { if (empty($map[$identifier])) {
throw new Exception( throw new Exception(
pht( pht(
"No repository exists with callsign '%s'!", 'No repository "%s" exists!',
$name)); $identifier));
} }
} }
} }
if ($exclude) { if ($exclude) {
$exclude = array_fuse($exclude); $xquery = id(new PhabricatorRepositoryQuery())
foreach ($repositories as $key => $repository) { ->setViewer($this->getViewer())
if (isset($exclude[$repository->getCallsign()])) { ->withIdentifiers($exclude);
unset($repositories[$key]);
$excluded_repos = $xquery->execute();
$xmap = $xquery->getIdentifierMap();
foreach ($exclude as $identifier) {
if (empty($xmap[$identifier])) {
throw new Exception(
pht(
'No repository "%s" exists!',
$identifier));
} }
} }
foreach ($excluded_repos as $excluded_repo) {
unset($repositories[$excluded_repo->getPHID()]);
}
} }
foreach ($repositories as $key => $repository) { foreach ($repositories as $key => $repository) {

View file

@ -100,8 +100,8 @@ final class PhabricatorRepositoryDiscoveryEngine
$this->log( $this->log(
pht( pht(
'Discovering commits in repository %s.', 'Discovering commits in repository "%s".',
$repository->getCallsign())); $repository->getDisplayName()));
$this->fillCommitCache(array_values($branches)); $this->fillCommitCache(array_values($branches));
@ -244,7 +244,7 @@ final class PhabricatorRepositoryDiscoveryEngine
'configured URI is "%s". To resolve this error, set the remote URI '. 'configured URI is "%s". To resolve this error, set the remote URI '.
'to point at the repository root. If you want to import only part '. 'to point at the repository root. If you want to import only part '.
'of a Subversion repository, use the "Import Only" option.', 'of a Subversion repository, use the "Import Only" option.',
$repository->getCallsign(), $repository->getDisplayName(),
$remote_root, $remote_root,
$expect_root)); $expect_root));
} }

View file

@ -37,7 +37,7 @@ final class PhabricatorRepositoryMirrorEngine
throw new PhutilAggregateException( throw new PhutilAggregateException(
pht( pht(
'Exceptions occurred while mirroring the "%s" repository.', 'Exceptions occurred while mirroring the "%s" repository.',
$repository->getCallsign()), $repository->getDisplayName()),
$exceptions); $exceptions);
} }
} }

View file

@ -29,7 +29,6 @@ final class PhabricatorRepositoryPullEngine
$is_svn = false; $is_svn = false;
$vcs = $repository->getVersionControlSystem(); $vcs = $repository->getVersionControlSystem();
$callsign = $repository->getCallsign();
switch ($vcs) { switch ($vcs) {
case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN: case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
@ -37,9 +36,9 @@ final class PhabricatorRepositoryPullEngine
if (!$repository->isHosted()) { if (!$repository->isHosted()) {
$this->skipPull( $this->skipPull(
pht( pht(
"Repository '%s' is a non-hosted Subversion repository, which ". 'Repository "%s" is a non-hosted Subversion repository, which '.
"does not require a local working copy to be pulled.", 'does not require a local working copy to be pulled.',
$callsign)); $repository->getDisplayName()));
return; return;
} }
$is_svn = true; $is_svn = true;
@ -55,13 +54,12 @@ final class PhabricatorRepositoryPullEngine
break; break;
} }
$callsign = $repository->getCallsign();
$local_path = $repository->getLocalPath(); $local_path = $repository->getLocalPath();
if ($local_path === null) { if ($local_path === null) {
$this->abortPull( $this->abortPull(
pht( pht(
"No local path is configured for repository '%s'.", 'No local path is configured for repository "%s".',
$callsign)); $repository->getDisplayName()));
} }
try { try {
@ -73,8 +71,8 @@ final class PhabricatorRepositoryPullEngine
if (!Filesystem::pathExists($local_path)) { if (!Filesystem::pathExists($local_path)) {
$this->logPull( $this->logPull(
pht( pht(
"Creating a new working copy for repository '%s'.", 'Creating a new working copy for repository "%s".',
$callsign)); $repository->getDisplayName()));
if ($is_git) { if ($is_git) {
$this->executeGitCreate(); $this->executeGitCreate();
} else if ($is_hg) { } else if ($is_hg) {
@ -86,8 +84,8 @@ final class PhabricatorRepositoryPullEngine
if (!$repository->isHosted()) { if (!$repository->isHosted()) {
$this->logPull( $this->logPull(
pht( pht(
"Updating the working copy for repository '%s'.", 'Updating the working copy for repository "%s".',
$callsign)); $repository->getDisplayName()));
if ($is_git) { if ($is_git) {
$this->verifyGitOrigin($repository); $this->verifyGitOrigin($repository);
$this->executeGitUpdate(); $this->executeGitUpdate();
@ -113,7 +111,10 @@ final class PhabricatorRepositoryPullEngine
} catch (Exception $ex) { } catch (Exception $ex) {
$this->abortPull( $this->abortPull(
pht('Pull of "%s" failed: %s', $callsign, $ex->getMessage()), pht(
"Pull of '%s' failed: %s",
$repository->getDisplayName(),
$ex->getMessage()),
$ex); $ex);
} }