-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathrun_test_nesting.sh
executable file
·146 lines (120 loc) · 3.91 KB
/
run_test_nesting.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
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
#!/bin/bash
base_app_dir="$(pwd)/tests_nesting/"
COMPSs_log_folder="/tmp/COMPSsWorker01"
target_log_folder="$(pwd)"
retry_num=1
echo $base_app_dir
echo $COMPSs_log_folder
echo $target_log_folder
AGENT_PIDS=""
exit_value=0
expected_time="60"
NUM_RETRIES="50"
app_name="Nesting_Tests"
# Traps and Handlers
function kill_agents() {
for pid in ${AGENT_PIDS}; do
kill -SIGINT ${pid} 2>/dev/null
done
}
trap kill_agents EXIT
#sed -i '/<InstallDir>/c<InstallDir>'"${COMPSS_HOME}"'<\/InstallDir>' "${base_app_dir}"/project.xml
mkdir -p /tmp/COMPSsWorker01/
echo ""
echo "*** RUNNING AGENTS TESTS ON DISLIB ***"
log_dir="${COMPSs_log_folder}/${app_name}_0${retry_num}/"
mkdir -p "${log_dir}"
output_log="${log_dir}test.outputlog"
error_log="${log_dir}test.errorlog"
touch "${output_log}"
touch "${error_log}"
port_offset=100
for file in "${base_app_dir}"test_*; do
corresponding_file=$(echo "${file}" | cut -d '/' -f4)
corresponding_file=$(echo "${corresponding_file}" | cut -d '.' -f1)
log_dir="${COMPSs_log_folder}/${app_name}_0${retry_num}/"
mkdir -p "${log_dir}"
output_log="${log_dir}test.outputlog"
error_log="${log_dir}test.errorlog"
touch "${output_log}"
touch "${error_log}"
# Starting agent
agent1_log_dir="${log_dir}/agent1/"
mkdir -p "${agent1_log_dir}"
agent1_output_log="${log_dir}agent1.outputlog"
agent1_error_log="${log_dir}agent1.errorlog"
rest_port=$(( 46000 + port_offset + 1))
comm_port=$(( 46000 + port_offset + 2))
which compss_agent_start
compss_agent_start \
--hostname="COMPSsWorker01" \
--classpath="${base_app_dir}" \
--log_dir="${agent1_log_dir}" \
--rest_port="${rest_port}" \
--comm_port="${comm_port}" \
--pythonpath="${base_app_dir}" \
--python_interpreter="python3"\
1>"${agent1_output_log}" 2>"${agent1_error_log}" &
agent_pid="$!"
AGENT_PIDS="${AGENT_PIDS} ${agent_pid}"
retries="${NUM_RETRIES}"
echo "testing first agent"
curl -XGET http://127.0.0.1:${rest_port}/COMPSs/test 1>/dev/null 2>/dev/null
ev=$?
while [ "$ev" != "0" ] && [ "${retries}" -gt "0" ]; do
echo "testing agent on port ${rest_port}"
sleep 2s
retries=$((retries - 1 ))
curl -XGET http://127.0.0.1:${rest_port}/COMPSs/test 1>/dev/null 2>/dev/null
ev=$?
done
echo "TEST invoked"
RESULT=$(grep "test invoked" "${agent1_output_log}")
if [ -z "${RESULT}" ]; then
echo "Agent failed to start" > >(tee -a "${error_log}")
exit 1
fi
echo "Agent started" > >(tee -a "${output_log}")
sleep 2s
# Invoking DemoFunction method
"${COMPSS_HOME}/Runtime/scripts/user/compss_agent_call_operation" \
--lang="PYTHON" \
--master_node="127.0.0.1" \
--master_port="${rest_port}" \
--method_name="main" \
--stop \
"${corresponding_file}" > >(tee -a "${output_log}") 2> >(tee -a "${error_log}")
ev=$?
if [ "$ev" != "0" ]; then
echo "Could not invoke main method." > >(tee -a "${error_log}")
exit $ev
fi
echo "main function invoked" > >(tee -a "${output_log}")
retries="3"
while [ ! -f "${agent1_log_dir}/jobs/job1_NEW.out" ] && [ "${retries}" -gt "0" ]; do
sleep 2s
retries=$((retries - 1 ))
done
if [ ! -f "${agent1_log_dir}/jobs/job1_NEW.out" ]; then
echo "Could not invoke main method." > >(tee -a "${error_log}")
exit 1
fi
wait ${AGENT_PIDS}
if [ ! -f "${agent1_log_dir}/jobs/job2_NEW.out" ]; then
echo "Could not invoke nested method." > >(tee -a "${error_log}")
exit 1
fi
job1_end=$(grep "Result tests" "${agent1_log_dir}/jobs/job1_NEW.out")
job1_end_value=$(echo "${job1_end}" | cut -d ' ' -f3)
if [ ! "${job1_end_value}" == "Passed" ]; then
echo "Unexpected integer value obtained from the test. Expecting Passed and ${job1_end_value} observed!" > >(tee -a "${error_log}")
exit 1
fi
kill_agents
rm -rf /tmp/COMPSsWorker01/*
AGENT_PIDS=""
# Copy LOG files
# cp -rf "${log_dir}" "${target_log_folder}"
port_offset=$((port_offset + 100 ));
done
exit 0