Page MenuHomePhabricator

Warn when 'git-http-backend' is not on the PATH.
ClosedPublic

Authored by hach-que on Nov 4 2013, 7:06 AM.
Tags
None
Referenced Files
F14742370: D7488.diff
Mon, Jan 20, 8:59 AM
Unknown Object (File)
Mon, Jan 6, 4:17 AM
Unknown Object (File)
Fri, Dec 27, 2:59 AM
Unknown Object (File)
Thu, Dec 26, 8:32 AM
Unknown Object (File)
Tue, Dec 24, 5:01 PM
Unknown Object (File)
Dec 14 2024, 8:21 PM
Unknown Object (File)
Dec 12 2024, 6:14 PM
Unknown Object (File)
Dec 11 2024, 8:10 PM

Details

Summary

Currently if 'git-http-backend' is not on the PATH, there is no visible message to the user other than "info/refs: is this a valid git repository?" when trying to clone. This adds a setup check so that if there are any Git repositories in use, it will check for the existance of the "git-http-backend" binary in the PATH.

I believe this is shipped by default alongside the git package on most distros, but in some (such as OpenSUSE), this binary isn't on the PATH by default.

Test Plan

Removed /usr/lib/git from my environment.append-paths and saw the message appear. Added it back and the message went away.

Diff Detail

Branch
warn-git-http-backend
Lint
Lint Passed
Unit
No Test Coverage

Event Timeline

src/applications/config/check/PhabricatorSetupCheckBinaries.php
151

This makes the additional information a bit more visible on the issue page.

We also need git-receive-pack (git ssh), git-upload-pack (git ssh), svnserve (any svn hosting?) and svnadmin (any svn hosting). For Mercurial, apparently hg is sufficient in all cases. (We could possibly rewrite the git-*-pack commands we receive over SSH to git *-pack, but I'm slightly hesitant about that.)

With this approach, I'm worried that it will be somewhat overwhelming and not actually as useful as it could be:

  • We'll potentially warn you about a lot of binaries you don't actually need, since we don't check if these repositories are hosted.
  • Whether we check if the repositories are hosted or not, this message probably comes too late. It generally will show up only after the next restart, so users without these binaries will probably hit "configure repo" -> "it doesn't work" -> "no clue how to proceed" without seeing this.

Instead, what do you think about moving this check to DiffusionRepositoryEditMainController::buildRepositoryStatus()? It could check for exactly the binaries that the repository needs based on whether it is hosted or not, and present the information to the user at a relevant time.

That's probably a better option.

I've always liked the idea of caching / storing exceptions that happen "behind-the-scenes" and then displaying a yellow bar to Administrators that exceptions have occurred. We could even use this to display exceptions in daemons out to Administrators so that they are aware that exceptions are occurring.

hach-que updated this revision to Unknown Object (????).Nov 4 2013, 11:00 PM

Move binary checks onto DiffusionRepositoryEditMainController

epriestley closed this revision.

Closed by commit rP10659ece8e2d (authored by @hach-que, committed by @epriestley).