-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathreloadAndTest.sh
executable file
·50 lines (35 loc) · 1.62 KB
/
reloadAndTest.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
#!/bin/bash
timestamp=$(date -u '+%Y%m%dT%H%M%SZ')
outdirRoot=/tmp/cleval_${timestamp}
export CL_MONITOR="true"
echo "[${timestamp}] Output dir is ${outdirRoot}"
logdir=${outdirRoot}/logs
mkdir -p ${logdir}
sampledir=${outdirRoot}/samples
mkdir -p ${sampledir}
formattedSampleDir=${sampledir}_formatted
mkdir -p ${formattedSampleDir}
plotDir=${sampledir}_plotted
mkdir -p ${plotDir}
# Reload the cluster
./reload.sh >${logdir}/${timestamp}_reload_log.txt 2>&1
signalfile=${logdir}/tests.complete
# Initiate the scenarios as a background process.
./runTestScenarios.sh ${signalfile} >${logdir}/${timestamp}_testsuite_log.txt 2>&1 &
# Start sampling the metrics
pollingScript="pollRawResourceMetrics.sh"
path=$(realpath ${pollingScript})
now=$(date -u '+%Y%m%dT%H%M%SZ')
echo "[$now] Run 'sudo fuser ${path} -k' to stop metrics gathering at any point, or if signal file ${signalfile} does not get generated."
./${pollingScript} ${sampledir} 5 ${signalfile} >${logdir}/${timestamp}_testsuite_raw_metrics_capture.txt 2>&1
# Note: polling needs manual termination once the scenarios are complete.
datafile=${formattedSampleDir}/${timestamp}_samples_formatted.csv
now=$(date -u '+%Y%m%dT%H%M%SZ')
echo "[$now] Formatting gathered samples into a single datafile: ${datafile}"
./convertRawMetricsToCSV.sh ${sampledir} ${datafile}
now=$(date -u '+%Y%m%dT%H%M%SZ')
echo "[$now] Visualizing the formatted samples."
python3 metricsVisualizer.py -i ${datafile} -c CPU_in_nanocores -p ${timestamp} -o ${plotDir}
python3 metricsVisualizer.py -i ${datafile} -c Memory_in_Kibibytes -p ${timestamp} -o ${plotDir}
now=$(date -u '+%Y%m%dT%H%M%SZ')
echo "[$now] Done."