blob: 958e33b77ee31dd5fcbda3a421ad98eab5bd5d40 [file] [log] [blame]
Pete Wyckofffc002332011-08-22 22:20:33 -04001#
Pete Wyckoff6ab1d762012-04-08 20:18:02 -04002# Library code for git p4 tests
Pete Wyckofffc002332011-08-22 22:20:33 -04003#
4
Pete Wyckoffc88015a2012-06-27 08:00:57 -04005# p4 tests never use the top-level repo; always build/clone into
6# a subdirectory called "$git"
7TEST_NO_CREATE_REPO=NoThanks
8
Lars Schneider23aee412015-11-19 09:58:08 +01009# Some operations require multiple attempts to be successful. Define
10# here the maximal retry timeout in seconds.
11RETRY_TIMEOUT=60
12
Lars Schneider842adde2015-11-19 09:58:09 +010013# Sometimes p4d seems to hang. Terminate the p4d process automatically after
14# the defined timeout in seconds.
15P4D_TIMEOUT=300
16
Pete Wyckofffc002332011-08-22 22:20:33 -040017. ./test-lib.sh
18
Pete Wyckoffcfa96492013-01-26 22:11:11 -050019if ! test_have_prereq PYTHON
20then
Pete Wyckoff6ab1d762012-04-08 20:18:02 -040021 skip_all='skipping git p4 tests; python not available'
Pete Wyckofffc002332011-08-22 22:20:33 -040022 test_done
23fi
24( p4 -h && p4d -h ) >/dev/null 2>&1 || {
Pete Wyckoff6ab1d762012-04-08 20:18:02 -040025 skip_all='skipping git p4 tests; no p4 or p4d'
Pete Wyckofffc002332011-08-22 22:20:33 -040026 test_done
27}
28
Pete Wyckoffcfa96492013-01-26 22:11:11 -050029# On cygwin, the NT version of Perforce can be used. When giving
30# it paths, either on the command-line or in client specifications,
31# be sure to use the native windows form.
32#
33# Older versions of perforce were available compiled natively for
34# cygwin. Those do not accept native windows paths, so make sure
35# not to convert for them.
Jan Duroveca98772c2016-04-19 19:49:41 +000036native_path () {
Pete Wyckoffcfa96492013-01-26 22:11:11 -050037 path="$1" &&
38 if test_have_prereq CYGWIN && ! p4 -V | grep -q CYGWIN
39 then
40 path=$(cygpath --windows "$path")
41 else
Nguyễn Thái Ngọc Duyb8d5cf42018-03-24 08:44:49 +010042 path=$(test-tool path-utils real_path "$path")
Pete Wyckoffcfa96492013-01-26 22:11:11 -050043 fi &&
44 echo "$path"
45}
46
Lars Schneider23aee412015-11-19 09:58:08 +010047# On Solaris the 'date +%s' function is not supported and therefore we
48# need this replacement.
49# Attention: This function is not safe again against time offset updates
50# at runtime (e.g. via NTP). The 'clock_gettime(CLOCK_MONOTONIC)'
51# function could fix that but it is not in Python until 3.3.
Jan Duroveca98772c2016-04-19 19:49:41 +000052time_in_seconds () {
Luke Diamand1fb3fb42016-04-26 08:51:01 +010053 (cd / && "$PYTHON_PATH" -c 'import time; print(int(time.time()))')
Lars Schneider23aee412015-11-19 09:58:08 +010054}
55
SZEDER Gáborfa840582019-01-05 02:08:58 +010056test_set_port P4DPORT
Pete Wyckofffc002332011-08-22 22:20:33 -040057
Pete Wyckoff8c291352012-09-09 16:16:02 -040058P4PORT=localhost:$P4DPORT
59P4CLIENT=client
Pete Wyckoff0055b562014-01-21 18:16:43 -050060P4USER=author
Pete Wyckoff0cf1b722014-01-21 18:16:44 -050061P4EDITOR=true
kazuki saitoh79946032013-08-10 16:15:12 -040062unset P4CHARSET
Pete Wyckoff0055b562014-01-21 18:16:43 -050063export P4PORT P4CLIENT P4USER P4EDITOR P4CHARSET
Pete Wyckofffc002332011-08-22 22:20:33 -040064
65db="$TRASH_DIRECTORY/db"
Pete Wyckoffcfa96492013-01-26 22:11:11 -050066cli="$TRASH_DIRECTORY/cli"
Pete Wyckofffc002332011-08-22 22:20:33 -040067git="$TRASH_DIRECTORY/git"
68pidfile="$TRASH_DIRECTORY/p4d.pid"
69
Lars Schneiderdfe90e82015-11-19 09:58:10 +010070# Sometimes "prove" seems to hang on exit because p4d is still running
Jan Duroveca98772c2016-04-19 19:49:41 +000071cleanup () {
Lars Schneiderdfe90e82015-11-19 09:58:10 +010072 if test -f "$pidfile"
73 then
74 kill -9 $(cat "$pidfile") 2>/dev/null && exit 255
75 fi
76}
Lars Schneiderdfe90e82015-11-19 09:58:10 +010077
Pete Wyckoff0cf1b722014-01-21 18:16:44 -050078# git p4 submit generates a temp file, which will
79# not get cleaned up if the submission fails. Don't
80# clutter up /tmp on the test machine.
81TMPDIR="$TRASH_DIRECTORY"
82export TMPDIR
83
Johannes Schindelin99e37c22019-03-13 13:24:15 +010084registered_stop_p4d_atexit_handler=
Jan Duroveca98772c2016-04-19 19:49:41 +000085start_p4d () {
Johannes Schindelin99e37c22019-03-13 13:24:15 +010086 # One of the test scripts stops and then re-starts p4d.
87 # Don't register and then run the same atexit handlers several times.
88 if test -z "$registered_stop_p4d_atexit_handler"
89 then
90 test_atexit 'kill_p4d; cleanup'
91 registered_stop_p4d_atexit_handler=AlreadyDone
92 fi
93
Pete Wyckofffc002332011-08-22 22:20:33 -040094 mkdir -p "$db" "$cli" "$git" &&
Pete Wyckofff89f35a2012-06-27 22:48:07 -040095 rm -f "$pidfile" &&
Pete Wyckofffc002332011-08-22 22:20:33 -040096 (
Pete Wyckoff6492a102013-01-26 22:11:10 -050097 cd "$db" &&
98 {
Luke Diamande80967b2015-04-28 10:08:01 +010099 p4d -q -p $P4DPORT "$@" &
Pete Wyckoff6492a102013-01-26 22:11:10 -0500100 echo $! >"$pidfile"
101 }
Pete Wyckofffc002332011-08-22 22:20:33 -0400102 ) &&
Pete Wyckofff89f35a2012-06-27 22:48:07 -0400103
104 # This gives p4d a long time to start up, as it can be
105 # quite slow depending on the machine. Set this environment
106 # variable to something smaller to fail faster in, say,
107 # an automated test setup. If the p4d process dies, that
108 # will be caught with the "kill -0" check below.
109 i=${P4D_START_PATIENCE:-300}
110 pid=$(cat "$pidfile")
Lars Schneider842adde2015-11-19 09:58:09 +0100111
112 timeout=$(($(time_in_seconds) + $P4D_TIMEOUT))
113 while true
114 do
115 if test $(time_in_seconds) -gt $timeout
116 then
117 kill -9 $pid
118 exit 1
119 fi
120 sleep 1
121 done &
122 watchdog_pid=$!
123
Pete Wyckofff89f35a2012-06-27 22:48:07 -0400124 ready=
125 while test $i -gt 0
126 do
127 # succeed when p4 client commands start to work
128 if p4 info >/dev/null 2>&1
129 then
130 ready=true
131 break
132 fi
133 # fail if p4d died
134 kill -0 $pid 2>/dev/null || break
135 echo waiting for p4d to start
Pete Wyckofffc002332011-08-22 22:20:33 -0400136 sleep 1
Pete Wyckofff89f35a2012-06-27 22:48:07 -0400137 i=$(( $i - 1 ))
138 done
139
140 if test -z "$ready"
141 then
142 # p4d failed to start
143 return 1
144 fi
145
Pete Wyckoff0055b562014-01-21 18:16:43 -0500146 # build a p4 user so author@example.com has an entry
147 p4_add_user author
148
Pete Wyckofff89f35a2012-06-27 22:48:07 -0400149 # build a client
Pete Wyckoffdaa38f42013-01-26 22:11:07 -0500150 client_view "//depot/... //client/..." &&
151
Pete Wyckofff89f35a2012-06-27 22:48:07 -0400152 return 0
Pete Wyckofffc002332011-08-22 22:20:33 -0400153}
154
Jan Duroveca98772c2016-04-19 19:49:41 +0000155p4_add_user () {
Pete Wyckoff0055b562014-01-21 18:16:43 -0500156 name=$1 &&
157 p4 user -f -i <<-EOF
158 User: $name
159 Email: $name@example.com
160 FullName: Dr. $name
161 EOF
162}
163
Jan Durovec26e6a272016-04-19 19:49:41 +0000164p4_add_job () {
165 p4 job -f -i <<-EOF
166 Job: $1
167 Status: open
168 User: dummy
169 Description:
170 EOF
171}
172
Jan Duroveca98772c2016-04-19 19:49:41 +0000173retry_until_success () {
Lars Schneider23aee412015-11-19 09:58:08 +0100174 timeout=$(($(time_in_seconds) + $RETRY_TIMEOUT))
175 until "$@" 2>/dev/null || test $(time_in_seconds) -gt $timeout
176 do
177 sleep 1
178 done
179}
180
Jan Duroveca98772c2016-04-19 19:49:41 +0000181retry_until_fail () {
Lars Schneider23aee412015-11-19 09:58:08 +0100182 timeout=$(($(time_in_seconds) + $RETRY_TIMEOUT))
183 until ! "$@" 2>/dev/null || test $(time_in_seconds) -gt $timeout
184 do
185 sleep 1
186 done
187}
188
Jan Duroveca98772c2016-04-19 19:49:41 +0000189kill_p4d () {
Pete Wyckofffc002332011-08-22 22:20:33 -0400190 pid=$(cat "$pidfile")
Lars Schneider23aee412015-11-19 09:58:08 +0100191 retry_until_fail kill $pid
192 retry_until_fail kill -9 $pid
Pete Wyckofffc002332011-08-22 22:20:33 -0400193 # complain if it would not die
194 test_must_fail kill $pid >/dev/null 2>&1 &&
Lars Schneider842adde2015-11-19 09:58:09 +0100195 rm -rf "$db" "$cli" "$pidfile" &&
196 retry_until_fail kill -9 $watchdog_pid
Pete Wyckofffc002332011-08-22 22:20:33 -0400197}
198
Jan Duroveca98772c2016-04-19 19:49:41 +0000199cleanup_git () {
Lars Schneider23aee412015-11-19 09:58:08 +0100200 retry_until_success rm -r "$git"
201 test_must_fail test -d "$git" &&
202 retry_until_success mkdir "$git"
Pete Wyckofffc002332011-08-22 22:20:33 -0400203}
Pete Wyckoff798d5982012-07-04 09:34:19 -0400204
Jan Duroveca98772c2016-04-19 19:49:41 +0000205marshal_dump () {
Pete Wyckoff798d5982012-07-04 09:34:19 -0400206 what=$1 &&
207 line=${2:-1} &&
208 cat >"$TRASH_DIRECTORY/marshal-dump.py" <<-EOF &&
209 import marshal
210 import sys
Luke Diamand84096812016-04-26 08:51:00 +0100211 instream = getattr(sys.stdin, 'buffer', sys.stdin)
Pete Wyckoff798d5982012-07-04 09:34:19 -0400212 for i in range($line):
Luke Diamand84096812016-04-26 08:51:00 +0100213 d = marshal.load(instream)
214 print(d[b'$what'].decode('utf-8'))
Pete Wyckoff798d5982012-07-04 09:34:19 -0400215 EOF
216 "$PYTHON_PATH" "$TRASH_DIRECTORY/marshal-dump.py"
217}
Pete Wyckoffd2018292012-08-11 12:55:00 -0400218
219#
220# Construct a client with this list of View lines
221#
Jan Duroveca98772c2016-04-19 19:49:41 +0000222client_view () {
Pete Wyckoffd2018292012-08-11 12:55:00 -0400223 (
224 cat <<-EOF &&
Pete Wyckoff50038ba2013-01-26 22:11:09 -0500225 Client: $P4CLIENT
226 Description: $P4CLIENT
Pete Wyckoffd2018292012-08-11 12:55:00 -0400227 Root: $cli
Pete Wyckoffcfa96492013-01-26 22:11:11 -0500228 AltRoots: $(native_path "$cli")
Pete Wyckoffe93f8692013-01-26 22:11:15 -0500229 LineEnd: unix
Pete Wyckoffd2018292012-08-11 12:55:00 -0400230 View:
231 EOF
Pete Wyckoff61125412013-01-26 22:11:08 -0500232 printf "\t%s\n" "$@"
Pete Wyckoffd2018292012-08-11 12:55:00 -0400233 ) | p4 client -i
234}
Pete Wyckoffe9df0f92013-01-26 22:11:17 -0500235
Jan Duroveca98772c2016-04-19 19:49:41 +0000236is_cli_file_writeable () {
Pete Wyckoffe9df0f92013-01-26 22:11:17 -0500237 # cygwin version of p4 does not set read-only attr,
238 # will be marked 444 but -w is true
239 file="$1" &&
240 if test_have_prereq CYGWIN && p4 -V | grep -q CYGWIN
241 then
242 stat=$(stat --format=%a "$file") &&
243 test $stat = 644
244 else
245 test -w "$file"
246 fi
247}