2022-05-10 22:32:49 +00:00
|
|
|
import json
|
|
|
|
|
2023-08-13 20:42:50 +00:00
|
|
|
import boto3
|
|
|
|
import pytest
|
2023-11-30 15:55:51 +00:00
|
|
|
from botocore.exceptions import ClientError
|
2023-08-13 20:42:50 +00:00
|
|
|
|
2023-11-30 15:55:51 +00:00
|
|
|
from moto import mock_secretsmanager, mock_ssm
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
# https://docs.aws.amazon.com/systems-manager/latest/userguide/integration-ps-secretsmanager.html
|
|
|
|
|
|
|
|
|
|
|
|
@mock_secretsmanager
|
|
|
|
@mock_ssm
|
|
|
|
def test_get_value_from_secrets_manager__by_name():
|
|
|
|
# given
|
|
|
|
ssm = boto3.client("ssm", "eu-north-1")
|
|
|
|
secrets_manager = boto3.client("secretsmanager", "eu-north-1")
|
|
|
|
secret_name = "mysecret"
|
|
|
|
# when
|
|
|
|
secrets_manager.create_secret(Name=secret_name, SecretString="some secret")
|
|
|
|
# then
|
|
|
|
param = ssm.get_parameter(
|
|
|
|
Name=f"/aws/reference/secretsmanager/{secret_name}", WithDecryption=True
|
|
|
|
)["Parameter"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert param["Name"] == "mysecret"
|
|
|
|
assert param["Type"] == "SecureString"
|
|
|
|
assert param["Value"] == "some secret"
|
|
|
|
assert param["Version"] == 0
|
|
|
|
assert "SourceResult" in param
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
secret = secrets_manager.describe_secret(SecretId=secret_name)
|
|
|
|
source_result = json.loads(param["SourceResult"])
|
|
|
|
|
2023-08-13 20:42:50 +00:00
|
|
|
assert source_result["ARN"] == secret["ARN"]
|
|
|
|
assert source_result["Name"] == secret["Name"]
|
|
|
|
assert source_result["VersionIdsToStages"] == secret["VersionIdsToStages"]
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_secretsmanager
|
|
|
|
@mock_ssm
|
|
|
|
def test_get_value_from_secrets_manager__without_decryption():
|
|
|
|
# Note that the parameter does not need to exist
|
|
|
|
ssm = boto3.client("ssm", "eu-north-1")
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
ssm.get_parameter(Name="/aws/reference/secretsmanager/sth")
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert err["Code"] == "ValidationException"
|
|
|
|
assert err["Message"] == (
|
2022-05-10 22:32:49 +00:00
|
|
|
"WithDecryption flag must be True for retrieving a Secret Manager secret."
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_secretsmanager
|
|
|
|
@mock_ssm
|
|
|
|
def test_get_value_from_secrets_manager__with_decryption_false():
|
|
|
|
# Note that the parameter does not need to exist
|
|
|
|
ssm = boto3.client("ssm", "eu-north-1")
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
ssm.get_parameter(
|
|
|
|
Name="/aws/reference/secretsmanager/sth", WithDecryption=False
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert err["Code"] == "ValidationException"
|
|
|
|
assert err["Message"] == (
|
2022-05-10 22:32:49 +00:00
|
|
|
"WithDecryption flag must be True for retrieving a Secret Manager secret."
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_secretsmanager
|
|
|
|
@mock_ssm
|
|
|
|
def test_get_value_from_secrets_manager__by_id():
|
|
|
|
# given
|
|
|
|
ssm = boto3.client("ssm", "eu-north-1")
|
|
|
|
secrets_manager = boto3.client("secretsmanager", "eu-north-1")
|
|
|
|
name = "mysecret"
|
|
|
|
# when
|
|
|
|
r1 = secrets_manager.create_secret(Name=name, SecretString="1st")
|
|
|
|
version_id1 = r1["VersionId"]
|
|
|
|
secrets_manager.put_secret_value(
|
|
|
|
SecretId=name, SecretString="2nd", VersionStages=["AWSCURRENT"]
|
|
|
|
)
|
|
|
|
r3 = secrets_manager.put_secret_value(
|
|
|
|
SecretId=name, SecretString="3rd", VersionStages=["ST1"]
|
|
|
|
)
|
|
|
|
version_id3 = r3["VersionId"]
|
|
|
|
# then
|
|
|
|
full_name = f"/aws/reference/secretsmanager/{name}:{version_id1}"
|
|
|
|
param = ssm.get_parameter(Name=full_name, WithDecryption=True)["Parameter"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert param["Value"] == "1st"
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
full_name = f"/aws/reference/secretsmanager/{name}"
|
|
|
|
param = ssm.get_parameter(Name=full_name, WithDecryption=True)["Parameter"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert param["Value"] == "2nd"
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
full_name = f"/aws/reference/secretsmanager/{name}:{version_id3}"
|
|
|
|
param = ssm.get_parameter(Name=full_name, WithDecryption=True)["Parameter"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert param["Value"] == "3rd"
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_secretsmanager
|
|
|
|
@mock_ssm
|
|
|
|
def test_get_value_from_secrets_manager__by_version():
|
|
|
|
# given
|
|
|
|
ssm = boto3.client("ssm", "eu-north-1")
|
|
|
|
secrets_manager = boto3.client("secretsmanager", "eu-north-1")
|
|
|
|
name = "mysecret"
|
|
|
|
# when
|
|
|
|
secrets_manager.create_secret(Name=name, SecretString="1st")
|
|
|
|
secrets_manager.put_secret_value(
|
|
|
|
SecretId=name, SecretString="2nd", VersionStages=["AWSCURRENT"]
|
|
|
|
)
|
|
|
|
# then
|
|
|
|
full_name = f"/aws/reference/secretsmanager/{name}:AWSPREVIOUS"
|
|
|
|
param = ssm.get_parameter(Name=full_name, WithDecryption=True)["Parameter"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert param["Value"] == "1st"
|
2022-05-10 22:32:49 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_secretsmanager
|
|
|
|
@mock_ssm
|
|
|
|
def test_get_value_from_secrets_manager__param_does_not_exist():
|
|
|
|
ssm = boto3.client("ssm", "us-east-1")
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
ssm.get_parameter(
|
|
|
|
Name="/aws/reference/secretsmanager/test", WithDecryption=True
|
|
|
|
)
|
|
|
|
err = exc.value.response["Error"]
|
2023-08-13 20:42:50 +00:00
|
|
|
assert err["Code"] == "ParameterNotFound"
|
|
|
|
assert err["Message"] == (
|
|
|
|
"An error occurred (ParameterNotFound) when referencing Secrets "
|
|
|
|
"Manager: Secret /aws/reference/secretsmanager/test not found."
|
2022-05-10 22:32:49 +00:00
|
|
|
)
|