1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-02 02:40:58 +01:00

Make repository pull install hooks the first time

Summary:
Ref T4257. Currently, the pull logic looks like this:

  if (new) {
    create();
  } else {
    if (hosted) {
      install_hooks();
    } else {
      update();
    }
  }

This means that the first time you run `repository pull`, hooks aren't installed, which makes debugging trickier. Instead, reorganize the logic:

  if (new) {
    create();
  } else {
    if (!hosted) {
      update();
    }
  }

  if (hosted) {
    install_hooks();
  }

Test Plan: Ran `bin/repository pull` on a new `hg` repo and got hooks installed immediately.

Reviewers: btrahan

Reviewed By: btrahan

CC: aran

Maniphest Tasks: T4257

Differential Revision: https://secure.phabricator.com/D7818
This commit is contained in:
epriestley 2013-12-23 10:43:49 -08:00
parent 6daa2b6c2e
commit 81dcf6378d

View file

@ -82,6 +82,19 @@ final class PhabricatorRepositoryPullEngine
$this->executeSubversionCreate(); $this->executeSubversionCreate();
} }
} else { } else {
if (!$repository->isHosted()) {
$this->logPull(
pht(
"Updating the working copy for repository '%s'.",
$callsign));
if ($is_git) {
$this->executeGitUpdate();
} else if ($is_hg) {
$this->executeMercurialUpdate();
}
}
}
if ($repository->isHosted()) { if ($repository->isHosted()) {
if ($is_git) { if ($is_git) {
$this->installGitHook(); $this->installGitHook();
@ -89,25 +102,9 @@ final class PhabricatorRepositoryPullEngine
$this->installSubversionHook(); $this->installSubversionHook();
} else if ($is_hg) { } else if ($is_hg) {
$this->installMercurialHook(); $this->installMercurialHook();
} else {
$this->logPull(
pht(
"Repository '%s' is hosted, so Phabricator does not pull ".
"updates for it.",
$callsign));
}
} else {
$this->logPull(
pht(
"Updating the working copy for repository '%s'.",
$callsign));
if ($is_git) {
$this->executeGitUpdate();
} else {
$this->executeMercurialUpdate();
}
} }
} }
} 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', $callsign, $ex->getMessage()),