| #!/bin/sh |
| |
| test_description='diff --relative tests' |
| |
| TEST_PASSES_SANITIZE_LEAK=true |
| . ./test-lib.sh |
| |
| test_expect_success 'setup' ' |
| git commit --allow-empty -m empty && |
| echo content >file1 && |
| mkdir subdir && |
| echo other content >subdir/file2 && |
| blob_file1=$(git hash-object file1) && |
| blob_file2=$(git hash-object subdir/file2) && |
| git add . && |
| git commit -m one |
| ' |
| |
| check_diff () { |
| dir=$1 |
| shift |
| expect=$1 |
| shift |
| short_blob=$(git rev-parse --short $blob_file2) |
| cat >expected <<-EOF |
| diff --git a/$expect b/$expect |
| new file mode 100644 |
| index 0000000..$short_blob |
| --- /dev/null |
| +++ b/$expect |
| @@ -0,0 +1 @@ |
| +other content |
| EOF |
| test_expect_success "-p $*" " |
| git -C '$dir' diff -p $* HEAD^ >actual && |
| test_cmp expected actual |
| " |
| } |
| |
| check_numstat () { |
| dir=$1 |
| shift |
| expect=$1 |
| shift |
| cat >expected <<-EOF |
| 1 0 $expect |
| EOF |
| test_expect_success "--numstat $*" " |
| echo '1 0 $expect' >expected && |
| git -C '$dir' diff --numstat $* HEAD^ >actual && |
| test_cmp expected actual |
| " |
| } |
| |
| check_stat () { |
| dir=$1 |
| shift |
| expect=$1 |
| shift |
| cat >expected <<-EOF |
| $expect | 1 + |
| 1 file changed, 1 insertion(+) |
| EOF |
| test_expect_success "--stat $*" " |
| git -C '$dir' diff --stat $* HEAD^ >actual && |
| test_cmp expected actual |
| " |
| } |
| |
| check_raw () { |
| dir=$1 |
| shift |
| expect=$1 |
| shift |
| cat >expected <<-EOF |
| :000000 100644 $ZERO_OID $blob_file2 A $expect |
| EOF |
| test_expect_success "--raw $*" " |
| git -C '$dir' diff --no-abbrev --raw $* HEAD^ >actual && |
| test_cmp expected actual |
| " |
| } |
| |
| for type in diff numstat stat raw |
| do |
| check_$type . file2 --relative=subdir/ |
| check_$type . file2 --relative=subdir |
| check_$type subdir file2 --relative |
| check_$type . dir/file2 --relative=sub |
| done |
| |
| check_diff_relative_option () { |
| dir=$1 |
| shift |
| expect=$1 |
| shift |
| relative_opt=$1 |
| shift |
| test_expect_success "config diff.relative $relative_opt -p $*" " |
| short_blob=\$(git rev-parse --short $blob_file2) && |
| cat >expected <<-EOF && |
| diff --git a/$expect b/$expect |
| new file mode 100644 |
| index 0000000..\$short_blob |
| --- /dev/null |
| +++ b/$expect |
| @@ -0,0 +1 @@ |
| +other content |
| EOF |
| test_config -C $dir diff.relative $relative_opt && |
| git -C '$dir' diff -p $* HEAD^ >actual && |
| test_cmp expected actual |
| " |
| } |
| |
| check_diff_no_relative_option () { |
| dir=$1 |
| shift |
| expect=$1 |
| shift |
| relative_opt=$1 |
| shift |
| test_expect_success "config diff.relative $relative_opt -p $*" " |
| short_blob_file1=\$(git rev-parse --short $blob_file1) && |
| short_blob_file2=\$(git rev-parse --short $blob_file2) && |
| cat >expected <<-EOF && |
| diff --git a/file1 b/file1 |
| new file mode 100644 |
| index 0000000..\$short_blob_file1 |
| --- /dev/null |
| +++ b/file1 |
| @@ -0,0 +1 @@ |
| +content |
| diff --git a/$expect b/$expect |
| new file mode 100644 |
| index 0000000..\$short_blob_file2 |
| --- /dev/null |
| +++ b/$expect |
| @@ -0,0 +1 @@ |
| +other content |
| EOF |
| test_config -C $dir diff.relative $relative_opt && |
| git -C '$dir' diff -p $* HEAD^ >actual && |
| test_cmp expected actual |
| " |
| } |
| |
| check_diff_no_relative_option . subdir/file2 false |
| check_diff_no_relative_option . subdir/file2 true --no-relative |
| check_diff_no_relative_option . subdir/file2 false --no-relative |
| check_diff_no_relative_option subdir subdir/file2 false |
| check_diff_no_relative_option subdir subdir/file2 true --no-relative |
| check_diff_no_relative_option subdir subdir/file2 false --no-relative |
| |
| check_diff_relative_option . file2 false --relative=subdir/ |
| check_diff_relative_option . file2 false --relative=subdir |
| check_diff_relative_option . file2 true --relative=subdir/ |
| check_diff_relative_option . file2 true --relative=subdir |
| check_diff_relative_option subdir file2 false --relative |
| check_diff_relative_option subdir file2 true --relative |
| check_diff_relative_option subdir file2 true |
| check_diff_relative_option subdir file2 false --no-relative --relative |
| check_diff_relative_option subdir file2 true --no-relative --relative |
| check_diff_relative_option . file2 false --no-relative --relative=subdir |
| check_diff_relative_option . file2 true --no-relative --relative=subdir |
| |
| test_expect_success 'external diff with --relative' ' |
| test_when_finished "git reset --hard" && |
| echo changed >file1 && |
| echo changed >subdir/file2 && |
| |
| write_script mydiff <<-\EOF && |
| # hacky pretend diff; the goal here is just to make sure we got |
| # passed sensible input that we _could_ diff, without relying on |
| # the specific output of a system diff tool. |
| echo "diff a/$1 b/$1" && |
| echo "--- a/$1" && |
| echo "+++ b/$1" && |
| echo "@@ -1 +0,0 @@" && |
| sed "s/^/-/" "$2" && |
| sed "s/^/+/" "$5" |
| EOF |
| |
| cat >expect <<-\EOF && |
| diff a/file2 b/file2 |
| --- a/file2 |
| +++ b/file2 |
| @@ -1 +0,0 @@ |
| -other content |
| +changed |
| EOF |
| GIT_EXTERNAL_DIFF=./mydiff git diff --relative=subdir >actual && |
| test_cmp expect actual |
| ' |
| |
| test_expect_success 'setup diff --relative unmerged' ' |
| test_commit zero file0 && |
| test_commit base subdir/file0 && |
| git switch -c br1 && |
| test_commit one file0 && |
| test_commit sub1 subdir/file0 && |
| git switch -c br2 base && |
| test_commit two file0 && |
| git switch -c br3 && |
| test_commit sub3 subdir/file0 |
| ' |
| |
| test_expect_success 'diff --relative without change in subdir' ' |
| git switch br2 && |
| test_when_finished "git merge --abort" && |
| test_must_fail git merge one && |
| git -C subdir diff --relative >out && |
| test_must_be_empty out && |
| git -C subdir diff --relative --name-only >out && |
| test_must_be_empty out |
| ' |
| |
| test_expect_success 'diff --relative --name-only with change in subdir' ' |
| git switch br3 && |
| test_when_finished "git merge --abort" && |
| test_must_fail git merge sub1 && |
| test_write_lines file0 file0 >expected && |
| git -C subdir diff --relative --name-only >out && |
| test_cmp expected out |
| ' |
| |
| test_expect_failure 'diff --relative with change in subdir' ' |
| git switch br3 && |
| br1_blob=$(git rev-parse --short --verify br1:subdir/file0) && |
| br3_blob=$(git rev-parse --short --verify br3:subdir/file0) && |
| test_when_finished "git merge --abort" && |
| test_must_fail git merge br1 && |
| cat >expected <<-EOF && |
| diff --cc file0 |
| index $br3_blob,$br1_blob..0000000 |
| --- a/file0 |
| +++ b/file0 |
| @@@ -1,1 -1,1 +1,5 @@@ |
| ++<<<<<<< HEAD |
| +sub3 |
| ++======= |
| + sub1 |
| ++>>>>>>> br1 |
| EOF |
| git -C subdir diff --relative >out && |
| test_cmp expected out |
| ' |
| |
| test_done |