Add delays after s3 container create/delete and after s3 object create/delete.

This commit is contained in:
Vladimir Domnich 2022-07-25 16:44:11 +03:00
parent 5ae49c283a
commit f2f7889f6e
2 changed files with 12 additions and 4 deletions

View file

@ -4,6 +4,7 @@ import json
import os
import uuid
from enum import Enum
from time import sleep
import boto3
from botocore.exceptions import ClientError
@ -12,7 +13,7 @@ from robot.api import logger
from robot.api.deco import keyword
from cli_helpers import _run_with_passwd, log_command_execution
from common import S3_GATE_PUB_KEY, NEOFS_ENDPOINT, S3_GATE
from common import ASSETS_DIR, S3_GATE_PUB_KEY, NEOFS_ENDPOINT, S3_GATE
##########################################################
# Disabling warnings on self-signed certificate which the
@ -22,10 +23,12 @@ urllib3.disable_warnings()
ROBOT_AUTO_KEYWORDS = False
CREDENTIALS_CREATE_TIMEOUT = '30s'
NEOFS_EXEC = os.getenv('NEOFS_EXEC', 'neofs-authmate')
ASSETS_DIR = os.getenv('ASSETS_DIR', 'TemporaryDir/')
# Artificial delay that we add after object deletion and container creation
# Delay is added because sometimes immediately after deletion object still appears
# to be existing (probably because tombstone object takes some time to replicate)
S3_SYNC_WAIT_TIME = 5
class VersioningStatus(Enum):
ENABLED = 'Enabled'
@ -92,6 +95,7 @@ def create_bucket_s3(s3_client):
try:
s3_bucket = s3_client.create_bucket(Bucket=bucket_name)
log_command_execution(f'Created S3 bucket {bucket_name}', s3_bucket)
sleep(S3_SYNC_WAIT_TIME)
return bucket_name
except ClientError as err:
@ -121,7 +125,7 @@ def delete_bucket_s3(s3_client, bucket: str):
try:
response = s3_client.delete_bucket(Bucket=bucket)
log_command_execution('S3 Delete bucket result', response)
sleep(S3_SYNC_WAIT_TIME)
return response
except ClientError as err:

View file

@ -3,6 +3,7 @@
import os
import uuid
from enum import Enum
from time import sleep
from typing import Optional
import urllib3
@ -12,6 +13,7 @@ from robot.api.deco import keyword
from cli_helpers import log_command_execution
from python_keywords.aws_cli_client import AwsCliClient
from python_keywords.s3_gate_bucket import S3_SYNC_WAIT_TIME
##########################################################
# Disabling warnings on self-signed certificate which the
@ -119,6 +121,7 @@ def delete_object_s3(s3_client, bucket, object_key, version_id: str = None):
params['VersionId'] = version_id
response = s3_client.delete_object(**params)
log_command_execution('S3 Delete object result', response)
sleep(S3_SYNC_WAIT_TIME)
return response
except ClientError as err:
@ -131,6 +134,7 @@ def delete_objects_s3(s3_client, bucket: str, object_keys: list):
try:
response = s3_client.delete_objects(Bucket=bucket, Delete=_make_objs_dict(object_keys))
log_command_execution('S3 Delete objects result', response)
sleep(S3_SYNC_WAIT_TIME)
return response
except ClientError as err: