moto/tests/test_rds/test_rds_clusters_with_instances.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

131 lines
4.0 KiB
Python
Raw Normal View History

2023-04-08 10:33:09 +00:00
import boto3
import pytest
from botocore.exceptions import ClientError
2023-04-08 10:33:09 +00:00
from moto import mock_rds
@mock_rds
def test_add_instance_as_cluster_member():
# When creating a rds instance with DBClusterIdentifier provided,
# the instance is included as a ClusterMember in the describe_db_clusters call
client = boto3.client("rds", "us-east-1")
_ = client.create_db_cluster(
2023-04-08 10:33:09 +00:00
DBClusterIdentifier="dbci",
Engine="mysql",
MasterUsername="masterusername",
MasterUserPassword="hunter2_",
)["DBCluster"]
client.create_db_instance(
DBInstanceIdentifier="dbi",
DBClusterIdentifier="dbci",
DBInstanceClass="db.r5.large",
Engine="mysql",
2023-04-08 10:33:09 +00:00
)
cluster = client.describe_db_clusters()["DBClusters"][0]
assert "DBClusterMembers" in cluster
members = cluster["DBClusterMembers"]
assert len(members) == 1
assert members[0] == {
"DBInstanceIdentifier": "dbi",
"IsClusterWriter": True,
"DBClusterParameterGroupStatus": "in-sync",
"PromotionTier": 1,
}
@mock_rds
def test_remove_instance_from_cluster():
# When creating a rds instance with DBClusterIdentifier provided,
# the instance is included as a ClusterMember in the describe_db_clusters call
client = boto3.client("rds", "us-east-1")
_ = client.create_db_cluster(
2023-04-08 10:33:09 +00:00
DBClusterIdentifier="dbci",
Engine="mysql",
MasterUsername="masterusername",
MasterUserPassword="hunter2_",
)["DBCluster"]
client.create_db_instance(
DBInstanceIdentifier="dbi",
DBClusterIdentifier="dbci",
DBInstanceClass="db.r5.large",
Engine="mysql",
2023-04-08 10:33:09 +00:00
)
client.delete_db_instance(
DBInstanceIdentifier="dbi",
SkipFinalSnapshot=True,
)
cluster = client.describe_db_clusters()["DBClusters"][0]
assert "DBClusterMembers" in cluster
members = cluster["DBClusterMembers"]
assert len(members) == 0
@mock_rds
def test_add_instance_to_serverless_cluster():
client = boto3.client("rds", "us-east-1")
_ = client.create_db_cluster(
2023-04-08 10:33:09 +00:00
DBClusterIdentifier="dbci",
Engine="aurora-postgresql",
2023-04-08 10:33:09 +00:00
EngineMode="serverless",
MasterUsername="masterusername",
MasterUserPassword="hunter2_",
)["DBCluster"]
with pytest.raises(ClientError) as exc:
client.create_db_instance(
DBInstanceIdentifier="dbi",
DBClusterIdentifier="dbci",
DBInstanceClass="db.r5.large",
Engine="aurora-postgresql",
)
err = exc.value.response["Error"]
assert err["Code"] == "InvalidParameterValue"
assert err["Message"] == "Instances cannot be added to Aurora Serverless clusters."
@mock_rds
def test_delete_db_cluster_fails_if_cluster_contains_db_instances():
cluster_identifier = "test-cluster"
instance_identifier = "test-instance"
client = boto3.client("rds", "us-east-1")
client.create_db_cluster(
DBClusterIdentifier=cluster_identifier,
Engine="aurora-postgresql",
MasterUsername="test-user",
MasterUserPassword="password",
)
client.create_db_instance(
DBClusterIdentifier=cluster_identifier,
Engine="aurora-postgresql",
DBInstanceIdentifier=instance_identifier,
DBInstanceClass="db.t4g.medium",
)
with pytest.raises(ClientError) as exc:
client.delete_db_cluster(
DBClusterIdentifier=cluster_identifier,
SkipFinalSnapshot=True,
)
err = exc.value.response["Error"]
assert err["Code"] == "InvalidDBClusterStateFault"
assert (
err["Message"]
== "Cluster cannot be deleted, it still contains DB instances in non-deleting state."
)
client.delete_db_instance(
DBInstanceIdentifier=instance_identifier,
SkipFinalSnapshot=True,
)
cluster = client.delete_db_cluster(
DBClusterIdentifier=cluster_identifier,
SkipFinalSnapshot=True,
).get("DBCluster")
assert cluster["DBClusterIdentifier"] == cluster_identifier