# Create commits in and assign each commit's oid to shell variables # given in the arguments (A, B, and C). E.g.: # # create_commits_in A B C # # NOTE: Never calling this function from a subshell since variable # assignments will disappear when subshell exits. create_commits_in () { repo="$1" && if ! parent=$(git -C "$repo" rev-parse HEAD^{} --) then parent= fi && T=$(git -C "$repo" write-tree) && shift && while test $# -gt 0 do name=$1 && test_tick && if test -z "$parent" then oid=$(echo $name | git -C "$repo" commit-tree $T) else oid=$(echo $name | git -C "$repo" commit-tree -p $parent $T) fi && eval $name=$oid && parent=$oid && shift || return 1 done && git -C "$repo" update-ref refs/heads/main $oid } # 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/$A//g" \ -e "s/$B//g" \ -e "s/$TAG//g" \ -e "s/$ZERO_OID//g" \ -e "s/$(echo $A | cut -c1-7)[0-9a-f]*//g" \ -e "s/$(echo $B | cut -c1-7)[0-9a-f]*//g" \ -e "s#To $URL_PREFIX/upstream.git#To #" \ -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.filtered && test_cmp show-ref.expect show-ref.filtered }