3 # Copyright (c) 2019, 2020 Stefan Sperling <stsp@openbsd.org>
5 # Permission to use, copy, modify, and distribute this software for any
6 # purpose with or without fee is hereby granted, provided that the above
7 # copyright notice and this permission notice appear in all copies.
9 # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 export GIT_AUTHOR_NAME="Flan Hacker"
20 export GIT_AUTHOR_EMAIL="flan_hacker@openbsd.org"
21 export GIT_COMMITTER_NAME="$GIT_AUTHOR_NAME"
22 export GIT_COMMITTER_EMAIL="$GIT_AUTHOR_EMAIL"
23 export GOT_AUTHOR="$GIT_AUTHOR_NAME <$GIT_AUTHOR_EMAIL>"
24 export GOT_AUTHOR_8="flan_hac"
25 export GOT_AUTHOR_11="flan_hacker"
26 export GOT_LOG_DEFAULT_LIMIT=0
27 export GOT_TEST_ROOT="/tmp"
28 export GOT_IGNORE_GITCONFIG=1
29 export GOT_VERSION_STR=`got --version | cut -d ' ' -f2`
30 export GOT_TEST_HTTP_PORT=8080
34 export MALLOC_OPTIONS=S
36 if [ "$(date -u -r 86400 +%F 2>/dev/null)" != 1970-01-02 ]; then
38 for p in date gdate; do
39 if [ "$($p -u -d @86400 +%F 2>/dev/null)" = 1970-01-02 ]; then
44 if [ -z "$DATECMD" ]; then
45 echo "Couldn't find gdate, is GNU coreutils installed?" >&2
52 while getopts r:u flag; do
60 command "$DATECMD" $u ${r+-d"@$r"} "$@"
68 # Switch the default branch to match our test expectations if needed.
69 # Only need to change HEAD since 'git init' did not create any refs.
70 # Relying on implementation details of 'git init' is no problem for us.
71 # We want to be alerted when Git changes fundamental assumptions such
72 # as what an empty repository looks like and where the default branch
73 # is set. In such cases Got's own tooling might well need to change
74 # its behaviour, too, and our tests should fail.
75 # TODO: Update all tests to assume 'main' instead of 'master' and
76 # switch to main here, to match Got's own default.
77 echo "ref: refs/heads/master" > "$1/.git/HEAD"
83 if [ -n "$GOT_TEST_PACK" ]; then
85 if [ "$GOT_TEST_PACK" = "ref-delta" ]; then
89 (cd $repo && gotadmin pack -a $arg > /dev/null)
90 (cd $repo && gotadmin cleanup -a -q)
98 git -C $repo commit --author="$GOT_AUTHOR" -q -a "$@"
106 git -C $repo rm -q "$@"
113 git -C $repo rm -q -r "$@"
119 git -C $repo show --no-patch --pretty='format:%H'
122 git_show_branch_head()
126 git -C $repo show --no-patch --pretty='format:%H' $branch
130 git_show_author_time()
134 git -C $repo show --no-patch --pretty='format:%at' $object
137 git_show_tagger_time()
141 git -C $repo cat-file tag $tag | grep ^tagger | \
142 sed -e "s/^tagger $GOT_AUTHOR//" | cut -d' ' -f2
145 git_show_parent_commit()
149 git -C $repo show --no-patch --pretty='format:%P' $commit
155 git -C $repo show --no-patch --pretty='format:%T'
164 while [ "$trimcount" -gt 0 ]; do
166 trimcount=$((trimcount - 1))
175 printf '%s' "${1:-index-out-of-bounds}"
183 git -C $repo commit-tree -m "$msg" "$tree"
191 git -C $repo fsck --strict \
192 > $testroot/fsck.stdout 2> $testroot/fsck.stderr
194 if [ $ret -ne 0 ]; then
196 cat $testroot/fsck.stderr
197 echo "git fsck failed; leaving test data in $testroot"
208 echo alpha > $repo/alpha
209 echo beta > $repo/beta
211 echo delta > $repo/gamma/delta
213 echo zeta > $repo/epsilon/zeta
216 make_single_file_repo()
223 echo "this is file $file" > $repo/$file
225 git_commit $repo -m "intialize $repo with file $file"
228 get_loose_object_path()
232 local id0=`trim_obj_id 38 $id`
233 local idrest=`echo ${id#[0-9a-f][0-9a-f]}`
234 echo "$repo/.git/objects/$id0/$idrest"
243 got tree -r $repo -i $tree_path | grep "[0-9a-f] ${filename}$" | \
251 if [ -z "$testname" ]; then
252 echo "No test name provided" >&2
255 local testroot=`mktemp -d \
256 "$GOT_TEST_ROOT/got-test-$testname-XXXXXXXXXX"`
258 git_init $testroot/repo
259 if [ -z "$no_tree" ]; then
260 make_test_tree $testroot/repo
262 git_commit $testroot/repo -m "adding the test tree"
264 touch $testroot/repo/.git/git-daemon-export-ok
272 git_fsck $testroot $testroot/repo
274 if [ $ret -ne 0 ]; then
283 while getopts qr: flag; do
285 q) export GOT_TEST_QUIET=1
287 r) export GOT_TEST_ROOT=${OPTARG%/}
289 ?) echo "Supported options:"
290 echo " -q: quiet mode"
291 echo " -r PATH: use PATH as test data root directory"
296 shift $(($OPTIND - 1))
297 regress_run_only="$@"
304 if [ -n "$regress_run_only" ]; then
305 case "$regress_run_only" in
311 if [ -z "$GOT_TEST_QUIET" ]; then
321 if [ "$result" = "0" ]; then
322 test_cleanup "$testroot" || return 1
323 if [ -z "$GOT_TEST_QUIET" ]; then
326 elif echo "$result" | grep -q "^xfail"; then
327 # expected test failure; test reproduces an unfixed bug
329 test_cleanup "$testroot" || return 1
331 echo "test failed; leaving test data in $testroot"