git-commit-vandalism/t/perf/p3400-rebase.sh
Nipunn Koorapati ed5a24573d perf lint: add make test-lint to perf tests
Perf tests have not been linted for some time.
They've grown some seq instead of test_seq. This
runs the existing lints on the perf tests as well.

Signed-off-by: Nipunn Koorapati <nipunn@dropbox.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2020-10-20 12:52:23 -07:00

57 lines
1.4 KiB
Bash
Executable File

#!/bin/sh
test_description='Tests rebase performance'
. ./perf-lib.sh
test_perf_default_repo
test_expect_success 'setup rebasing on top of a lot of changes' '
git checkout -f -B base &&
git checkout -B to-rebase &&
git checkout -B upstream &&
for i in $(test_seq 100)
do
# simulate huge diffs
echo change$i >unrelated-file$i &&
test_seq 1000 >>unrelated-file$i &&
git add unrelated-file$i &&
test_tick &&
git commit -m commit$i unrelated-file$i &&
echo change$i >unrelated-file$i &&
test_seq 1000 | tac >>unrelated-file$i &&
git add unrelated-file$i &&
test_tick &&
git commit -m commit$i-reverse unrelated-file$i ||
break
done &&
git checkout to-rebase &&
test_commit our-patch interesting-file
'
test_perf 'rebase on top of a lot of unrelated changes' '
git rebase --onto upstream HEAD^ &&
git rebase --onto base HEAD^
'
test_expect_success 'setup rebasing many changes without split-index' '
git config core.splitIndex false &&
git checkout -B upstream2 to-rebase &&
git checkout -B to-rebase2 upstream
'
test_perf 'rebase a lot of unrelated changes without split-index' '
git rebase --onto upstream2 base &&
git rebase --onto base upstream2
'
test_expect_success 'setup rebasing many changes with split-index' '
git config core.splitIndex true
'
test_perf 'rebase a lot of unrelated changes with split-index' '
git rebase --onto upstream2 base &&
git rebase --onto base upstream2
'
test_done