2021-09-23 17:22:16 +00:00
|
|
|
import time
|
2015-06-05 23:36:43 +00:00
|
|
|
|
2023-11-30 15:55:51 +00:00
|
|
|
import boto3
|
|
|
|
|
2022-01-18 15:18:57 +00:00
|
|
|
from moto import mock_glacier
|
2022-08-13 09:49:43 +00:00
|
|
|
from moto.core import DEFAULT_ACCOUNT_ID as ACCOUNT_ID
|
2015-06-05 23:36:43 +00:00
|
|
|
|
|
|
|
|
2021-09-23 17:22:16 +00:00
|
|
|
@mock_glacier
|
|
|
|
def test_initiate_job():
|
|
|
|
client = boto3.client("glacier", region_name="us-west-2")
|
|
|
|
client.create_vault(vaultName="myname")
|
|
|
|
|
|
|
|
archive = client.upload_archive(vaultName="myname", body=b"body of archive")
|
|
|
|
|
|
|
|
job = client.initiate_job(
|
|
|
|
vaultName="myname",
|
|
|
|
jobParameters={"ArchiveId": archive["archiveId"], "Type": "archive-retrieval"},
|
|
|
|
)
|
2023-07-27 22:47:15 +00:00
|
|
|
assert job["ResponseMetadata"]["HTTPStatusCode"] == 202
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
headers = job["ResponseMetadata"]["HTTPHeaders"]
|
2023-07-27 22:47:15 +00:00
|
|
|
assert "x-amz-job-id" in headers
|
2021-09-23 17:22:16 +00:00
|
|
|
# Should be an exact match, but Flask adds 'http' to the start of the Location-header
|
2023-07-27 22:47:15 +00:00
|
|
|
assert headers["location"] == "//vaults/myname/jobs/" + headers["x-amz-job-id"]
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
# Don't think this is correct - the spec says no body is returned, only headers
|
|
|
|
# https://docs.aws.amazon.com/amazonglacier/latest/dev/api-initiate-job-post.html
|
2023-07-27 22:47:15 +00:00
|
|
|
assert "jobId" in job
|
|
|
|
assert "location" in job
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_glacier
|
|
|
|
def test_describe_job_boto3():
|
|
|
|
client = boto3.client("glacier", region_name="us-west-2")
|
|
|
|
client.create_vault(vaultName="myname")
|
|
|
|
|
|
|
|
archive = client.upload_archive(vaultName="myname", body=b"body of archive")
|
|
|
|
|
|
|
|
job = client.initiate_job(
|
|
|
|
vaultName="myname",
|
|
|
|
jobParameters={"ArchiveId": archive["archiveId"], "Type": "archive-retrieval"},
|
|
|
|
)
|
|
|
|
job_id = job["jobId"]
|
|
|
|
|
|
|
|
describe = client.describe_job(vaultName="myname", jobId=job_id)
|
2023-07-27 22:47:15 +00:00
|
|
|
assert describe["JobId"] == job_id
|
|
|
|
assert describe["Action"] == "ArchiveRetrieval"
|
|
|
|
assert describe["ArchiveId"] == archive["archiveId"]
|
|
|
|
assert (
|
|
|
|
describe["VaultARN"] == f"arn:aws:glacier:us-west-2:{ACCOUNT_ID}:vaults/myname"
|
2018-03-22 05:13:09 +00:00
|
|
|
)
|
2023-07-27 22:47:15 +00:00
|
|
|
assert "CreationDate" in describe
|
|
|
|
assert describe["Completed"] is False
|
|
|
|
assert describe["StatusCode"] == "InProgress"
|
|
|
|
assert describe["ArchiveSizeInBytes"] == 0
|
|
|
|
assert describe["InventorySizeInBytes"] == 0
|
|
|
|
assert describe["Tier"] == "Standard"
|
2015-06-05 23:36:43 +00:00
|
|
|
|
|
|
|
|
2021-09-23 17:22:16 +00:00
|
|
|
@mock_glacier
|
|
|
|
def test_list_jobs():
|
|
|
|
client = boto3.client("glacier", region_name="us-west-2")
|
|
|
|
client.create_vault(vaultName="myname")
|
|
|
|
|
|
|
|
archive1 = client.upload_archive(vaultName="myname", body=b"first archive")
|
|
|
|
archive2 = client.upload_archive(vaultName="myname", body=b"second archive")
|
|
|
|
|
|
|
|
job1 = client.initiate_job(
|
|
|
|
vaultName="myname",
|
|
|
|
jobParameters={"ArchiveId": archive1["archiveId"], "Type": "archive-retrieval"},
|
|
|
|
)
|
|
|
|
|
|
|
|
job2 = client.initiate_job(
|
|
|
|
vaultName="myname",
|
|
|
|
jobParameters={"ArchiveId": archive2["archiveId"], "Type": "archive-retrieval"},
|
|
|
|
)
|
|
|
|
jobs = client.list_jobs(vaultName="myname")["JobList"]
|
|
|
|
|
|
|
|
# Verify the created jobs are in this list
|
|
|
|
found_jobs = [j["JobId"] for j in jobs]
|
2023-07-27 22:47:15 +00:00
|
|
|
assert job1["jobId"] in found_jobs
|
|
|
|
assert job2["jobId"] in found_jobs
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
found_job1 = [j for j in jobs if j["JobId"] == job1["jobId"]][0]
|
2023-07-27 22:47:15 +00:00
|
|
|
assert found_job1["ArchiveId"] == archive1["archiveId"]
|
2021-09-23 17:22:16 +00:00
|
|
|
found_job2 = [j for j in jobs if j["JobId"] == job2["jobId"]][0]
|
2023-07-27 22:47:15 +00:00
|
|
|
assert found_job2["ArchiveId"] == archive2["archiveId"]
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
# Verify all jobs follow the correct format
|
|
|
|
for job in jobs:
|
2023-07-27 22:47:15 +00:00
|
|
|
assert "JobId" in job
|
|
|
|
assert "Action" in job
|
|
|
|
assert "ArchiveId" in job
|
|
|
|
assert "VaultARN" in job
|
|
|
|
assert "CreationDate" in job
|
|
|
|
assert "ArchiveSizeInBytes" in job
|
|
|
|
assert "Completed" in job
|
|
|
|
assert "StatusCode" in job
|
|
|
|
assert "InventorySizeInBytes" in job
|
|
|
|
assert "Tier" in job
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_glacier
|
|
|
|
def test_get_job_output_boto3():
|
|
|
|
client = boto3.client("glacier", region_name="us-west-2")
|
|
|
|
client.create_vault(vaultName="myname")
|
|
|
|
|
|
|
|
archive = client.upload_archive(vaultName="myname", body=b"contents of archive")
|
|
|
|
|
|
|
|
job = client.initiate_job(
|
|
|
|
vaultName="myname",
|
|
|
|
jobParameters={"ArchiveId": archive["archiveId"], "Type": "archive-retrieval"},
|
|
|
|
)
|
|
|
|
|
|
|
|
output = None
|
|
|
|
start = time.time()
|
|
|
|
while (time.time() - start) < 10:
|
|
|
|
try:
|
|
|
|
output = client.get_job_output(vaultName="myname", jobId=job["jobId"])
|
|
|
|
break
|
|
|
|
except Exception:
|
|
|
|
time.sleep(1)
|
|
|
|
|
2023-07-27 22:47:15 +00:00
|
|
|
assert output["status"] == 200
|
|
|
|
assert output["contentType"] == "application/octet-stream"
|
|
|
|
assert "body" in output
|
2021-09-23 17:22:16 +00:00
|
|
|
|
|
|
|
body = output["body"].read().decode("utf-8")
|
2023-07-27 22:47:15 +00:00
|
|
|
assert body == "contents of archive"
|