From: Jeff King <peff@peff.net>
To: git@vger.kernel.org
Cc: "Yi, EungJun" <semtlenori@gmail.com>
Subject: [RFC/PATCH 0/9] friendlier http error messages
Date: Fri, 5 Apr 2013 18:13:31 -0400 [thread overview]
Message-ID: <20130405221331.GA21209@sigill.intra.peff.net> (raw)
The error messages that git generates for routine http problems can
sometimes be a bit verbose or confusing. They also provide no
opportunity for the server to communicate any free-form text, even
though the server knows much better than the git client the reason for
the error or what the next step to suggest to the user might be.
This series provides a channel for those messages, and does some general
cleanup and reformatting of the error messages that git itself produces.
Here are some before-and-after examples with this series (apologies for
the long lines, but they are part of the ugliness I want to address, so
I am leaving them in).
The "remote:" bits are simulated in the output below, as I haven't yet
updated GitHub's server side to produce more useful messages. So you can
repeat the tests, but note that the text you get from the server will
not be the same (e.g., our 404 currently just says "Repository not
found" which is not all that helpful).
[before]
$ git ls-remote https://github.com/non/existent
fatal: https://github.com/non/existent/info/refs?service=git-upload-pack not found: did you run git update-server-info on the server?
[after]
$ git ls-remote https://github.com/non/existent
remote: The remote repository was not found, or you do not have
remote: permission to access it.
fatal: repository 'https://github.com/non/existent/' not found
[before]
$ GIT_SMART_HTTP=0 git ls-remote https://github.com/git/git.git
error: The requested URL returned error: 403 Forbidden while accessing https://github.com/git/git.git/info/refs
fatal: HTTP request failed
[after]
$ GIT_SMART_HTTP=0 git ls-remote https://github.com/git/git.git
remote: Sorry, fetching via dumb http is forbidden.
remote: Please upgrade your git client to v1.6.6 or greater
remote: and make sure that smart-http is enabled.
fatal: unable to access 'https://github.com/git/git.git/': The requested URL returned error: 403
I still really hate the length of the generic http message (which you
can see in the final 403 example). The text "The requested URL returned
error:" comes from curl, though there is actually an opportunity to
munge it, as you will see in the patches. However, I was unable to come
up with a shorter text that sounded any better.
Another option would be to just split it across lines with some
indentation, like:
fatal: The requested URL returned error: 403
while accessing https://github.com/git/git.git
I'm open to suggestions.
There are a lot of little patches, as I tried to explain the rationale
for each individual change (and it makes it easy to take or reject
individual patches). If we do take them all, it may make sense to just
squash patches 3-5.
[1/9]: http: add HTTP_KEEP_ERROR option
[2/9]: remote-curl: show server content on http errors
[3/9]: remote-curl: let servers override http 404 advice
[4/9]: remote-curl: always show friendlier 404 message
[5/9]: remote-curl: consistently report repo url for http errors
[6/9]: http: simplify http_error helper function
[7/9]: http: re-word http error message
[8/9]: remote-curl: die directly with http error messages
[9/9]: http: drop http_error function
-Peff
next reply other threads:[~2013-04-06 16:56 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-04-05 22:13 Jeff King [this message]
2013-04-05 22:14 ` [PATCH 1/9] http: add HTTP_KEEP_ERROR option Jeff King
2013-04-05 22:17 ` [PATCH 2/9] remote-curl: show server content on http errors Jeff King
2013-04-05 22:17 ` [PATCH 3/9] remote-curl: let servers override http 404 advice Jeff King
2013-04-05 22:20 ` [PATCH 4/9] remote-curl: always show friendlier 404 message Jeff King
2013-04-05 22:21 ` [PATCH 5/9] remote-curl: consistently report repo url for http errors Jeff King
2013-04-05 22:21 ` [PATCH 6/9] http: simplify http_error helper function Jeff King
2013-04-05 22:22 ` [PATCH 7/9] http: re-word http error message Jeff King
2013-04-05 22:22 ` [PATCH 8/9] remote-curl: die directly with http error messages Jeff King
2013-04-05 22:22 ` [PATCH 9/9] http: drop http_error function Jeff King
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20130405221331.GA21209@sigill.intra.peff.net \
--to=peff@peff.net \
--cc=git@vger.kernel.org \
--cc=semtlenori@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).