3 test_description
='various tests of reflog walk (log -g) behavior'
6 test_expect_success
'set up some reflog entries' '
9 git checkout -b side HEAD^ &&
11 git merge --no-commit master &&
12 echo evil-merge-content >>one.t &&
14 git commit --no-edit -a
18 git log
-g --format="%gd %gs" "$@"
22 test_expect_success
'set up expected reflog' '
23 cat >expect.all <<-EOF
24 HEAD@{0} commit (merge): Merge branch ${sq}master${sq} into side
25 HEAD@{1} commit: three
26 HEAD@{2} checkout: moving from master to side
28 HEAD@{4} commit (initial): one
32 test_expect_success
'reflog walk shows expected logs' '
34 test_cmp expect.all actual
37 test_expect_success
'reflog can limit with --no-merges' '
38 grep -v merge expect.all >expect &&
39 do_walk --no-merges >actual &&
40 test_cmp expect actual
43 test_expect_success
'reflog can limit with pathspecs' '
44 grep two expect.all >expect &&
45 do_walk -- two.t >actual &&
46 test_cmp expect actual
49 test_expect_success
'pathspec limiting handles merges' '
51 # - the initial commit of one
52 # - the checkout back to commit one
53 # - the evil merge which touched one
54 sed -n "1p;3p;5p" expect.all >expect &&
55 do_walk -- one.t >actual &&
56 test_cmp expect actual
59 test_expect_success
'--parents shows true parents' '
60 # convert newlines to spaces
61 echo $(git rev-parse HEAD HEAD^1 HEAD^2) >expect &&
62 git rev-list -g --parents -1 HEAD >actual &&
63 test_cmp expect actual
66 test_expect_success
'walking multiple reflogs shows all' '
67 # We expect to see all entries for all reflogs, but interleaved by
68 # date, with order on the command line breaking ties. We
69 # can use "sort" on the separate lists to generate this,
70 # but note two tricks:
72 # 1. We use "{" as the delimiter, which lets us skip to the reflog
73 # date specifier as our second field, and then our "-n" numeric
74 # sort ignores the bits after the timestamp.
76 # 2. POSIX leaves undefined whether this is a stable sort or not. So
77 # we use "-k 1" to ensure that we see HEAD before master before
78 # side when breaking ties.
80 do_walk --date=unix HEAD &&
81 do_walk --date=unix side &&
82 do_walk --date=unix master
84 sort -t "{" -k 2nr -k 1 <expect.raw >expect &&
85 do_walk --date=unix HEAD master side >actual &&
86 test_cmp expect actual
89 test_expect_success
'date-limiting does not interfere with other logs' '
90 do_walk HEAD@{1979-01-01} HEAD >actual &&
91 test_cmp expect.all actual
94 test_expect_success
'min/max age uses entry date to limit' '
95 # Flip between commits one and two so each ref update actually
96 # does something (and does not get optimized out). We know
97 # that the timestamps of those commits will be before our "min".
99 git update-ref -m before refs/heads/minmax one &&
103 git update-ref -m min refs/heads/minmax two &&
107 git update-ref -m max refs/heads/minmax one &&
110 git update-ref -m after refs/heads/minmax two &&
112 cat >expect <<-\EOF &&
116 git log -g --since=$min --until=$max --format=%gs minmax >actual &&
117 test_cmp expect actual
120 test_expect_success
'walk prefers reflog to ref tip' '
121 head=$(git rev-parse HEAD) &&
122 one=$(git rev-parse one) &&
123 ident="$GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE" &&
124 echo "$head $one $ident broken reflog entry" >>.git/logs/HEAD &&
127 git log -g --format=%H -1 >actual &&
128 test_cmp expect actual
131 test_expect_success
'rev-list -g complains when there are no reflogs' '
132 test_must_fail git rev-list -g