blob: 4455609edcc732cd674e4e49d2d1efea4f777c5c (
plain)
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
|
#! /bin/bash
##############################################################################
# Copyright (c) 2017 ZTE and others.
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
set -o errexit
set -o pipefail
set -o nounset
set -x
usage(){
echo "usage: $0 -s <stack_json_path> -j <job_json_path>" >&2
}
#Get options
while getopts ":s:j:he" optchar; do
case "${optchar}" in
s) stack_json=${OPTARG} ;;
j) job_json=${OPTARG} ;;
h) usage
exit 0
;;
*) echo "Non-option argument: '-${OPTARG}'" >&2
usage
exit 2
;;
esac
done
# See https://stackoverflow.com/questions/59895/getting-the-source-directory-of-a-bash-script-from-within
script_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
stack_json=${stack_json:-"$script_dir/default_stack.json"}
job_json=${job_json:-"$script_dir/default_job.json"}
WORKSPACE=${WORKSPACE:-$(pwd)}
nova_vm_mapping()
{
openstack server list --name storperf-agent -c ID -c Host --long -f json > $WORKSPACE/nova_vm.json
echo ==========================================================================
echo "Vms vs. Compute nodes"
cat $WORKSPACE/nova_vm.json
echo ==========================================================================
}
storperf_api="http://storperf-master:5000/api/v1.0"
echo "QTIP: Waiting for storperf api ready"
while [ $(curl -s -o /dev/null -I -w "%{http_code}" -X GET ${storperf_api}/configurations) != "200" ]
do
sleep 1
done
echo ==========================================================================
echo "Start to create storperf stack"
cat ${stack_json} 1>&2
echo ==========================================================================
curl -X POST --header 'Content-Type: application/json' \
--header 'Accept: application/json' -d @${stack_json} \
${storperf_api}/configurations
nova_vm_mapping
echo
echo ==========================================================================
echo "Start to run storperf test"
cat ${job_json} 1>&2
echo ==========================================================================
JOB=$(curl -s -X POST --header 'Content-Type: application/json' \
--header 'Accept: application/json' \
-d @${job_json} ${storperf_api}/jobs | \
awk '/job_id/ {print $2}' | sed 's/"//g')
echo "JOB ID: $JOB"
if [[ -z "$JOB" ]]; then
echo "Oops, JOB ID is empty!"
exit 1
else
echo "checking job status..."
curl -s -X GET "${storperf_api}/jobs?id=$JOB&type=status" \
-o $WORKSPACE/status.json
cat $WORKSPACE/status.json
JOB_STATUS=`cat $WORKSPACE/status.json | awk '/Status/ {print $2}' | cut -d\" -f2`
while [ "$JOB_STATUS" != "Completed" ]
do
sleep 180
mv $WORKSPACE/status.json $WORKSPACE/old-status.json
curl -s -X GET "${storperf_api}/jobs?id=$JOB&type=status" \
-o $WORKSPACE/status.json
JOB_STATUS=`cat $WORKSPACE/status.json | awk '/Status/ {print $2}' | cut -d\" -f2`
diff $WORKSPACE/status.json $WORKSPACE/old-status.json >/dev/null
if [ $? -eq 1 ]
then
cat $WORKSPACE/status.json
fi
done
echo
echo "Storperf test completed!"
echo ==========================================================================
echo Final report
echo ==========================================================================
curl -s -X GET "${storperf_api}/jobs?id=$JOB&type=metadata" \
-o $WORKSPACE/report.json
cat $WORKSPACE/report.json
fi
echo "Deleting stack for cleanup"
curl -s -X DELETE --header 'Accept: application/json' ${storperf_api}/configurations
|