2011-08-23 10:20:33 +08:00
|
|
|
#
|
2012-04-09 08:18:02 +08:00
|
|
|
# Library code for git p4 tests
|
2011-08-23 10:20:33 +08:00
|
|
|
#
|
|
|
|
|
2012-06-27 20:00:57 +08:00
|
|
|
# p4 tests never use the top-level repo; always build/clone into
|
|
|
|
# a subdirectory called "$git"
|
|
|
|
TEST_NO_CREATE_REPO=NoThanks
|
|
|
|
|
2011-08-23 10:20:33 +08:00
|
|
|
. ./test-lib.sh
|
|
|
|
|
|
|
|
if ! test_have_prereq PYTHON; then
|
2012-04-09 08:18:02 +08:00
|
|
|
skip_all='skipping git p4 tests; python not available'
|
2011-08-23 10:20:33 +08:00
|
|
|
test_done
|
|
|
|
fi
|
|
|
|
( p4 -h && p4d -h ) >/dev/null 2>&1 || {
|
2012-04-09 08:18:02 +08:00
|
|
|
skip_all='skipping git p4 tests; no p4 or p4d'
|
2011-08-23 10:20:33 +08:00
|
|
|
test_done
|
|
|
|
}
|
|
|
|
|
|
|
|
# Try to pick a unique port: guess a large number, then hope
|
|
|
|
# no more than one of each test is running.
|
|
|
|
#
|
|
|
|
# This does not handle the case where somebody else is running the
|
|
|
|
# same tests and has chosen the same ports.
|
|
|
|
testid=${this_test#t}
|
|
|
|
git_p4_test_start=9800
|
|
|
|
P4DPORT=$((10669 + ($testid - $git_p4_test_start)))
|
|
|
|
|
|
|
|
export P4PORT=localhost:$P4DPORT
|
|
|
|
export P4CLIENT=client
|
2012-04-24 16:33:20 +08:00
|
|
|
export P4EDITOR=:
|
2011-08-23 10:20:33 +08:00
|
|
|
|
|
|
|
db="$TRASH_DIRECTORY/db"
|
2012-06-27 20:00:55 +08:00
|
|
|
cli=$(test-path-utils real_path "$TRASH_DIRECTORY/cli")
|
2011-08-23 10:20:33 +08:00
|
|
|
git="$TRASH_DIRECTORY/git"
|
|
|
|
pidfile="$TRASH_DIRECTORY/p4d.pid"
|
|
|
|
|
|
|
|
start_p4d() {
|
|
|
|
mkdir -p "$db" "$cli" "$git" &&
|
2012-06-28 10:48:07 +08:00
|
|
|
rm -f "$pidfile" &&
|
2011-08-23 10:20:33 +08:00
|
|
|
(
|
|
|
|
p4d -q -r "$db" -p $P4DPORT &
|
|
|
|
echo $! >"$pidfile"
|
|
|
|
) &&
|
2012-06-28 10:48:07 +08:00
|
|
|
|
|
|
|
# This gives p4d a long time to start up, as it can be
|
|
|
|
# quite slow depending on the machine. Set this environment
|
|
|
|
# variable to something smaller to fail faster in, say,
|
|
|
|
# an automated test setup. If the p4d process dies, that
|
|
|
|
# will be caught with the "kill -0" check below.
|
|
|
|
i=${P4D_START_PATIENCE:-300}
|
|
|
|
pid=$(cat "$pidfile")
|
|
|
|
ready=
|
|
|
|
while test $i -gt 0
|
|
|
|
do
|
|
|
|
# succeed when p4 client commands start to work
|
|
|
|
if p4 info >/dev/null 2>&1
|
|
|
|
then
|
|
|
|
ready=true
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
# fail if p4d died
|
|
|
|
kill -0 $pid 2>/dev/null || break
|
|
|
|
echo waiting for p4d to start
|
2011-08-23 10:20:33 +08:00
|
|
|
sleep 1
|
2012-06-28 10:48:07 +08:00
|
|
|
i=$(( $i - 1 ))
|
|
|
|
done
|
|
|
|
|
|
|
|
if test -z "$ready"
|
|
|
|
then
|
|
|
|
# p4d failed to start
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# build a client
|
2011-08-23 10:20:33 +08:00
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 client -i <<-EOF
|
|
|
|
Client: client
|
|
|
|
Description: client
|
|
|
|
Root: $cli
|
|
|
|
View: //depot/... //client/...
|
|
|
|
EOF
|
|
|
|
)
|
2012-06-28 10:48:07 +08:00
|
|
|
return 0
|
2011-08-23 10:20:33 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
kill_p4d() {
|
|
|
|
pid=$(cat "$pidfile")
|
|
|
|
# it had better exist for the first kill
|
|
|
|
kill $pid &&
|
|
|
|
for i in 1 2 3 4 5 ; do
|
|
|
|
kill $pid >/dev/null 2>&1 || break
|
|
|
|
sleep 1
|
|
|
|
done &&
|
|
|
|
# complain if it would not die
|
|
|
|
test_must_fail kill $pid >/dev/null 2>&1 &&
|
|
|
|
rm -rf "$db" "$cli" "$pidfile"
|
|
|
|
}
|
|
|
|
|
|
|
|
cleanup_git() {
|
2012-06-27 20:01:01 +08:00
|
|
|
rm -rf "$git" &&
|
|
|
|
mkdir "$git"
|
2011-08-23 10:20:33 +08:00
|
|
|
}
|
2012-07-04 21:34:19 +08:00
|
|
|
|
|
|
|
marshal_dump() {
|
|
|
|
what=$1 &&
|
|
|
|
line=${2:-1} &&
|
|
|
|
cat >"$TRASH_DIRECTORY/marshal-dump.py" <<-EOF &&
|
|
|
|
import marshal
|
|
|
|
import sys
|
|
|
|
for i in range($line):
|
|
|
|
d = marshal.load(sys.stdin)
|
|
|
|
print d['$what']
|
|
|
|
EOF
|
|
|
|
"$PYTHON_PATH" "$TRASH_DIRECTORY/marshal-dump.py"
|
|
|
|
}
|