2009-03-20 07:00:43 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='Test reflog display routines'
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
test_expect_success 'setup' '
|
|
|
|
echo content >file &&
|
|
|
|
git add file &&
|
|
|
|
test_tick &&
|
|
|
|
git commit -m one
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
Reflog: HEAD@{0} (C O Mitter <committer@example.com>)
|
|
|
|
Reflog message: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'log -g shows reflog headers' '
|
|
|
|
git log -g -1 >tmp &&
|
|
|
|
grep ^Reflog <tmp >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
e46513e HEAD@{0}: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'oneline reflog format' '
|
|
|
|
git log -g -1 --oneline >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2011-04-01 11:20:32 +02:00
|
|
|
test_expect_success 'reflog default format' '
|
|
|
|
git reflog -1 >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
commit e46513e
|
|
|
|
Reflog: HEAD@{0} (C O Mitter <committer@example.com>)
|
|
|
|
Reflog message: commit (initial): one
|
|
|
|
Author: A U Thor <author@example.com>
|
|
|
|
|
|
|
|
one
|
|
|
|
EOF
|
2011-04-01 11:20:33 +02:00
|
|
|
test_expect_success 'override reflog default format' '
|
2011-04-01 11:20:32 +02:00
|
|
|
git reflog --format=short -1 >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2009-03-20 07:00:43 +01:00
|
|
|
cat >expect <<'EOF'
|
|
|
|
Reflog: HEAD@{Thu Apr 7 15:13:13 2005 -0700} (C O Mitter <committer@example.com>)
|
|
|
|
Reflog message: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'using @{now} syntax shows reflog date (multiline)' '
|
|
|
|
git log -g -1 HEAD@{now} >tmp &&
|
|
|
|
grep ^Reflog <tmp >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
e46513e HEAD@{Thu Apr 7 15:13:13 2005 -0700}: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'using @{now} syntax shows reflog date (oneline)' '
|
|
|
|
git log -g -1 --oneline HEAD@{now} >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2012-05-04 07:23:14 +02:00
|
|
|
cat >expect <<'EOF'
|
|
|
|
HEAD@{Thu Apr 7 15:13:13 2005 -0700}
|
|
|
|
EOF
|
|
|
|
test_expect_success 'using @{now} syntax shows reflog date (format=%gd)' '
|
|
|
|
git log -g -1 --format=%gd HEAD@{now} >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2009-03-20 07:00:43 +01:00
|
|
|
cat >expect <<'EOF'
|
2012-05-07 23:11:32 +02:00
|
|
|
Reflog: HEAD@{Thu Apr 7 15:13:13 2005 -0700} (C O Mitter <committer@example.com>)
|
2009-03-20 07:00:43 +01:00
|
|
|
Reflog message: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'using --date= shows reflog date (multiline)' '
|
2012-05-07 23:11:32 +02:00
|
|
|
git log -g -1 --date=default >tmp &&
|
2009-03-20 07:00:43 +01:00
|
|
|
grep ^Reflog <tmp >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
2012-05-07 23:11:32 +02:00
|
|
|
e46513e HEAD@{Thu Apr 7 15:13:13 2005 -0700}: commit (initial): one
|
2009-03-20 07:00:43 +01:00
|
|
|
EOF
|
|
|
|
test_expect_success 'using --date= shows reflog date (oneline)' '
|
2012-05-07 23:11:32 +02:00
|
|
|
git log -g -1 --oneline --date=default >actual &&
|
2009-03-20 07:00:43 +01:00
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2012-05-04 07:23:14 +02:00
|
|
|
cat >expect <<'EOF'
|
|
|
|
HEAD@{1112911993 -0700}
|
|
|
|
EOF
|
|
|
|
test_expect_success 'using --date= shows reflog date (format=%gd)' '
|
|
|
|
git log -g -1 --format=%gd --date=raw >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
Reflog: HEAD@{0} (C O Mitter <committer@example.com>)
|
|
|
|
Reflog message: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'log.date does not invoke "--date" magic (multiline)' '
|
|
|
|
test_config log.date raw &&
|
|
|
|
git log -g -1 >tmp &&
|
|
|
|
grep ^Reflog <tmp >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
e46513e HEAD@{0}: commit (initial): one
|
|
|
|
EOF
|
|
|
|
test_expect_success 'log.date does not invoke "--date" magic (oneline)' '
|
|
|
|
test_config log.date raw &&
|
|
|
|
git log -g -1 --oneline >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
cat >expect <<'EOF'
|
|
|
|
HEAD@{0}
|
|
|
|
EOF
|
log: respect date_mode_explicit with --format:%gd
When we show a reflog selector (e.g., via "git log -g"), we
perform some DWIM magic: while we normally show the entry's
index (e.g., HEAD@{1}), if the user has given us a date
with "--date", then we show a date-based select (e.g.,
HEAD@{yesterday}).
However, we don't want to trigger this magic if the
alternate date format we got was from the "log.date"
configuration; that is not sufficiently strong context for
us to invoke this particular magic. To fix this, commit
f4ea32f (improve reflog date/number heuristic, 2009-09-24)
introduced a "date_mode_explicit" flag in rev_info. This
flag is set only when we see a "--date" option on the
command line, and we a vanilla date to the reflog code if
the date was not explicit.
Later, commit 8f8f547 (Introduce new pretty formats %g[sdD]
for reflog information, 2009-10-19) added another way to
show selectors, and it did not respect the date_mode_explicit
flag from f4ea32f.
This patch propagates the date_mode_explicit flag to the
pretty-print code, which can then use it to pass the
appropriate date field to the reflog code. This brings the
behavior of "%gd" in line with the other formats, and means
that its output is independent of any user configuration.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2012-05-04 07:25:18 +02:00
|
|
|
test_expect_success 'log.date does not invoke "--date" magic (format=%gd)' '
|
2012-05-04 07:23:14 +02:00
|
|
|
test_config log.date raw &&
|
|
|
|
git log -g -1 --format=%gd >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
reflog-walk: always make HEAD@{0} show indexed selectors
When we are showing reflog selectors during a walk, we infer
from context whether the user wanted to see the index in
each selector, or the reflog date. The current rules are:
1. if the user asked for an explicit date format in the
output, show the date
2. if the user asked for ref@{now}, show the date
3. if neither is true, show the index
However, if we see "ref@{0}", that should be a strong clue
that the user wants to see the counted version. In fact, it
should be much stronger than the date format in (1). The
user may have been setting the date format to use in another
part of the output (e.g., in --format="%gd (%ad)", they may
have wanted to influence the author date).
This patch flips the rules to:
1. if the user asked for ref@{0}, always show the index
2. if the user asked for ref@{now}, always show the date
3. otherwise, we have just "ref"; show them counted by
default, but respect the presence of "--date" as a clue
that the user wanted them date-based
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2012-05-04 07:27:25 +02:00
|
|
|
cat >expect <<'EOF'
|
|
|
|
HEAD@{0}
|
|
|
|
EOF
|
|
|
|
test_expect_success '--date magic does not override explicit @{0} syntax' '
|
|
|
|
git log -g -1 --format=%gd --date=raw HEAD@{0} >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2010-03-13 23:47:05 +01:00
|
|
|
: >expect
|
|
|
|
test_expect_success 'empty reflog file' '
|
|
|
|
git branch empty &&
|
2015-07-28 00:57:08 +02:00
|
|
|
git reflog expire --expire=all refs/heads/empty &&
|
2010-03-13 23:47:05 +01:00
|
|
|
|
|
|
|
git log -g empty >actual &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2013-08-03 12:36:15 +02:00
|
|
|
# This guards against the alternative of showing the diffs vs. the
|
|
|
|
# reflog ancestor. The reflog used is designed to list the commits
|
|
|
|
# more than once, so as to exercise the corresponding logic.
|
|
|
|
test_expect_success 'git log -g -p shows diffs vs. parents' '
|
|
|
|
test_commit two &&
|
|
|
|
git branch flipflop &&
|
|
|
|
git update-ref refs/heads/flipflop -m flip1 HEAD^ &&
|
|
|
|
git update-ref refs/heads/flipflop -m flop1 HEAD &&
|
|
|
|
git update-ref refs/heads/flipflop -m flip2 HEAD^ &&
|
|
|
|
git log -g -p flipflop >reflog &&
|
|
|
|
grep -v ^Reflog reflog >actual &&
|
|
|
|
git log -1 -p HEAD^ >log.one &&
|
|
|
|
git log -1 -p HEAD >log.two &&
|
|
|
|
(
|
|
|
|
cat log.one; echo
|
|
|
|
cat log.two; echo
|
|
|
|
cat log.one; echo
|
|
|
|
cat log.two
|
|
|
|
) >expect &&
|
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
2015-07-21 23:04:53 +02:00
|
|
|
test_expect_success 'reflog exists works' '
|
|
|
|
git reflog exists refs/heads/master &&
|
|
|
|
! git reflog exists refs/heads/nonexistent
|
|
|
|
'
|
|
|
|
|
reflog-walk: duplicate strings in complete_reflogs list
As part of the add_reflog_to_walk() function, we keep a
string_list mapping refnames to their reflog contents. This
serves as a cache so that accessing the same reflog twice
requires only a single copy of the log in memory.
The string_list is initialized via xcalloc, meaning its
strdup_strings field is set to 0. But after inserting a
string into the list, we unconditionally call free() on the
string, leaving the list pointing to freed memory. If
another reflog is added (e.g., "git log -g HEAD HEAD"), then
the second one may have unpredictable results.
The extra free was added by 5026b47175 (add_reflog_for_walk:
avoid memory leak, 2017-05-04). Though if you look
carefully, you can see that the code was buggy even before
then. If we tried to read the reflogs by time but came up
with no entries, we exited with an error, freeing the string
in that code path. So the bug was harder to trigger, but
still there.
We can fix it by just asking the string list to make a copy
of the string. Technically we could fix the problem by not
calling free() on our string (and just handing over
ownership to the string list), but there are enough
conditionals that it's quite hard to figure out which code
paths need the free and which do not. Simpler is better
here.
The new test reliably shows the problem when run with
--valgrind or ASAN.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2017-07-07 10:39:50 +02:00
|
|
|
# The behavior with two reflogs is buggy and the output is in flux; for now
|
|
|
|
# we're just checking that the program works at all without segfaulting.
|
|
|
|
test_expect_success 'showing multiple reflogs works' '
|
|
|
|
git log -g HEAD HEAD >actual
|
|
|
|
'
|
|
|
|
|
2017-07-07 10:41:49 +02:00
|
|
|
test_expect_success 'showing multiple reflogs with an old date' '
|
|
|
|
git log -g HEAD@{1979-01-01} HEAD >actual
|
|
|
|
'
|
|
|
|
|
2009-03-20 07:00:43 +01:00
|
|
|
test_done
|