forked from TrueCloudLab/frostfs-testcases
346809005f
* New test case and keywords for the storage group have been added * Timeout for object PUT operation has been increased up to 120 seconds * Object operations keywords have been renamed
96 lines
No EOL
5.4 KiB
Text
96 lines
No EOL
5.4 KiB
Text
*** Settings ***
|
|
Variables ../../../variables/common.py
|
|
Library Collections
|
|
Library ../${RESOURCES}/neofs.py
|
|
Library ../${RESOURCES}/payment_neogo.py
|
|
Library ../${RESOURCES}/gates.py
|
|
|
|
|
|
*** Test cases ***
|
|
NeoFS S3 Gateway
|
|
[Documentation] Execute operations via S3 Gate
|
|
[Timeout] 5 min
|
|
|
|
|
|
${PRIV_KEY} = Form WIF from String 1dd37fba80fec4e6a6f13fd708d8dcb3b29def768017052f6c930fa1c5d90bbb
|
|
${WALLET} = Init wallet
|
|
|
|
Generate wallet from WIF ${WALLET} ${PRIV_KEY}
|
|
${ADDR} = Dump Address ${WALLET}
|
|
Dump PrivKey ${WALLET} ${ADDR}
|
|
${SCRIPT_HASH} = Get ScripHash ${PRIV_KEY}
|
|
|
|
${TX_DEPOSIT} = NeoFS Deposit ${WALLET} ${ADDR} ${SCRIPT_HASH} 5
|
|
Wait Until Keyword Succeeds 1 min 15 sec
|
|
... Transaction accepted in block ${TX_DEPOSIT}
|
|
Get Transaction ${TX_DEPOSIT}
|
|
|
|
${FILE_S3} = Generate file of bytes 70e+6
|
|
${FILE_S3_HASH} = Get file hash ${FILE_S3}
|
|
${FILE_S3_NAME} = Get file name ${FILE_S3}
|
|
|
|
${FILE_FS} = Generate file of bytes 70e+6
|
|
${FILE_FS_HASH} = Get file hash ${FILE_FS}
|
|
${FILE_FS_NAME} = Get file name ${FILE_FS}
|
|
|
|
${CID}
|
|
... ${BUCKET}
|
|
... ${ACCESS_KEY_ID}
|
|
... ${SEC_ACCESS_KEY}
|
|
... ${OWNER_PRIV_KEY} = Init S3 Credentials ${PRIV_KEY} keys/s3_docker_hcs.pub.key
|
|
|
|
${CONTEINERS_LIST} = Container List ${PRIV_KEY}
|
|
List Should Contain Value ${CONTEINERS_LIST} ${CID}
|
|
|
|
|
|
${S3_CLIENT} = Config S3 client ${ACCESS_KEY_ID} ${SEC_ACCESS_KEY}
|
|
|
|
${LIST_S3_BUCKETS} = List buckets S3 ${S3_CLIENT}
|
|
List Should Contain Value ${LIST_S3_BUCKETS} ${BUCKET}
|
|
|
|
Put object S3 ${S3_CLIENT} ${BUCKET} ${FILE_S3}
|
|
Head object S3 ${S3_CLIENT} ${BUCKET} ${FILE_S3_NAME}
|
|
|
|
${OID_FS} = Put object ${PRIV_KEY} ${FILE_FS} ${CID} ${EMPTY} ${EMPTY}
|
|
Head object ${PRIV_KEY} ${CID} ${OID_FS} ${EMPTY}
|
|
|
|
${LIST_S3_OBJECTS} = List objects S3 ${S3_CLIENT} ${BUCKET}
|
|
List Should Contain Value ${LIST_S3_OBJECTS} ${FILE_S3_NAME}
|
|
List Should Contain Value ${LIST_S3_OBJECTS} ${FILE_FS_NAME}
|
|
|
|
${LIST_V2_S3_OBJECTS} = List objects S3 v2 ${S3_CLIENT} ${BUCKET}
|
|
List Should Contain Value ${LIST_V2_S3_OBJECTS} ${FILE_S3_NAME}
|
|
List Should Contain Value ${LIST_V2_S3_OBJECTS} ${FILE_S3_NAME}
|
|
|
|
${OID_LIST_S3} = Search object ${PRIV_KEY} ${CID} ${EMPTY} ${EMPTY} FileName=${FILE_S3_NAME}
|
|
${OID_S3} = Get From List ${OID_LIST_S3} 0
|
|
|
|
Get object S3 ${S3_CLIENT} ${BUCKET} ${FILE_S3_NAME} s3_obj_get_s3
|
|
Get object S3 ${S3_CLIENT} ${BUCKET} ${FILE_FS_NAME} fs_obj_get_s3
|
|
|
|
Verify file hash s3_obj_get_s3 ${FILE_S3_HASH}
|
|
Verify file hash fs_obj_get_s3 ${FILE_FS_HASH}
|
|
|
|
Get object ${PRIV_KEY} ${CID} ${OID_S3} ${EMPTY} s3_obj_get_fs
|
|
Get object ${PRIV_KEY} ${CID} ${OID_FS} ${EMPTY} fs_obj_get_fs
|
|
|
|
Verify file hash s3_obj_get_fs ${FILE_S3_HASH}
|
|
Verify file hash fs_obj_get_fs ${FILE_FS_HASH}
|
|
|
|
Copy object S3 ${S3_CLIENT} ${BUCKET} ${FILE_S3_NAME} NewName
|
|
${LIST_S3_OBJECTS} = List objects S3 ${S3_CLIENT} ${BUCKET}
|
|
List Should Contain Value ${LIST_S3_OBJECTS} NewName
|
|
|
|
Delete object S3 ${S3_CLIENT} ${BUCKET} ${FILE_S3_NAME}
|
|
${LIST_S3_OBJECTS} = List objects S3 ${S3_CLIENT} ${BUCKET}
|
|
List Should Not Contain Value ${LIST_S3_OBJECTS} FILE_S3_NAME
|
|
|
|
[Teardown] Cleanup ${FILE_S3} ${FILE_FS}
|
|
|
|
*** Keywords ***
|
|
|
|
Cleanup
|
|
[Arguments] ${FILE_S3} ${FILE_FS}
|
|
Cleanup Files s3_obj_get_fs fs_obj_get_fs s3_obj_get_s3 fs_obj_get_s3
|
|
... ${FILE_S3} ${FILE_FS}
|
|
Get Docker Logs s3_gate |