#!/bin/sh setvar test_description = ''git rebase - test patch id computation'' source ./test-lib.sh proc count { setvar i = '0' while test $i -lt $1 { echo $i setvar i = $(($i+1)) } } proc scramble { setvar i = '0' while read x { if test $i -ne 0 { echo $x } setvar i = $((($i+1) % 10)) } <"$1" >"$1.new" mv -f "$1.new" $1 } proc run { echo '$' @ARGV /usr/bin/time @ARGV >/dev/null } test_expect_success 'setup' ' git commit --allow-empty -m initial && git tag root ' proc do_tests { setvar nlines = "$1", pr = ${2-} test_expect_success $pr "setup: $nlines lines" " rm -f .gitattributes && git checkout -q -f master && git reset --hard root && count $nlines >file && git add file && git commit -q -m initial && git branch -f other && scramble file && git add file && git commit -q -m 'change big file' && git checkout -q other && : >newfile && git add newfile && git commit -q -m 'add small file' && git cherry-pick master >/dev/null 2>&1 " test_debug " run git diff master^\! " test_expect_success $pr 'setup attributes' " echo 'file binary' >.gitattributes " test_debug " run git format-patch --stdout master && run git format-patch --stdout --ignore-if-in-upstream master " test_expect_success $pr 'detect upstream patch' ' git checkout -q master && scramble file && git add file && git commit -q -m "change big file again" && git checkout -q other^{} && git rebase master && test_must_fail test -n "$(git rev-list master...HEAD~)" ' test_expect_success $pr 'do not drop patch' ' git branch -f squashed master && git checkout -q -f squashed && git reset -q --soft HEAD~2 && git commit -q -m squashed && git checkout -q other^{} && test_must_fail git rebase squashed && rm -rf .git/rebase-apply ' } do_tests 500 do_tests 50000 EXPENSIVE test_done