blob: febb3cc0d51decaf683f1f58ce8a042e1084cf01 [file] [log] [blame]
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +02001# ============LICENSE_START===============================================
2# Copyright (C) 2020 Nordix Foundation. All rights reserved.
3# ========================================================================
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15# ============LICENSE_END=================================================
16#
17
18# This script delete policies spread over a number rics
19# Intended for parallel processing
20# Returns a string with result, either "0" for ok, or "1<fault description>"
21
22import os
23import json
24import sys
25import requests
BjornMagnussonXA048aaa12020-06-04 07:48:37 +020026import traceback
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020027
28# disable warning about unverified https requests
29from requests.packages import urllib3
30
31urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
32
BjornMagnussonXAad047782020-06-08 15:54:11 +020033#arg responsecode baseurl num_rics uuid startid count pids pid_id
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020034
35try:
BjornMagnussonXAad047782020-06-08 15:54:11 +020036 if len(sys.argv) != 9:
37 print("1Expected 8 args, got "+str(len(sys.argv)-1)+ ". Args: responsecode baseurl num_rics uuid startid count pids pid_id")
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020038 sys.exit()
39
40 responsecode=int(sys.argv[1])
BjornMagnussonXA4207b832020-11-03 09:52:49 +010041 baseurl=str(sys.argv[2])
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020042 num_rics=int(sys.argv[3])
BjornMagnussonXA4207b832020-11-03 09:52:49 +010043 uuid=str(sys.argv[4])
BjornMagnussonXAad047782020-06-08 15:54:11 +020044 start=int(sys.argv[5])
45 count=int(sys.argv[6])
46 pids=int(sys.argv[7])
47 pid_id=int(sys.argv[8])
48
49 if uuid == "NOUUID":
50 uuid=""
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020051
BjornMagnussonXA49f0e5a2020-11-08 22:41:39 +010052 total_retry_count=0
53
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020054 stop=count*num_rics+start
55 for i in range(start,stop):
56 if (i%pids == (pid_id-1)):
BjornMagnussonXA49f0e5a2020-11-08 22:41:39 +010057 retry_cnt=5
58 while(retry_cnt>0):
59 if ("/v2/policies/" in baseurl):
60 url=str(baseurl+uuid+str(i))
61 else:
62 url=str(baseurl+"?id="+uuid+str(i))
63 try:
64 resp=requests.delete(url, verify=False, timeout=90)
65 except Exception as e1:
66 print("1Delete failed for id:"+uuid+str(i)+ ", "+str(e1) + " "+traceback.format_exc())
67 sys.exit()
68 if (resp.status_code == None):
69 print("1Delete failed for id:"+uuid+str(i)+ ", expected response code: "+str(responsecode)+", got: None")
70 sys.exit()
71 if (resp.status_code != responsecode):
72 if (resp.status_code == 503 ) and (retry_cnt > 1):
73 sleep(0.1)
74 retry_cnt -= 1
75 total_retry_count += 1
76 else:
77 print("1Delete failed for id:"+uuid+str(i)+ ", expected response code: "+str(responsecode)+", got: "+str(resp.status_code))
78 sys.exit()
79 else:
80 retry_cnt=-1
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020081
BjornMagnussonXA49f0e5a2020-11-08 22:41:39 +010082 if (total_retry_count > 0):
83 print("0 retries:"+str(total_retry_count))
84 else:
85 print("0")
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020086 sys.exit()
87
88except Exception as e:
89 print("1"+str(e))
BjornMagnussonXA4207b832020-11-03 09:52:49 +010090 traceback.print_exc()
BjornMagnussonXAbbd2e9d2020-05-27 21:24:06 +020091sys.exit()