Skip to content

Commit

Permalink
format code
Browse files Browse the repository at this point in the history
Signed-off-by: zhuwenxing <[email protected]>
  • Loading branch information
zhuwenxing committed Dec 11, 2024
1 parent f5a21ff commit 86b4ea5
Show file tree
Hide file tree
Showing 34 changed files with 3,620 additions and 1,476 deletions.
118 changes: 77 additions & 41 deletions tests/api/milvus_backup.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,91 +7,119 @@
from requests.exceptions import ConnectionError


def logger_request_response(response, url, tt, headers, data, str_data, str_response, method):
def logger_request_response(
response, url, tt, headers, data, str_data, str_response, method
):
if len(data) > 2000:
data = data[:1000] + "..." + data[-1000:]
try:
if response.status_code == 200:
if ('code' in response.json() and response.json()["code"] == 200) or (
'Code' in response.json() and response.json()["Code"] == 0):
if ("code" in response.json() and response.json()["code"] == 200) or (
"Code" in response.json() and response.json()["Code"] == 0
):
log.debug(
f"\nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {str_data}, \nresponse: {str_response}")
f"\nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {str_data}, \nresponse: {str_response}"
)
else:
log.debug(
f"\nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {data}, \nresponse: {response.text}")
f"\nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {data}, \nresponse: {response.text}"
)
else:
log.debug(
f"method: \nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {data}, \nresponse: {response.text}")
f"method: \nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {data}, \nresponse: {response.text}"
)
except Exception as e:
log.debug(
f"method: \nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {data}, \nresponse: {response.text}, \nerror: {e}")
f"method: \nmethod: {method}, \nurl: {url}, \ncost time: {tt}, \nheader: {headers}, \npayload: {data}, \nresponse: {response.text}, \nerror: {e}"
)


class Requests:
def __init__(self, url=None):
self.url = url
self.headers = {
'Content-Type': 'application/json',
'RequestId': str(uuid.uuid1())
"Content-Type": "application/json",
"RequestId": str(uuid.uuid1()),
}

def update_headers(self):
headers = {
'Content-Type': 'application/json',
'RequestId': str(uuid.uuid1())
}
headers = {"Content-Type": "application/json", "RequestId": str(uuid.uuid1())}
return headers

# retry when request failed caused by network or server error
@retry(retry=retry_if_exception_type(ConnectionError), stop=stop_after_attempt(3))
def post(self, url, headers=None, data=None, params=None):
headers = headers if headers is not None else self.update_headers()
data = json.dumps(data)
str_data = data[:200] + '...' + data[-200:] if len(data) > 400 else data
str_data = data[:200] + "..." + data[-200:] if len(data) > 400 else data
t0 = time.time()
response = requests.post(url, headers=headers, data=data, params=params)
tt = time.time() - t0
str_response = response.text[:200] + '...' + response.text[-200:] if len(response.text) > 400 else response.text
logger_request_response(response, url, tt, headers, data, str_data, str_response, "post")
str_response = (
response.text[:200] + "..." + response.text[-200:]
if len(response.text) > 400
else response.text
)
logger_request_response(
response, url, tt, headers, data, str_data, str_response, "post"
)
return response

@retry(retry=retry_if_exception_type(ConnectionError), stop=stop_after_attempt(3))
def get(self, url, headers=None, params=None, data=None):
headers = headers if headers is not None else self.update_headers()
data = json.dumps(data)
str_data = data[:200] + '...' + data[-200:] if len(data) > 400 else data
str_data = data[:200] + "..." + data[-200:] if len(data) > 400 else data
t0 = time.time()
if data is None or data == "null":
response = requests.get(url, headers=headers, params=params)
else:
response = requests.get(url, headers=headers, params=params, data=data)
tt = time.time() - t0
str_response = response.text[:200] + '...' + response.text[-200:] if len(response.text) > 400 else response.text
logger_request_response(response, url, tt, headers, data, str_data, str_response, "get")
str_response = (
response.text[:200] + "..." + response.text[-200:]
if len(response.text) > 400
else response.text
)
logger_request_response(
response, url, tt, headers, data, str_data, str_response, "get"
)
return response

@retry(retry=retry_if_exception_type(ConnectionError), stop=stop_after_attempt(3))
def put(self, url, headers=None, data=None):
headers = headers if headers is not None else self.update_headers()
data = json.dumps(data)
str_data = data[:200] + '...' + data[-200:] if len(data) > 400 else data
str_data = data[:200] + "..." + data[-200:] if len(data) > 400 else data
t0 = time.time()
response = requests.put(url, headers=headers, data=data)
tt = time.time() - t0
str_response = response.text[:200] + '...' + response.text[-200:] if len(response.text) > 400 else response.text
logger_request_response(response, url, tt, headers, data, str_data, str_response, "put")
str_response = (
response.text[:200] + "..." + response.text[-200:]
if len(response.text) > 400
else response.text
)
logger_request_response(
response, url, tt, headers, data, str_data, str_response, "put"
)
return response

@retry(retry=retry_if_exception_type(ConnectionError), stop=stop_after_attempt(3))
def delete(self, url, headers=None, data=None, params=None):
headers = headers if headers is not None else self.update_headers()
data = json.dumps(data)
str_data = data[:200] + '...' + data[-200:] if len(data) > 400 else data
str_data = data[:200] + "..." + data[-200:] if len(data) > 400 else data
t0 = time.time()
response = requests.delete(url, headers=headers, data=data, params=params)
tt = time.time() - t0
str_response = response.text[:200] + '...' + response.text[-200:] if len(response.text) > 400 else response.text
logger_request_response(response, url, tt, headers, data, str_data, str_response, "delete")
str_response = (
response.text[:200] + "..." + response.text[-200:]
if len(response.text) > 400
else response.text
)
logger_request_response(
response, url, tt, headers, data, str_data, str_response, "delete"
)
return response


Expand All @@ -100,46 +128,51 @@ def __init__(self, endpoint):
super().__init__(url=endpoint)
self.endpoint = endpoint
self.headers = self.update_headers()
self.backup_list = []

def update_headers(self):
headers = {
'Content-Type': 'application/json',
'RequestId': str(uuid.uuid1())
}
headers = {"Content-Type": "application/json", "RequestId": str(uuid.uuid1())}
return headers

def hello(self):
url = f'{self.endpoint}/hello'
url = f"{self.endpoint}/hello"
response = self.get(url, headers=self.update_headers())
return response.json()

def create_backup(self, payload):
url = f'{self.endpoint}/create'
url = f"{self.endpoint}/create"
response = self.post(url, headers=self.update_headers(), data=payload)
name = payload.get("backup_name", None)
if name is not None:
self.backup_list.append(name)
return response.json()

def list_backup(self):
url = f'{self.endpoint}/list'
url = f"{self.endpoint}/list"
response = self.get(url, headers=self.update_headers())
return response.json()

def get_backup(self, backup_name):
url = f'{self.endpoint}/get_backup'
response = self.get(url, headers=self.update_headers(), params={"backup_name": backup_name})
url = f"{self.endpoint}/get_backup"
response = self.get(
url, headers=self.update_headers(), params={"backup_name": backup_name}
)
return response.json()

def delete_backup(self, backup_name):
url = f'{self.endpoint}/delete'
response = self.delete(url, headers=self.update_headers(), params={"backup_name": backup_name})
url = f"{self.endpoint}/delete"
response = self.delete(
url, headers=self.update_headers(), params={"backup_name": backup_name}
)
return response.json()

def restore_backup(self, payload):
url = f'{self.endpoint}/restore'
url = f"{self.endpoint}/restore"
response = self.post(url, headers=self.update_headers(), data=payload)
return response.json()

def get_restore(self, id):
url = f'{self.endpoint}/get_restore'
url = f"{self.endpoint}/get_restore"
response = self.get(url, headers=self.update_headers(), params={"id": id})
return response.json()

Expand All @@ -156,10 +189,14 @@ def wait_create_backup_complete(self, backup_name, timeout=120):
res = self.get_backup(backup_name)
end_time = time.time()
elif state_code == 2:
log.info(f"backup {backup_name} is ready in {end_time - start_time} seconds")
log.info(
f"backup {backup_name} is ready in {end_time - start_time} seconds"
)
return True
else:
log.error(f"get backup {backup_name} failed in unknown state {state_code}")
log.error(
f"get backup {backup_name} failed in unknown state {state_code}"
)
return False
end_time = time.time()
log.info(f"backup {backup_name} is timeout in {end_time - start_time} seconds")
Expand Down Expand Up @@ -199,4 +236,3 @@ def wait_restore_complete(self, id, timeout=120):
print("restore backup")
res = client.restore_backup({"backup_name": "test_api"})
print(res)

Loading

0 comments on commit 86b4ea5

Please sign in to comment.