forked from TrueCloudLab/frostfs-testcases
91 lines
5.2 KiB
Text
91 lines
5.2 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} 50
|
||
|
Wait Until Keyword Succeeds 1 min 15 sec
|
||
|
... Transaction accepted in block ${TX_DEPOSIT}
|
||
|
Get Transaction ${TX_DEPOSIT}
|
||
|
|
||
|
${FILE_S3} = Generate file of bytes 256
|
||
|
${FILE_S3_HASH} = Get file hash ${FILE_S3}
|
||
|
${FILE_S3_NAME} = Get file name ${FILE_S3}
|
||
|
|
||
|
${FILE_FS} = Generate file of bytes 256
|
||
|
${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 to NeoFS ${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 from NeoFS ${PRIV_KEY} ${CID} ${OID_S3} ${EMPTY} s3_obj_get_fs
|
||
|
Get object from NeoFS ${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 Files s3_obj_get_fs fs_obj_get_fs s3_obj_get_s3 fs_obj_get_s3
|
||
|
... ${FILE_S3} ${FILE_FS} hcs.pub.key
|
||
|
|