summaryrefslogtreecommitdiffstats
path: root/s3p/list_failed_policy.sh
blob: 042dcf346b473f1a1781e8c33feca3cd7b0a5798 (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
#!/bin/bash

function print_usage_and_exit {
  echo "Usage: $0  <type> <log file name or rule name>"
  echo "    - <type>: s for stability log , p for perf log , or other for simple policy name"
  echo "    - <log file name or rule>"
  exit 1
}

[ "$#" -ne 2 ] && print_usage_and_exit
case $1 in
[sS])
  type='s'
  ;;
[pP])
  type='p'
  ;;
*)
  type='simple'
  ;;
esac

rules=()
if [ -f $2 ] && [ $type == 's' ]; then
    resids=(`grep -o "get policy failed for resource [0-9]\+" $2 | cut -d ' ' -f 6`)
    for i in ${resids[@]}; do
        rules+=("oofCasablanca.Config_OOF_Optimization_s3p_$i.*")
    done
elif [ -f $2 ] && [ $type == 'p' ]; then
    idx=`grep -o "Fail at idx [0-9]\+" $2 | cut -d ' ' -f 4`
    total=`cat perf_data.csv | wc -l`
    while [ "s$idx" > "s" ] && [ $idx -lt $total ]; do
        rules+=("oofCasablanca.Config_OOF_Optimization_s3p_$idx.*")
        idx=$((idx+1))
    done
else
  rules+=($2)
fi

for NAME in ${rules[@]}; do
    BODY="{\"policyName\":\"${NAME}\"}"
    rescode=`curl --silent --write-out %{http_code} -k -H 'Content-Type: application/json' -H 'Accept: application/json' -H 'ClientAuth: cHl0aG9uOnRlc3Q=' -H 'Authorization: Basic dGVzdHBkcDphbHBoYTEyMw==' -H 'Environment: TEST' -X POST -d $BODY --output /dev/null https://pdp:8081/pdp/api/listConfig`
    if [ "$rescode" == '200' ]; then
        echo "list policy $NAME in PDP success"
    else
        echo "list policy $NAME in PDP FAIL with rescode $rescode"
    fi
done