| # Create commits in <repo> and assign each commit's oid to shell variables |
| # given in the arguments (A, B, and C). E.g.: |
| # |
| # create_commits_in <repo> A B C |
| # |
| # NOTE: Never calling this function from a subshell since variable |
| # assignments will disappear when subshell exits. |
| create_commits_in () { |
| repo="$1" && test -d "$repo" || |
| error "Repository $repo does not exist." |
| shift && |
| while test $# -gt 0 |
| do |
| name=$1 && |
| shift && |
| test_commit -C "$repo" --no-tag "$name" && |
| eval $name=$(git -C "$repo" rev-parse HEAD) |
| done |
| } |
| |
| get_abbrev_oid () { |
| oid=$1 && |
| suffix=${oid#???????} && |
| oid=${oid%$suffix} && |
| if test -n "$oid" |
| then |
| echo "$oid" |
| else |
| echo "undefined-oid" |
| fi |
| } |
| |
| # Format the output of git-push, git-show-ref and other commands to make a |
| # user-friendly and stable text. We can easily prepare the expect text |
| # without having to worry about changes of the commit ID (full or abbrev.) |
| # of the output. Single quotes are replaced with double quotes, because |
| # it is boring to prepare unquoted single quotes in expect text. We also |
| # remove some locale error messages. The emitted human-readable errors are |
| # redundant to the more machine-readable output the tests already assert. |
| make_user_friendly_and_stable_output () { |
| sed \ |
| -e "s/'/\"/g" \ |
| -e "s/$(get_abbrev_oid $A)[0-9a-f]*/<COMMIT-A>/g" \ |
| -e "s/$(get_abbrev_oid $B)[0-9a-f]*/<COMMIT-B>/g" \ |
| -e "s/$(get_abbrev_oid $TAG)[0-9a-f]*/<TAG-v123>/g" \ |
| -e "s/$ZERO_OID/<ZERO-OID>/g" \ |
| -e "s#To $URL_PREFIX/upstream.git#To <URL/of/upstream.git>#" \ |
| -e "/^error: / d" |
| } |
| |
| filter_out_user_friendly_and_stable_output () { |
| make_user_friendly_and_stable_output | |
| sed -n ${1+"$@"} |
| } |
| |
| format_and_save_expect () { |
| sed -e 's/^> //' -e 's/Z$//' >expect |
| } |
| |
| test_cmp_refs () { |
| indir= |
| if test "$1" = "-C" |
| then |
| shift |
| indir="$1" |
| shift |
| fi |
| indir=${indir:+"$indir"/} |
| cat >show-ref.expect && |
| git ${indir:+ -C "$indir"} show-ref >show-ref.pristine && |
| make_user_friendly_and_stable_output <show-ref.pristine >show-ref.filtered && |
| test_cmp show-ref.expect show-ref.filtered |
| } |