2020-07-01 02:28:31 +00:00
|
|
|
*** Settings ***
|
|
|
|
Variables ../../variables/common.py
|
|
|
|
|
|
|
|
Library ${RESOURCES}/environment.py
|
|
|
|
Library ${RESOURCES}/neo.py
|
|
|
|
Library ${RESOURCES}/neofs.py
|
|
|
|
Library ${RESOURCES}/payment.py
|
|
|
|
Library ${RESOURCES}/assertions.py
|
|
|
|
Library ${RESOURCES}/neo.py
|
|
|
|
|
|
|
|
*** Variables ***
|
|
|
|
&{FILE_USR_HEADER} = key1=1 key2='abc'
|
|
|
|
|
|
|
|
|
|
|
|
*** Test cases ***
|
|
|
|
NeoFS Simple Object Operations
|
|
|
|
[Documentation] Testcase to validate NeoFS operations with simple object.
|
|
|
|
[Tags] Object NeoFS NeoCLI
|
|
|
|
[Timeout] 20 min
|
|
|
|
|
|
|
|
${PRIV_KEY} = Generate Neo private key
|
|
|
|
${PUB_KEY} = Get Neo public key ${PRIV_KEY}
|
|
|
|
${ADDR} = Get Neo address ${PRIV_KEY}
|
|
|
|
${TX} = Request NeoFS Deposit ${PUB_KEY}
|
|
|
|
Wait Until Keyword Succeeds 1 min 15 sec
|
|
|
|
... Transaction accepted in block ${TX}
|
|
|
|
Get Transaction ${TX}
|
|
|
|
${BALANCE} = Wait Until Keyword Succeeds 10 min 1 min
|
|
|
|
... Get Balance ${PUB_KEY}
|
|
|
|
Expected Balance ${PUB_KEY} 0 50
|
|
|
|
${CID} = Create container ${PRIV_KEY}
|
|
|
|
Container Existing ${PRIV_KEY} ${CID}
|
2020-07-06 23:11:41 +00:00
|
|
|
# Due to develop branch with zero-payment for container and different blockchains for payment.
|
|
|
|
# Fail will be ignored temporarily.
|
|
|
|
Run Keyword And Ignore Error
|
|
|
|
... Wait Until Keyword Succeeds 2 min 30 sec
|
2020-07-01 02:28:31 +00:00
|
|
|
... Expected Balance ${PUB_KEY} ${BALANCE} -0.00001424
|
|
|
|
${FILE} = Generate file of bytes 1024
|
|
|
|
${FILE_HASH} = Get file hash ${FILE}
|
|
|
|
${S_OID} = Put object to NeoFS ${PRIV_KEY} ${FILE} ${CID}
|
|
|
|
${H_OID} = Put object to NeoFS ${PRIV_KEY} ${FILE} ${CID} &{FILE_USR_HEADER}
|
|
|
|
# Next keyword has been removed due to https://neospcc.atlassian.net/browse/NSPCC-1103
|
|
|
|
# Validate storage policy for object ${PRIV_KEY} 2 ${CID} ${S_OID}
|
|
|
|
${SGID} = Create storage group ${PRIV_KEY} ${CID} ${S_OID} ${H_OID}
|
|
|
|
|
|
|
|
@{S_OBJ_SG} = Create List ${SGID}
|
|
|
|
@{S_OBJ_ALL} = Create List ${S_OID} ${H_OID} ${SGID}
|
|
|
|
@{S_OBJ_H} = Create List ${H_OID}
|
|
|
|
|
|
|
|
Search object ${PRIV_KEY} ${CID} --sg @{S_OBJ_SG}
|
|
|
|
Get storage group ${PRIV_KEY} ${CID} ${SGID}
|
|
|
|
Get object from NeoFS ${PRIV_KEY} ${CID} ${S_OID} s_file_read
|
|
|
|
Get object from NeoFS ${PRIV_KEY} ${CID} ${S_OID} h_file_read
|
|
|
|
Search object ${PRIV_KEY} ${CID} ${EMPTY} @{S_OBJ_ALL}
|
|
|
|
Search object ${PRIV_KEY} ${CID} ${EMPTY} @{S_OBJ_H} &{FILE_USR_HEADER}
|
|
|
|
Head object ${PRIV_KEY} ${CID} ${S_OID} ${True}
|
|
|
|
Head object ${PRIV_KEY} ${CID} ${H_OID} ${True} &{FILE_USR_HEADER}
|
|
|
|
|
|
|
|
Run Keyword And Expect Error REGEXP:User header (\\w+=\\w+\\s?)+ was not found
|
|
|
|
... Head object ${PRIV_KEY} ${CID} ${H_OID} ${False} &{FILE_USR_HEADER}
|
|
|
|
|
|
|
|
Verify file hash s_file_read ${FILE_HASH}
|
|
|
|
Verify file hash h_file_read ${FILE_HASH}
|
|
|
|
&{ID_OBJ_S} = Create Dictionary ID=${S_OID}
|
|
|
|
Delete object ${PRIV_KEY} ${CID} ${S_OID}
|
|
|
|
Verify Head tombstone ${PRIV_KEY} ${CID} ${S_OID}
|
|
|
|
Wait Until Keyword Succeeds 2 min 30 sec
|
|
|
|
... Search object ${PRIV_KEY} ${CID} ${EMPTY} @{EMPTY} &{ID_OBJ_S}
|
|
|
|
|
|
|
|
Run Keyword And Expect Error *
|
|
|
|
... Get object from NeoFS ${PRIV_KEY} ${CID} ${S_OID} s_file_read_2
|
|
|
|
&{ID_OBJ_H} = Create Dictionary ID=${H_OID}
|
|
|
|
Delete object ${PRIV_KEY} ${CID} ${H_OID}
|
|
|
|
Verify Head tombstone ${PRIV_KEY} ${CID} ${H_OID}
|
|
|
|
Search object ${PRIV_KEY} ${CID} ${EMPTY} @{EMPTY} &{FILE_USR_HEADER}
|
|
|
|
Wait Until Keyword Succeeds 2 min 30 sec
|
|
|
|
... Search object ${PRIV_KEY} ${CID} ${EMPTY} @{EMPTY} &{ID_OBJ_H}
|
|
|
|
Run Keyword And Expect Error *
|
|
|
|
... Get object from NeoFS ${PRIV_KEY} ${CID} ${H_OID} s_file_read_2
|
|
|
|
|
|
|
|
|
|
|
|
&{SGID_OBJ} = Create Dictionary ID=${SGID}
|
|
|
|
Delete object ${PRIV_KEY} ${CID} ${SGID}
|
|
|
|
Verify Head tombstone ${PRIV_KEY} ${CID} ${SGID}
|
|
|
|
Search object ${PRIV_KEY} ${CID} --sg @{EMPTY}
|
|
|
|
Wait Until Keyword Succeeds 2 min 30 sec
|
|
|
|
... Search object ${PRIV_KEY} ${CID} ${EMPTY} @{EMPTY} &{SGID_OBJ}
|
|
|
|
Run Keyword And Expect Error *
|
|
|
|
... Get object from NeoFS ${PRIV_KEY} ${CID} ${SGID} s_file_read_2
|
|
|
|
|
|
|
|
Cleanup File ${FILE}
|
|
|
|
Cleanup File s_file_read
|
|
|
|
Cleanup File h_file_read
|
|
|
|
Run Keyword And Expect Error Error: 's_file_read_2' file not found
|
|
|
|
... Cleanup File s_file_read_2
|
|
|
|
|
|
|
|
|
|
|
|
NeoFS Complex Object Operations
|
|
|
|
[Documentation] Testcase to validate NeoFS operations with complex object.
|
|
|
|
[Tags] Object NeoFS NeoCLI
|
|
|
|
[Timeout] 15 min
|
|
|
|
|
|
|
|
${PRIV_KEY} = Generate Neo private key
|
|
|
|
${PUB_KEY} = Get Neo public key ${PRIV_KEY}
|
|
|
|
${ADDR} = Get Neo address ${PRIV_KEY}
|
|
|
|
${TX} = Request NeoFS Deposit ${PUB_KEY}
|
|
|
|
Wait Until Keyword Succeeds 1 min 15 sec
|
|
|
|
... Transaction accepted in block ${TX}
|
|
|
|
Get Transaction ${TX}
|
|
|
|
${BALANCE} = Wait Until Keyword Succeeds 10 min 1 min
|
|
|
|
... Get Balance ${PUB_KEY}
|
|
|
|
Expected Balance ${PUB_KEY} 0 50
|
|
|
|
${CID} = Create container ${PRIV_KEY}
|
|
|
|
Container Existing ${PRIV_KEY} ${CID}
|
2020-07-06 23:11:41 +00:00
|
|
|
# Due to develop branch with zero-payment for container and different blockchains for payment.
|
|
|
|
# Fail will be ignored temporarily.
|
|
|
|
Run Keyword And Ignore Error
|
|
|
|
... Wait Until Keyword Succeeds 2 min 30 sec
|
2020-07-01 02:28:31 +00:00
|
|
|
... Expected Balance ${PUB_KEY} ${BALANCE} -0.00001424
|
|
|
|
|
|
|
|
${SIZE} = Set Variable 20e+6
|
|
|
|
${FILE} = Generate file of bytes ${SIZE}
|
|
|
|
${FILE_HASH} = Get file hash ${FILE}
|
|
|
|
${S_OID} = Put object to NeoFS ${PRIV_KEY} ${FILE} ${CID}
|
|
|
|
${H_OID} = Put object to NeoFS ${PRIV_KEY} ${FILE} ${CID} &{FILE_USR_HEADER}
|
|
|
|
|
|
|
|
@{Link_obj_S} = Verify linked objects ${PRIV_KEY} ${CID} ${S_OID} ${SIZE}
|
|
|
|
@{Link_obj_H} = Verify linked objects ${PRIV_KEY} ${CID} ${H_OID} ${SIZE}
|
|
|
|
|
|
|
|
@{Full_obj_list} = Create List @{Link_obj_S} @{Link_obj_H} ${S_OID} ${H_OID}
|
|
|
|
Search object ${PRIV_KEY} ${CID} ${EMPTY} @{Full_obj_list}
|
|
|
|
|
|
|
|
# Next keyword has been removed due to https://neospcc.atlassian.net/browse/NSPCC-1103
|
|
|
|
# Validate storage policy for object ${PRIV_KEY} 2 ${CID} ${S_OID}
|
|
|
|
${SGID} = Create storage group ${PRIV_KEY} ${CID} ${S_OID} ${H_OID}
|
|
|
|
|
|
|
|
@{S_OBJ_SG} = Create List ${SGID}
|
|
|
|
@{S_OBJ_ALL} = Create List ${S_OID} ${H_OID} ${SGID}
|
|
|
|
@{S_OBJ_H} = Create List ${H_OID}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Search object ${PRIV_KEY} ${CID} --sg @{S_OBJ_SG}
|
|
|
|
Get storage group ${PRIV_KEY} ${CID} ${SGID}
|
|
|
|
Get object from NeoFS ${PRIV_KEY} ${CID} ${S_OID} s_file_read
|
|
|
|
Get object from NeoFS ${PRIV_KEY} ${CID} ${S_OID} h_file_read
|
|
|
|
Search object ${PRIV_KEY} ${CID} --root @{S_OBJ_ALL}
|
|
|
|
# Check sub-objects
|
|
|
|
|
|
|
|
Search object ${PRIV_KEY} ${CID} --root @{S_OBJ_H} &{FILE_USR_HEADER}
|
|
|
|
Head object ${PRIV_KEY} ${CID} ${S_OID} ${True}
|
|
|
|
Head object ${PRIV_KEY} ${CID} ${H_OID} ${True} &{FILE_USR_HEADER}
|
|
|
|
|
|
|
|
Run Keyword And Expect Error REGEXP:User header (\\w+=\\w+\\s?)+ was not found
|
|
|
|
... Head object ${PRIV_KEY} ${CID} ${H_OID} ${False} &{FILE_USR_HEADER}
|
|
|
|
|
|
|
|
Verify file hash s_file_read ${FILE_HASH}
|
|
|
|
Verify file hash h_file_read ${FILE_HASH}
|
|
|
|
&{ID_OBJ_S} = Create Dictionary ID=${S_OID}
|
|
|
|
Delete object ${PRIV_KEY} ${CID} ${S_OID}
|
|
|
|
Verify Head tombstone ${PRIV_KEY} ${CID} ${S_OID}
|
|
|
|
Wait Until Keyword Succeeds 2 min 30 sec
|
|
|
|
... Search object ${PRIV_KEY} ${CID} --root @{EMPTY} &{ID_OBJ_S}
|
|
|
|
|
|
|
|
Run Keyword And Expect Error *
|
|
|
|
... Get object from NeoFS ${PRIV_KEY} ${CID} ${S_OID} s_file_read_2
|
|
|
|
&{ID_OBJ_H} = Create Dictionary ID=${H_OID}
|
|
|
|
Delete object ${PRIV_KEY} ${CID} ${H_OID}
|
|
|
|
Verify Head tombstone ${PRIV_KEY} ${CID} ${H_OID}
|
|
|
|
Search object ${PRIV_KEY} ${CID} --root @{EMPTY} &{FILE_USR_HEADER}
|
|
|
|
Wait Until Keyword Succeeds 2 min 30 sec
|
|
|
|
... Search object ${PRIV_KEY} ${CID} --root @{EMPTY} &{ID_OBJ_H}
|
|
|
|
Run Keyword And Expect Error *
|
|
|
|
... Get object from NeoFS ${PRIV_KEY} ${CID} ${H_OID} s_file_read_2
|
|
|
|
|
|
|
|
|
|
|
|
&{SGID_OBJ} = Create Dictionary ID=${SGID}
|
|
|
|
Delete object ${PRIV_KEY} ${CID} ${SGID}
|
|
|
|
Verify Head tombstone ${PRIV_KEY} ${CID} ${SGID}
|
|
|
|
Search object ${PRIV_KEY} ${CID} --sg @{EMPTY}
|
|
|
|
Wait Until Keyword Succeeds 2 min 30 sec
|
|
|
|
... Search object ${PRIV_KEY} ${CID} ${EMPTY} @{EMPTY} &{SGID_OBJ}
|
|
|
|
Run Keyword And Expect Error *
|
|
|
|
... Get object from NeoFS ${PRIV_KEY} ${CID} ${SGID} s_file_read_2
|
|
|
|
|
|
|
|
Cleanup File ${FILE}
|
|
|
|
Cleanup File s_file_read
|
|
|
|
Cleanup File h_file_read
|
|
|
|
Run Keyword And Expect Error Error: 's_file_read_2' file not found
|
|
|
|
... Cleanup File s_file_read_2
|