2009-02-08 15:34:27 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='.mailmap configurations'
|
|
|
|
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
2010-10-15 19:12:19 +02:00
|
|
|
fuzz_blame () {
|
|
|
|
sed "
|
|
|
|
s/$_x05[0-9a-f][0-9a-f][0-9a-f]/OBJID/g
|
|
|
|
s/$_x05[0-9a-f][0-9a-f]/OBJI/g
|
|
|
|
s/[-0-9]\{10\} [:0-9]\{8\} [-+][0-9]\{4\}/DATE/g
|
|
|
|
" "$@"
|
|
|
|
}
|
|
|
|
|
2009-02-08 15:34:27 +01:00
|
|
|
test_expect_success setup '
|
|
|
|
echo one >one &&
|
|
|
|
git add one &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m initial &&
|
|
|
|
echo two >>one &&
|
|
|
|
git add one &&
|
2010-10-11 17:41:16 +02:00
|
|
|
test_tick &&
|
2009-02-08 15:34:27 +01:00
|
|
|
git commit --author "nick1 <bugs@company.xx>" -m second
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<\EOF
|
|
|
|
A U Thor (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
nick1 (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'No mailmap' '
|
|
|
|
git shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<\EOF
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
nick1 (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'default .mailmap' '
|
|
|
|
echo "Repo Guy <author@example.com>" > .mailmap &&
|
|
|
|
git shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
# Using a mailmap file in a subdirectory of the repo here, but
|
|
|
|
# could just as well have been a file outside of the repository
|
|
|
|
cat >expect <<\EOF
|
|
|
|
Internal Guy (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
EOF
|
|
|
|
test_expect_success 'mailmap.file set' '
|
2010-10-11 17:41:16 +02:00
|
|
|
mkdir -p internal_mailmap &&
|
2009-02-08 15:34:27 +01:00
|
|
|
echo "Internal Guy <bugs@company.xx>" > internal_mailmap/.mailmap &&
|
|
|
|
git config mailmap.file internal_mailmap/.mailmap &&
|
|
|
|
git shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<\EOF
|
|
|
|
External Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
Internal Guy (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
test_expect_success 'mailmap.file override' '
|
|
|
|
echo "External Guy <author@example.com>" >> internal_mailmap/.mailmap &&
|
|
|
|
git config mailmap.file internal_mailmap/.mailmap &&
|
|
|
|
git shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<\EOF
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
nick1 (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
2011-06-16 15:42:48 +02:00
|
|
|
test_expect_success 'mailmap.file non-existent' '
|
2009-02-08 15:34:27 +01:00
|
|
|
rm internal_mailmap/.mailmap &&
|
|
|
|
rmdir internal_mailmap &&
|
|
|
|
git shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2010-10-11 17:41:16 +02:00
|
|
|
cat >expect <<\EOF
|
|
|
|
Internal Guy (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'name entry after email entry' '
|
|
|
|
mkdir -p internal_mailmap &&
|
|
|
|
echo "<bugs@company.xy> <bugs@company.xx>" >internal_mailmap/.mailmap &&
|
|
|
|
echo "Internal Guy <bugs@company.xx>" >>internal_mailmap/.mailmap &&
|
2010-10-20 08:32:06 +02:00
|
|
|
git shortlog HEAD >actual &&
|
2010-10-11 17:41:16 +02:00
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<\EOF
|
|
|
|
Internal Guy (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'name entry after email entry, case-insensitive' '
|
|
|
|
mkdir -p internal_mailmap &&
|
|
|
|
echo "<bugs@company.xy> <bugs@company.xx>" >internal_mailmap/.mailmap &&
|
|
|
|
echo "Internal Guy <BUGS@Company.xx>" >>internal_mailmap/.mailmap &&
|
2010-10-20 08:32:06 +02:00
|
|
|
git shortlog HEAD >actual &&
|
2010-10-11 17:41:16 +02:00
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2009-02-08 15:34:27 +01:00
|
|
|
cat >expect <<\EOF
|
|
|
|
A U Thor (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
nick1 (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
test_expect_success 'No mailmap files, but configured' '
|
2010-10-11 17:41:16 +02:00
|
|
|
rm -f .mailmap internal_mailmap/.mailmap &&
|
2009-02-08 15:34:27 +01:00
|
|
|
git shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2012-12-12 12:04:04 +01:00
|
|
|
test_expect_success 'setup mailmap blob tests' '
|
|
|
|
git checkout -b map &&
|
|
|
|
test_when_finished "git checkout master" &&
|
|
|
|
cat >just-bugs <<-\EOF &&
|
|
|
|
Blob Guy <bugs@company.xx>
|
|
|
|
EOF
|
|
|
|
cat >both <<-\EOF &&
|
|
|
|
Blob Guy <author@example.com>
|
|
|
|
Blob Guy <bugs@company.xx>
|
|
|
|
EOF
|
|
|
|
git add just-bugs both &&
|
|
|
|
git commit -m "my mailmaps" &&
|
|
|
|
echo "Repo Guy <author@example.com>" >.mailmap &&
|
|
|
|
echo "Internal Guy <author@example.com>" >internal.map
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'mailmap.blob set' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
Blob Guy (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
EOF
|
|
|
|
git -c mailmap.blob=map:just-bugs shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'mailmap.blob overrides .mailmap' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
Blob Guy (2):
|
|
|
|
initial
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
git -c mailmap.blob=map:both shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'mailmap.file overrides mailmap.blob' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
Blob Guy (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
Internal Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
EOF
|
|
|
|
git \
|
|
|
|
-c mailmap.blob=map:both \
|
|
|
|
-c mailmap.file=internal.map \
|
|
|
|
shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'mailmap.blob can be missing' '
|
|
|
|
cat >expect <<-\EOF &&
|
|
|
|
Repo Guy (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
nick1 (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
git -c mailmap.blob=map:nonexistent shortlog HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
mailmap: default mailmap.blob in bare repositories
The motivation for mailmap.blob is to let users of bare
repositories use the mailmap feature, as they would not have
a checkout containing the .mailmap file. We can make it even
easier for them by just looking in HEAD:.mailmap by default.
We can't know for sure that this is where they would keep a
mailmap, of course, but it is the best guess (and it matches
the non-bare behavior, which reads from HEAD:.mailmap in the
working tree). If it's missing, git will silently ignore the
setting.
We do not do the same magic in the non-bare case, because:
1. In the common case, HEAD:.mailmap will be the same as
the .mailmap in the working tree, which is a no-op.
2. In the uncommon case, the user has modified .mailmap
but not yet committed it, and would expect the working
tree version to take precedence.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2012-12-13 14:04:47 +01:00
|
|
|
test_expect_success 'mailmap.blob defaults to off in non-bare repo' '
|
|
|
|
git init non-bare &&
|
|
|
|
(
|
|
|
|
cd non-bare &&
|
|
|
|
test_commit one .mailmap "Fake Name <author@example.com>" &&
|
|
|
|
echo " 1 Fake Name" >expect &&
|
|
|
|
git shortlog -ns HEAD >actual &&
|
|
|
|
test_cmp expect actual &&
|
|
|
|
rm .mailmap &&
|
|
|
|
echo " 1 A U Thor" >expect &&
|
|
|
|
git shortlog -ns HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'mailmap.blob defaults to HEAD:.mailmap in bare repo' '
|
|
|
|
git clone --bare non-bare bare &&
|
|
|
|
(
|
|
|
|
cd bare &&
|
|
|
|
echo " 1 Fake Name" >expect &&
|
|
|
|
git shortlog -ns HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
2012-12-12 12:04:04 +01:00
|
|
|
test_expect_success 'cleanup after mailmap.blob tests' '
|
|
|
|
rm -f .mailmap
|
|
|
|
'
|
|
|
|
|
2013-07-15 08:54:06 +02:00
|
|
|
test_expect_success 'single-character name' '
|
2013-07-15 08:54:05 +02:00
|
|
|
echo " 1 A <author@example.com>" >expect &&
|
|
|
|
echo " 1 nick1 <bugs@company.xx>" >>expect &&
|
|
|
|
echo "A <author@example.com>" >.mailmap &&
|
|
|
|
test_when_finished "rm .mailmap" &&
|
|
|
|
git shortlog -es HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
2013-07-15 08:54:07 +02:00
|
|
|
'
|
|
|
|
|
2013-07-15 08:54:08 +02:00
|
|
|
test_expect_success 'preserve canonical email case' '
|
2013-07-15 08:54:07 +02:00
|
|
|
echo " 1 A U Thor <AUTHOR@example.com>" >expect &&
|
|
|
|
echo " 1 nick1 <bugs@company.xx>" >>expect &&
|
|
|
|
echo "<AUTHOR@example.com> <author@example.com>" >.mailmap &&
|
|
|
|
test_when_finished "rm .mailmap" &&
|
|
|
|
git shortlog -es HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
2013-07-15 08:54:05 +02:00
|
|
|
'
|
|
|
|
|
2009-02-08 15:34:30 +01:00
|
|
|
# Extended mailmap configurations should give us the following output for shortlog
|
|
|
|
cat >expect <<\EOF
|
|
|
|
A U Thor <author@example.com> (1):
|
|
|
|
initial
|
|
|
|
|
|
|
|
CTO <cto@company.xx> (1):
|
|
|
|
seventh
|
|
|
|
|
|
|
|
Other Author <other@author.xx> (2):
|
|
|
|
third
|
|
|
|
fourth
|
|
|
|
|
|
|
|
Santa Claus <santa.claus@northpole.xx> (2):
|
|
|
|
fifth
|
|
|
|
sixth
|
|
|
|
|
|
|
|
Some Dude <some@dude.xx> (1):
|
|
|
|
second
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'Shortlog output (complex mapping)' '
|
|
|
|
echo three >>one &&
|
|
|
|
git add one &&
|
|
|
|
test_tick &&
|
|
|
|
git commit --author "nick2 <bugs@company.xx>" -m third &&
|
|
|
|
|
|
|
|
echo four >>one &&
|
|
|
|
git add one &&
|
|
|
|
test_tick &&
|
|
|
|
git commit --author "nick2 <nick2@company.xx>" -m fourth &&
|
|
|
|
|
|
|
|
echo five >>one &&
|
|
|
|
git add one &&
|
|
|
|
test_tick &&
|
|
|
|
git commit --author "santa <me@company.xx>" -m fifth &&
|
|
|
|
|
|
|
|
echo six >>one &&
|
|
|
|
git add one &&
|
|
|
|
test_tick &&
|
|
|
|
git commit --author "claus <me@company.xx>" -m sixth &&
|
|
|
|
|
|
|
|
echo seven >>one &&
|
|
|
|
git add one &&
|
|
|
|
test_tick &&
|
|
|
|
git commit --author "CTO <cto@coompany.xx>" -m seventh &&
|
|
|
|
|
2010-10-11 17:41:16 +02:00
|
|
|
mkdir -p internal_mailmap &&
|
2009-02-08 15:34:30 +01:00
|
|
|
echo "Committed <committer@example.com>" > internal_mailmap/.mailmap &&
|
|
|
|
echo "<cto@company.xx> <cto@coompany.xx>" >> internal_mailmap/.mailmap &&
|
|
|
|
echo "Some Dude <some@dude.xx> nick1 <bugs@company.xx>" >> internal_mailmap/.mailmap &&
|
|
|
|
echo "Other Author <other@author.xx> nick2 <bugs@company.xx>" >> internal_mailmap/.mailmap &&
|
|
|
|
echo "Other Author <other@author.xx> <nick2@company.xx>" >> internal_mailmap/.mailmap &&
|
|
|
|
echo "Santa Claus <santa.claus@northpole.xx> <me@company.xx>" >> internal_mailmap/.mailmap &&
|
|
|
|
echo "Santa Claus <santa.claus@northpole.xx> <me@company.xx>" >> internal_mailmap/.mailmap &&
|
|
|
|
|
|
|
|
git shortlog -e HEAD >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
|
|
|
|
'
|
|
|
|
|
|
|
|
# git log with --pretty format which uses the name and email mailmap placemarkers
|
|
|
|
cat >expect <<\EOF
|
|
|
|
Author CTO <cto@coompany.xx> maps to CTO <cto@company.xx>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
|
|
|
|
Author claus <me@company.xx> maps to Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
|
|
|
|
Author santa <me@company.xx> maps to Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
|
|
|
|
Author nick2 <nick2@company.xx> maps to Other Author <other@author.xx>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
|
|
|
|
Author nick2 <bugs@company.xx> maps to Other Author <other@author.xx>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
|
|
|
|
Author nick1 <bugs@company.xx> maps to Some Dude <some@dude.xx>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
|
|
|
|
Author A U Thor <author@example.com> maps to A U Thor <author@example.com>
|
|
|
|
Committer C O Mitter <committer@example.com> maps to Committed <committer@example.com>
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'Log output (complex mapping)' '
|
|
|
|
git log --pretty=format:"Author %an <%ae> maps to %aN <%aE>%nCommitter %cn <%ce> maps to %cN <%cE>%n" >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2013-01-05 22:26:44 +01:00
|
|
|
cat >expect <<\EOF
|
|
|
|
Author: CTO <cto@company.xx>
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Author: Other Author <other@author.xx>
|
|
|
|
Author: Other Author <other@author.xx>
|
|
|
|
Author: Some Dude <some@dude.xx>
|
|
|
|
Author: A U Thor <author@example.com>
|
|
|
|
EOF
|
2013-01-05 22:26:45 +01:00
|
|
|
|
2013-01-05 22:26:44 +01:00
|
|
|
test_expect_success 'Log output with --use-mailmap' '
|
|
|
|
git log --use-mailmap | grep Author >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2013-01-05 22:26:46 +01:00
|
|
|
cat >expect <<\EOF
|
|
|
|
Author: CTO <cto@company.xx>
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Author: Other Author <other@author.xx>
|
|
|
|
Author: Other Author <other@author.xx>
|
|
|
|
Author: Some Dude <some@dude.xx>
|
|
|
|
Author: A U Thor <author@example.com>
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'Log output with log.mailmap' '
|
|
|
|
git -c log.mailmap=True log | grep Author >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2013-01-05 22:26:45 +01:00
|
|
|
cat >expect <<\EOF
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'Grep author with --use-mailmap' '
|
|
|
|
git log --use-mailmap --author Santa | grep Author >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
2013-01-05 22:26:46 +01:00
|
|
|
cat >expect <<\EOF
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
Author: Santa Claus <santa.claus@northpole.xx>
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_expect_success 'Grep author with log.mailmap' '
|
|
|
|
git -c log.mailmap=True log --author Santa | grep Author >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
2013-01-05 22:26:45 +01:00
|
|
|
|
|
|
|
>expect
|
|
|
|
|
|
|
|
test_expect_success 'Only grep replaced author with --use-mailmap' '
|
|
|
|
git log --use-mailmap --author "<cto@coompany.xx>" >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2009-02-08 15:34:30 +01:00
|
|
|
# git blame
|
|
|
|
cat >expect <<\EOF
|
2010-10-15 19:12:19 +02:00
|
|
|
^OBJI (A U Thor DATE 1) one
|
|
|
|
OBJID (Some Dude DATE 2) two
|
|
|
|
OBJID (Other Author DATE 3) three
|
|
|
|
OBJID (Other Author DATE 4) four
|
|
|
|
OBJID (Santa Claus DATE 5) five
|
|
|
|
OBJID (Santa Claus DATE 6) six
|
|
|
|
OBJID (CTO DATE 7) seven
|
2009-02-08 15:34:30 +01:00
|
|
|
EOF
|
|
|
|
test_expect_success 'Blame output (complex mapping)' '
|
|
|
|
git blame one >actual &&
|
2010-10-15 19:12:19 +02:00
|
|
|
fuzz_blame actual >actual.fuzz &&
|
|
|
|
test_cmp expect actual.fuzz
|
2009-02-08 15:34:30 +01:00
|
|
|
'
|
|
|
|
|
2009-02-08 15:34:27 +01:00
|
|
|
test_done
|