| #!/bin/sh |
| # |
| # Copyright (c) 2007 Johannes E. Schindelin |
| # |
| |
| test_description='Test commit notes index (expensive!)' |
| |
| . ./test-lib.sh |
| |
| test -z "$GIT_NOTES_TIMING_TESTS" && { |
| say Skipping timing tests |
| test_done |
| exit |
| } |
| |
| create_repo () { |
| number_of_commits=$1 |
| nr=0 |
| test -d .git || { |
| git init && |
| ( |
| while [ $nr -lt $number_of_commits ]; do |
| nr=$(($nr+1)) |
| mark=$(($nr+$nr)) |
| notemark=$(($mark+1)) |
| test_tick && |
| cat <<INPUT_END && |
| commit refs/heads/master |
| mark :$mark |
| committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE |
| data <<COMMIT |
| commit #$nr |
| COMMIT |
| |
| M 644 inline file |
| data <<EOF |
| file in commit #$nr |
| EOF |
| |
| blob |
| mark :$notemark |
| data <<EOF |
| note for commit #$nr |
| EOF |
| |
| INPUT_END |
| |
| echo "N :$notemark :$mark" >> note_commit |
| done && |
| test_tick && |
| cat <<INPUT_END && |
| commit refs/notes/commits |
| committer $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL> $GIT_COMMITTER_DATE |
| data <<COMMIT |
| notes |
| COMMIT |
| |
| INPUT_END |
| |
| cat note_commit |
| ) | |
| git fast-import --quiet && |
| git config core.notesRef refs/notes/commits |
| } |
| } |
| |
| test_notes () { |
| count=$1 && |
| git config core.notesRef refs/notes/commits && |
| git log | grep "^ " > output && |
| i=$count && |
| while [ $i -gt 0 ]; do |
| echo " commit #$i" && |
| echo " note for commit #$i" && |
| i=$(($i-1)); |
| done > expect && |
| test_cmp expect output |
| } |
| |
| cat > time_notes << \EOF |
| mode=$1 |
| i=1 |
| while [ $i -lt $2 ]; do |
| case $1 in |
| no-notes) |
| GIT_NOTES_REF=non-existing; export GIT_NOTES_REF |
| ;; |
| notes) |
| unset GIT_NOTES_REF |
| ;; |
| esac |
| git log >/dev/null |
| i=$(($i+1)) |
| done |
| EOF |
| |
| time_notes () { |
| for mode in no-notes notes |
| do |
| echo $mode |
| /usr/bin/time sh ../time_notes $mode $1 |
| done |
| } |
| |
| for count in 10 100 1000 10000; do |
| |
| mkdir $count |
| (cd $count; |
| |
| test_expect_success "setup $count" "create_repo $count" |
| |
| test_expect_success 'notes work' "test_notes $count" |
| |
| test_expect_success 'notes timing' "time_notes 100" |
| ) |
| done |
| |
| test_done |