From: Junio C Hamano <gitster@pobox.com>
To: Erick Mattos <erick.mattos@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: [PATCH] commit -c/-C/--amend: acquire authorship and restamp time with --claim
Date: Sun, 01 Nov 2009 12:02:02 -0800 [thread overview]
Message-ID: <7vr5sixbd1.fsf@alter.siamese.dyndns.org> (raw)
In-Reply-To: <1257101127-8196-1-git-send-email-erick.mattos@gmail.com> (Erick Mattos's message of "Sun\, 1 Nov 2009 16\:45\:27 -0200")
Erick Mattos <erick.mattos@gmail.com> writes:
> The new --claim option is meant to solve this need by regenerating the
> timestamp and setting as new author the committer or the one specified
> on --author option.
Thanks.
I don't think "claim" is a good name for this option. It makes me go
"huh, I do not get it. What are you claiming? Claiming that this is the
correct fix?"
Renaming it to "claim-authorship" may avoid that confusion, but it is too
long.
How about naming this option "mine"?
> @@ -61,14 +61,19 @@ OPTIONS
> -C <commit>::
> --reuse-message=<commit>::
> Take an existing commit object, and reuse the log message
> - and the authorship information (including the timestamp)
> - when creating the commit.
> + and the authorship information when creating the commit.
I don't think this is a good change.
When you use the new option, the author name, email and timestamp are
ignored, and when you don't, they are all used.
To new users who are taught to first set user.name and user.email via
configuration variables, the phrase "authorship information" would mean
<name, email> pair, and the explanation in the parentheses helps to avoid
a misunderstanding that these two are the only things that are copied.
I would suggest you keep the original text.
> +--claim::
> + When used with -C/-c/--amend options, declare that the
> + authorship of the resulting commit now belongs of the committer.
> + This also renews the author timestamp. Therefore this option
> + sets the use of only the message from the original commit.
I don't understand/parse the last sentence; I don't think it is necessary,
either.
> diff --git a/builtin-commit.c b/builtin-commit.c
> index c395cbf..919e3fe 100644
> --- a/builtin-commit.c
> +++ b/builtin-commit.c
> @@ -51,7 +51,7 @@ static const char *template_file;
> static char *edit_message, *use_message;
> static char *author_name, *author_email, *author_date;
> static int all, edit_flag, also, interactive, only, amend, signoff;
> -static int quiet, verbose, no_verify, allow_empty, dry_run;
> +static int quiet, verbose, no_verify, allow_empty, dry_run, claim;
Even if you name the command option "claim" in order to keep it short, I
think it is a bad idea to name the variable "claim", because it doesn't
say _what_ you are claiming and is confusing. Naming it claim_authorship
would be better.
> + OPT_BOOLEAN(0, "claim", &claim, "acquire authorship and restamp time of resulting commit"),
It is unclear from where it is "acquire"-ing, nor what "restamp" means.
Here are my attempts to come up with better wording:
"ignore author and timestamp of the original commit (used with -C/-c/--amend)"
"the commit is authored by me now (used with -C/-c/--amend)"
The latter will work well if the option is renamed to "--mine".
What should happen when the user uses --claim without -C/-c/--amend?
% git commit --claim
Should you detect an error? Does your code do so? Do you have a test
that catches this error?
What should happen when the user uses --author and --claim at the same time?
% git commit --claim --author='Erick Mattos <eric@mattos>' -C HEAD
Should you detect an error? Does your code do so? Do you have a test
that catches this error?
> diff --git a/t/t7509-commit.sh b/t/t7509-commit.sh
> new file mode 100755
> index 0000000..62fb00f
> --- /dev/null
> +++ b/t/t7509-commit.sh
> @@ -0,0 +1,87 @@
> +#!/bin/sh
> +#
> +# Copyright (c) 2009 Erick Mattos
> +#
> +
> +test_description='git commit
> +
> +Tests for --claim option on a commit.'
> +
> +. ./test-lib.sh
> +
> +TEST_FILE="$PWD"/foo
Why does this have to be given as a full path, not just "foo"?
> +test_expect_success '-C option should be working' '
Every test is about "should be working", so you are wasting 16 letters or
so without giving any useful information.
Say something like "-C without --claim uses the author from the old commit" here.
> + echo "Initial" > "$TEST_FILE" &&
> + git add "$TEST_FILE" &&
> + git commit -m "Initial Commit" --author Frigate\ \<flying@over.world\> &&
> + sleep 1 &&
If you use "test_tick", you don't have to slow the test down. You use
"test_tick" before you commit to increment the time. Look at t6036 for an
example.
> + echo "Test 1" >> "$TEST_FILE" &&
> + git add "$TEST_FILE" &&
> + git commit -C HEAD &&
> + git cat-file -p HEAD^ | sed -e '/^parent/d' -e '/^tree/d' -e '/^committer/d' > commit_1 &&
> + git cat-file -p HEAD | sed -e '/^parent/d' -e '/^tree/d' -e '/^committer/d' > commit_2 &&
> + cmp commit_1 commit_2
> +'
Use "test_cmp" instead, so that errors can be seen easily when somebody
breaks this new feature.
> +test_expect_success '-C option with --claim is working properly' '
Again, "working properly" is a meaningless thing to say because that is
what all tests check. "-C with --claim makes me the author" would be
better.
> + sleep 1 &&
> + echo "Test 2" >> "$TEST_FILE" &&
> + git add "$TEST_FILE" &&
> + git commit -C HEAD^ --claim &&
> + git cat-file -p HEAD^ | grep '^author' > commit_1 &&
> + git cat-file -p HEAD | grep '^author' > commit_2 &&
> + test_must_fail cmp commit_1 commit_2
This test shouldn't be happy with any random author information that
happens to be different from the original. The purpose of --claim option
is to take the authorship, make it mine (or whoever is specified with
GIT_AUTHOR_NAME or user.name or uid-to-gecos), so the last cmp (again, it
should use test_cmp) should make sure that the author is 'A U Thor', not
just being different from "Frigate" or whatever. It should check email
and timestamp as well, of course.
> +'
> +
> +test_expect_success '-c option should be working' '
> + echo "Initial" > "$TEST_FILE" &&
> + git add "$TEST_FILE" &&
> + git commit -m "Initial Commit" --author Frigate\ \<flying@over.world\> &&
> + sleep 1 &&
> + echo "Test 3" >> "$TEST_FILE" &&
> + git add "$TEST_FILE" &&
> + git commit -c HEAD <<EOF
> + "Changed"
> + EOF &&
What editor is reading this "Changed"?
next prev parent reply other threads:[~2009-11-01 20:02 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-10-31 3:08 [PATCH] commit -c/-C/--amend: take over authorship and restamp time with --claim Erick Mattos
2009-10-31 21:24 ` Junio C Hamano
2009-11-01 18:19 ` [PATCH v2] " Erick Mattos
2009-11-01 18:45 ` [PATCH] commit -c/-C/--amend: acquire " Erick Mattos
2009-11-01 20:02 ` Junio C Hamano [this message]
2009-11-01 20:57 ` Erick Mattos
2009-11-02 0:47 ` Junio C Hamano
2009-11-02 0:54 ` Erick Mattos
2009-11-02 2:58 ` Junio C Hamano
2009-11-02 3:07 ` Junio C Hamano
2009-11-03 16:39 ` Erick Mattos
2009-11-01 23:14 ` Erick Mattos
2009-11-02 0:44 ` [PATCH] commit -c/-C/--amend: reset timestamp and authorship to committer with --mine Erick Mattos
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=7vr5sixbd1.fsf@alter.siamese.dyndns.org \
--to=gitster@pobox.com \
--cc=erick.mattos@gmail.com \
--cc=git@vger.kernel.org \
/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).