]> git.ipfire.org Git - thirdparty/git.git/commitdiff
pickaxe tests: add test for "log -S" not being a regex
authorÆvar Arnfjörð Bjarmason <avarab@gmail.com>
Mon, 12 Apr 2021 17:15:11 +0000 (19:15 +0200)
committerJunio C Hamano <gitster@pobox.com>
Tue, 11 May 2021 03:47:31 +0000 (12:47 +0900)
No test in our test suite checked for "log -S<pat>" being a fixed
string, as opposed to "log -S<pat> --pickaxe-regex". Let's test for
it.

Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
t/t4209-log-pickaxe.sh

index eacb9f0a1b57ce16850076284e549848c144d698..9fa770b5fbd4009a77c0c843b4d7e9f972f08db9 100755 (executable)
@@ -106,11 +106,18 @@ test_expect_success 'log -S --no-textconv (missing textconv tool)' '
        rm .gitattributes
 '
 
-test_expect_success 'setup log -[GS] plain' '
+test_expect_success 'setup log -[GS] plain & regex' '
        test_create_repo GS-plain &&
        test_commit -C GS-plain --append A data.txt "a" &&
        test_commit -C GS-plain --append B data.txt "a a" &&
-       test_commit -C GS-plain C data.txt "" &&
+       test_commit -C GS-plain --append C data.txt "b" &&
+       test_commit -C GS-plain --append D data.txt "[b]" &&
+       test_commit -C GS-plain E data.txt "" &&
+
+       # We also include E, the deletion commit
+       git -C GS-plain log --grep="[ABE]" >A-to-B-then-E-log &&
+       git -C GS-plain log --grep="[CDE]" >C-to-D-then-E-log &&
+       git -C GS-plain log --grep="[DE]" >D-then-E-log &&
        git -C GS-plain log >full-log
 '
 
@@ -118,7 +125,24 @@ test_expect_success 'log -G trims diff new/old [-+]' '
        git -C GS-plain log -G"[+-]a" >log &&
        test_must_be_empty log &&
        git -C GS-plain log -G"^a" >log &&
-       test_cmp log full-log
+       test_cmp log A-to-B-then-E-log
+'
+
+test_expect_success 'log -S<pat> is not a regex, but -S<pat> --pickaxe-regex is' '
+       git -C GS-plain log -S"a" >log &&
+       test_cmp log A-to-B-then-E-log &&
+
+       git -C GS-plain log -S"[a]" >log &&
+       test_must_be_empty log &&
+
+       git -C GS-plain log -S"[a]" --pickaxe-regex >log &&
+       test_cmp log A-to-B-then-E-log &&
+
+       git -C GS-plain log -S"[b]" >log &&
+       test_cmp log D-then-E-log &&
+
+       git -C GS-plain log -S"[b]" --pickaxe-regex >log &&
+       test_cmp log C-to-D-then-E-log
 '
 
 test_expect_success 'setup log -[GS] binary & --text' '