forked from awslabs/libfabric-ci-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsingle-node.sh
executable file
·100 lines (83 loc) · 3.34 KB
/
single-node.sh
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
#!/bin/bash
set -xe
source $WORKSPACE/libfabric-ci-scripts/common.sh
trap 'on_exit' EXIT
slave_name=slave_$label
slave_value=${!slave_name}
ami=($slave_value)
NODES=1
# Placement group is not needed for single-node tests.
export ENABLE_PLACEMENT_GROUP=0
export USER_DATA_FILE=${USER_DATA_FILE:-${JENKINS_HOME}/user_data_script.sh}
set +x
create_instance || { echo "==>Unable to create instance"; exit 65; }
set -x
get_instance_ip
execution_seq=$((${execution_seq}+1))
test_ssh ${INSTANCE_IPS}
scp -o ConnectTimeout=30 -o StrictHostKeyChecking=no -i ~/${slave_keypair} \
$WORKSPACE/libfabric-ci-scripts/wget_check.sh \
${ami[1]}@${INSTANCE_IPS}:~/
execution_seq=$((${execution_seq}+1))
# Add AMI specific installation commands
script_builder single-node
# Appending fabtests to the existing installation script
cat <<-"EOF" >> ${tmp_script}
. ~/.bash_profile
ssh-keygen -f ${HOME}/.ssh/id_rsa -N "" > /dev/null
cat ${HOME}/.ssh/id_rsa.pub >> ${HOME}/.ssh/authorized_keys
runfabtests_script="${HOME}/libfabric/fabtests/install/bin/runfabtests.sh"
EXCLUDE=${HOME}/libfabric/fabtests/install/share/fabtests/test_configs/${PROVIDER}/${PROVIDER}.exclude
if [ -f ${EXCLUDE} ]; then
EXCLUDE="-R -f ${EXCLUDE}"
else
EXCLUDE=""
fi
# Provider-specific handling of the options passed to runfabtests.sh
FABTESTS_OPTS="-E LD_LIBRARY_PATH=\"$LD_LIBRARY_PATH\" -vvv ${EXCLUDE}"
FABTESTS_OPTS+=" -p ${HOME}/libfabric/fabtests/install/bin/"
case "${PROVIDER}" in
"efa")
# EFA provider supports a custom address format based on the GID of the
# device. Extract that from sysfs and pass it to the tests. Also have the
# client communicate with QP0 of the server. This is only for older
# versions of fabtests, newer versions can use the -b option to exchange
# out of band.
b_option_available="$($runfabtests_script -h 2>&1 | grep '\-b' || true)"
# Check if '-P' option (Run provider specific fabtests) is available
P_option_available="$($runfabtests_script -h 2>&1 | grep '\-P' || true)"
FABTESTS_OPTS+=" -t all"
if [ -n "$P_option_available" ]; then
FABTESTS_OPTS+=" -P"
fi
if [ -n "$b_option_available" ]; then
FABTESTS_OPTS+=" -b"
else
gid=$(ibv_devinfo -v | grep GID | awk '{print $3}')
FABTESTS_OPTS+=" -C \"-P 0\" -s $gid -c $gid"
fi
;;
"shm")
# The shm provider does not support the negative tests with bad addresses,
# and there seems to be no easy way to add them to the exclude lists..
# See https://github.com/ofiwg/libfabric/issues/5182 for context.
FABTESTS_OPTS+=" -N"
;;
esac
bash -c "$runfabtests_script ${FABTESTS_OPTS} ${PROVIDER} 127.0.0.1 127.0.0.1"
EOF
# Test whether node is ready for SSH connection or not
test_ssh ${INSTANCE_IPS}
execution_seq=$((${execution_seq}+1))
# For single node, the ssh connection is established only once. The script
# builds libfabric and also executes fabtests
set +x
ssh -o ConnectTimeout=30 -o StrictHostKeyChecking=no -T -i ~/${slave_keypair} ${ami[1]}@${INSTANCE_IPS} \
"bash -s" -- <${tmp_script} \
"$PULL_REQUEST_ID" "$PULL_REQUEST_REF" "$PROVIDER" "$ami_arch" "$libfabric_job_type" 2>&1 | tr \\r \\n | \
sed 's/\(.*\)/'${INSTANCE_IPS}' \1/' | tee ${output_dir}/temp_execute_runfabtests.txt
EXIT_CODE=${PIPESTATUS[0]}
set -x
# Get build status
exit_status "$EXIT_CODE" "${INSTANCE_IPS}"
exit ${BUILD_CODE}