Show More
@@ -1,39 +1,42 | |||||
1 | #!/bin/sh |
|
1 | #!/bin/sh | |
2 | # |
|
2 | # | |
3 | # wait up to TIMEOUT seconds until a WAIT_ON_FILE is created. |
|
3 | # wait up to TIMEOUT seconds until a WAIT_ON_FILE is created. | |
4 | # |
|
4 | # | |
5 | # In addition, this script can create CREATE_FILE once it is ready to wait. |
|
5 | # In addition, this script can create CREATE_FILE once it is ready to wait. | |
6 |
|
6 | |||
7 | if [ $# -lt 2 ] || [ $# -gt 3 ]; then |
|
7 | if [ $# -lt 2 ] || [ $# -gt 3 ]; then | |
8 | echo $# |
|
8 | echo $# | |
9 | echo "USAGE: $0 TIMEOUT WAIT_ON_FILE [CREATE_FILE]" |
|
9 | echo "USAGE: $0 TIMEOUT WAIT_ON_FILE [CREATE_FILE]" | |
10 | fi |
|
10 | fi | |
11 |
|
11 | |||
12 | timer="$1" |
|
12 | timer="$1" | |
13 |
|
13 | |||
14 | # Scale the timeout to match the sleep steps below, i.e. 1/0.02. |
|
|||
15 | timer=$(( 50 * $timer )) |
|
|||
16 | # If the test timeout have been extended, also scale the timer relative |
|
14 | # If the test timeout have been extended, also scale the timer relative | |
17 | # to the normal timing. |
|
15 | # to the normal timing. | |
18 | if [ "$HGTEST_TIMEOUT_DEFAULT" -lt "$HGTEST_TIMEOUT" ]; then |
|
16 | if [ "$HGTEST_TIMEOUT_DEFAULT" -lt "$HGTEST_TIMEOUT" ]; then | |
19 | timer=$(( ( $timer * $HGTEST_TIMEOUT) / $HGTEST_TIMEOUT_DEFAULT )) |
|
17 | timer=$(( ( $timer * $HGTEST_TIMEOUT) / $HGTEST_TIMEOUT_DEFAULT )) | |
20 | fi |
|
18 | fi | |
21 |
|
19 | |||
|
20 | max_time=$timer | |||
|
21 | ||||
|
22 | # Scale the timeout to match the sleep steps below, i.e. 1/0.02. | |||
|
23 | timer=$(( 50 * $timer )) | |||
|
24 | ||||
22 | wait_on="$2" |
|
25 | wait_on="$2" | |
23 | create="" |
|
26 | create="" | |
24 | if [ $# -eq 3 ]; then |
|
27 | if [ $# -eq 3 ]; then | |
25 | create="$3" |
|
28 | create="$3" | |
26 | fi |
|
29 | fi | |
27 |
|
30 | |||
28 | if [ -n "$create" ]; then |
|
31 | if [ -n "$create" ]; then | |
29 | touch "$create" |
|
32 | touch "$create" | |
30 | create="" |
|
33 | create="" | |
31 | fi |
|
34 | fi | |
32 | while [ "$timer" -gt 0 ] && !([ -e "$wait_on" ] || [ -L "$wait_on" ]) ; do |
|
35 | while [ "$timer" -gt 0 ] && !([ -e "$wait_on" ] || [ -L "$wait_on" ]) ; do | |
33 | timer=$(( $timer - 1)) |
|
36 | timer=$(( $timer - 1)) | |
34 | sleep 0.02 |
|
37 | sleep 0.02 | |
35 | done |
|
38 | done | |
36 | if [ "$timer" -le 0 ]; then |
|
39 | if [ "$timer" -le 0 ]; then | |
37 |
echo "file not created after $ |
|
40 | echo "file not created after $max_time seconds: $wait_on" >&2 | |
38 | exit 1 |
|
41 | exit 1 | |
39 | fi |
|
42 | fi |
General Comments 0
You need to be logged in to leave comments.
Login now