Merge "Adapted function test for E release"
[nonrtric.git] / test / common / delete_policies_process.py
1 #  ============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
22 import os
23 import json
24 import sys
25 import requests
26 import traceback
27
28 # disable warning about unverified https requests
29 from requests.packages import urllib3
30
31 urllib3.disable_warnings(urllib3.exceptions.InsecureRequestWarning)
32
33 #arg responsecode baseurl num_rics uuid startid count pids pid_id proxy
34
35 try:
36     if len(sys.argv) != 10:
37         print("1Expected 9 args, got "+str(len(sys.argv)-1)+ ". Args: responsecode baseurl num_rics uuid startid count pids pid_id proxy")
38         sys.exit()
39
40     responsecode=int(sys.argv[1])
41     baseurl=str(sys.argv[2])
42     num_rics=int(sys.argv[3])
43     uuid=str(sys.argv[4])
44     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     httpproxy=str(sys.argv[9])
49
50     proxydict=None
51     if httpproxy != "NOPROXY":
52         proxydict = {
53             "http" : httpproxy,
54             "https" : httpproxy
55         }
56     if uuid == "NOUUID":
57         uuid=""
58
59     http_retry_count=0
60     connect_retry_count=0
61
62     stop=count*num_rics+start
63     for i in range(start,stop):
64         if (i%pids == (pid_id-1)):
65             connect_ok=False
66             retry_cnt=5
67             while(retry_cnt>0):
68                 if ("/v2/policies/" in baseurl):
69                     url=str(baseurl+uuid+str(i))
70                 else:
71                     url=str(baseurl+"?id="+uuid+str(i))
72                 try:
73                     if proxydict is None:
74                         resp=requests.delete(url, verify=False, timeout=90)
75                     else:
76                         resp=requests.delete(url, verify=False, timeout=90, proxies=proxydict)
77                     cconnect_ok=True
78                 except Exception as e1:
79                     if (retry_cnt > 1):
80                         sleep(0.1)
81                         retry_cnt -= 1
82                         connect_retry_count += 1
83                     else:
84                         print("1Delete failed for id:"+uuid+str(i)+ ", "+str(e1) + " "+traceback.format_exc())
85                         sys.exit()
86
87                 if (cconnect_ok == True):
88                     if (resp.status_code == None):
89                         print("1Delete failed for id:"+uuid+str(i)+ ", expected response code: "+str(responsecode)+", got: None")
90                         sys.exit()
91                     if (resp.status_code != responsecode):
92                         if (resp.status_code >= 500) and (http_retry_count < 600 ) and (retry_cnt > 1):
93                             sleep(0.1)
94                             retry_cnt -= 1
95                             http_retry_count += 1
96                         else:
97                             print("1Delete failed for id:"+uuid+str(i)+ ", expected response code: "+str(responsecode)+", got: "+str(resp.status_code)+str(resp.raw))
98                             sys.exit()
99                     else:
100                         retry_cnt=-1
101
102     print("0 http retries:"+str(http_retry_count) + ", connect retries: "+str(connect_retry_count))
103     sys.exit()
104
105 except Exception as e:
106     print("1"+str(e))
107     traceback.print_exc()
108 sys.exit()