Hash :
2d463f36
Author :
Date :
2019-08-13T00:42:47
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173
#!/bin/sh
#
# Copyright (c) 2019 Stefan Sperling <stsp@openbsd.org>
#
# Permission to use, copy, modify, and distribute this software for any
# purpose with or without fee is hereby granted, provided that the above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
. ./common.sh
function test_ref_create {
local testroot=`test_init ref_create`
local commit_id=`git_show_head $testroot/repo`
# Create a head ref based on repository's HEAD reference
got ref -r $testroot/repo refs/heads/newref HEAD
ret="$?"
if [ "$ret" != "0" ]; then
echo "got ref command failed unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
# Ensure that Git recognizes the ref Got has created
(cd $testroot/repo && git checkout -q newref)
ret="$?"
if [ "$ret" != "0" ]; then
echo "git checkout command failed unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
# Ensure Git recognizes the new ref
got checkout -b newref $testroot/repo $testroot/wt >/dev/null
ret="$?"
if [ "$ret" != "0" ]; then
echo "got checkout command failed unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
# Create a head ref based on another specific ref
(cd $testroot/wt && got ref refs/heads/anotherref refs/heads/master)
ret="$?"
if [ "$ret" != "0" ]; then
test_done "$testroot" "$ret"
return 1
fi
(cd $testroot/repo && git checkout -q anotherref)
ret="$?"
if [ "$ret" != "0" ]; then
echo "git checkout command failed unexpectedly"
test_done "$testroot" "$ret"
fi
# Create a symbolic ref
(cd $testroot/wt && got ref -s refs/heads/symbolicref refs/heads/master)
ret="$?"
if [ "$ret" != "0" ]; then
test_done "$testroot" "$ret"
return 1
fi
(cd $testroot/repo && git checkout -q symbolicref)
ret="$?"
if [ "$ret" != "0" ]; then
echo "git checkout command failed unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
# Attempt to create a symbolic ref pointing at a non-reference
(cd $testroot/wt && got ref -s refs/heads/symbolicref $commit_id \
2> $testroot/stderr)
ret="$?"
if [ "$ret" == "0" ]; then
echo "git ref command succeeded unexpectedly"
test_done "$testroot" "1"
return 1
fi
echo "got: reference $commit_id not found" > $testroot/stderr.expected
cmp -s $testroot/stderr $testroot/stderr.expected
ret="$?"
if [ "$ret" != "0" ]; then
diff -u $testroot/stderr.expected $testroot/stderr
test_done "$testroot" "$ret"
return 1
fi
got ref -r $testroot/repo -l > $testroot/stdout
echo "HEAD: refs/heads/symbolicref" > $testroot/stdout.expected
echo -n "refs/got/worktree/base-" >> $testroot/stdout.expected
cat $testroot/wt/.got/uuid | tr -d '\n' >> $testroot/stdout.expected
echo ": $commit_id" >> $testroot/stdout.expected
echo "refs/heads/anotherref: $commit_id" >> $testroot/stdout.expected
echo "refs/heads/master: $commit_id" >> $testroot/stdout.expected
echo "refs/heads/newref: $commit_id" >> $testroot/stdout.expected
echo "refs/heads/symbolicref: refs/heads/master" \
>> $testroot/stdout.expected
cmp -s $testroot/stdout $testroot/stdout.expected
ret="$?"
if [ "$ret" != "0" ]; then
diff -u $testroot/stdout.expected $testroot/stdout
fi
test_done "$testroot" "$ret"
}
function test_ref_delete {
local testroot=`test_init ref_delete`
local commit_id=`git_show_head $testroot/repo`
for b in ref1 ref2 ref3; do
got ref -r $testroot/repo refs/heads/$b refs/heads/master
ret="$?"
if [ "$ret" != "0" ]; then
echo "got ref command failed unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
done
got ref -d refs/heads/ref2 -r $testroot/repo > $testroot/stdout
ret="$?"
if [ "$ret" != "0" ]; then
echo "got ref command failed unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
got ref -l -r $testroot/repo > $testroot/stdout
echo "HEAD: refs/heads/master" > $testroot/stdout.expected
echo "refs/heads/master: $commit_id" >> $testroot/stdout.expected
echo "refs/heads/ref1: $commit_id" >> $testroot/stdout.expected
echo "refs/heads/ref3: $commit_id" >> $testroot/stdout.expected
cmp -s $testroot/stdout $testroot/stdout.expected
ret="$?"
if [ "$ret" != "0" ]; then
diff -u $testroot/stdout.expected $testroot/stdout
test_done "$testroot" "$ret"
return 1
fi
got ref -d refs/heads/bogus_ref_name -r $testroot/repo \
> $testroot/stdout 2> $testroot/stderr
ret="$?"
if [ "$ret" == "0" ]; then
echo "got ref succeeded unexpectedly"
test_done "$testroot" "$ret"
return 1
fi
echo "got: reference refs/heads/bogus_ref_name not found" \
> $testroot/stderr.expected
cmp -s $testroot/stderr $testroot/stderr.expected
ret="$?"
if [ "$ret" != "0" ]; then
diff -u $testroot/stderr.expected $testroot/stderr
fi
test_done "$testroot" "$ret"
}
run_test test_ref_create
run_test test_ref_delete