| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import boto | 
					
						
							| 
									
										
										
										
											2017-03-15 21:58:37 -04:00
										 |  |  | import boto3 | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | from boto.redshift.exceptions import ( | 
					
						
							|  |  |  |     ClusterNotFound, | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  |     ClusterParameterGroupNotFound, | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  |     ClusterSecurityGroupNotFound, | 
					
						
							|  |  |  |     ClusterSubnetGroupNotFound, | 
					
						
							| 
									
										
										
										
											2014-11-23 23:20:02 -05:00
										 |  |  |     InvalidSubnet, | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | ) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | from botocore.exceptions import ( | 
					
						
							|  |  |  |     ClientError | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | import sure  # noqa | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-02 11:45:27 -07:00
										 |  |  | from moto import mock_ec2 | 
					
						
							|  |  |  | from moto import mock_ec2_deprecated | 
					
						
							|  |  |  | from moto import mock_redshift | 
					
						
							|  |  |  | from moto import mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2017-03-15 21:58:37 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_boto3(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     response = client.create_cluster( | 
					
						
							|  |  |  |         DBName='test', | 
					
						
							|  |  |  |         ClusterIdentifier='test', | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='user', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response['Cluster']['NodeType'].should.equal('ds2.xlarge') | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | def test_create_cluster(): | 
					
						
							|  |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     cluster_response = conn.create_cluster( | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |         db_name="my_db", | 
					
						
							|  |  |  |         cluster_type="multi-node", | 
					
						
							|  |  |  |         availability_zone="us-east-1d", | 
					
						
							|  |  |  |         preferred_maintenance_window="Mon:03:00-Mon:11:00", | 
					
						
							|  |  |  |         automated_snapshot_retention_period=10, | 
					
						
							|  |  |  |         port=1234, | 
					
						
							|  |  |  |         cluster_version="1.0", | 
					
						
							|  |  |  |         allow_version_upgrade=True, | 
					
						
							|  |  |  |         number_of_nodes=3, | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     cluster_response['CreateClusterResponse']['CreateClusterResult'][ | 
					
						
							|  |  |  |         'Cluster']['ClusterStatus'].should.equal('creating') | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = conn.describe_clusters(cluster_identifier) | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     cluster['ClusterIdentifier'].should.equal(cluster_identifier) | 
					
						
							|  |  |  |     cluster['NodeType'].should.equal("dw.hs1.xlarge") | 
					
						
							|  |  |  |     cluster['MasterUsername'].should.equal("username") | 
					
						
							|  |  |  |     cluster['DBName'].should.equal("my_db") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster['ClusterSecurityGroups'][0][ | 
					
						
							|  |  |  |         'ClusterSecurityGroupName'].should.equal("Default") | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     cluster['VpcSecurityGroups'].should.equal([]) | 
					
						
							|  |  |  |     cluster['ClusterSubnetGroupName'].should.equal(None) | 
					
						
							|  |  |  |     cluster['AvailabilityZone'].should.equal("us-east-1d") | 
					
						
							|  |  |  |     cluster['PreferredMaintenanceWindow'].should.equal("Mon:03:00-Mon:11:00") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster['ClusterParameterGroups'][0][ | 
					
						
							|  |  |  |         'ParameterGroupName'].should.equal("default.redshift-1.0") | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     cluster['AutomatedSnapshotRetentionPeriod'].should.equal(10) | 
					
						
							|  |  |  |     cluster['Port'].should.equal(1234) | 
					
						
							|  |  |  |     cluster['ClusterVersion'].should.equal("1.0") | 
					
						
							|  |  |  |     cluster['AllowVersionUpgrade'].should.equal(True) | 
					
						
							|  |  |  |     cluster['NumberOfNodes'].should.equal(3) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | def test_create_single_node_cluster(): | 
					
						
							|  |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.create_cluster( | 
					
						
							|  |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |         db_name="my_db", | 
					
						
							|  |  |  |         cluster_type="single-node", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = conn.describe_clusters(cluster_identifier) | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     cluster['ClusterIdentifier'].should.equal(cluster_identifier) | 
					
						
							|  |  |  |     cluster['NodeType'].should.equal("dw.hs1.xlarge") | 
					
						
							|  |  |  |     cluster['MasterUsername'].should.equal("username") | 
					
						
							|  |  |  |     cluster['DBName'].should.equal("my_db") | 
					
						
							|  |  |  |     cluster['NumberOfNodes'].should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | def test_default_cluster_attributes(): | 
					
						
							| 
									
										
										
										
											2014-11-23 18:16:22 -05:00
										 |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.create_cluster( | 
					
						
							|  |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = conn.describe_clusters(cluster_identifier) | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							| 
									
										
										
										
											2014-11-23 18:16:22 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     cluster['DBName'].should.equal("dev") | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  |     cluster['ClusterSubnetGroupName'].should.equal(None) | 
					
						
							| 
									
										
										
										
											2014-11-23 18:16:22 -05:00
										 |  |  |     assert "us-east-" in cluster['AvailabilityZone'] | 
					
						
							|  |  |  |     cluster['PreferredMaintenanceWindow'].should.equal("Mon:03:00-Mon:03:30") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster['ClusterParameterGroups'][0][ | 
					
						
							|  |  |  |         'ParameterGroupName'].should.equal("default.redshift-1.0") | 
					
						
							| 
									
										
										
										
											2014-11-23 18:16:22 -05:00
										 |  |  |     cluster['AutomatedSnapshotRetentionPeriod'].should.equal(1) | 
					
						
							|  |  |  |     cluster['Port'].should.equal(5439) | 
					
						
							|  |  |  |     cluster['ClusterVersion'].should.equal("1.0") | 
					
						
							|  |  |  |     cluster['AllowVersionUpgrade'].should.equal(True) | 
					
						
							|  |  |  |     cluster['NumberOfNodes'].should.equal(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							|  |  |  | @mock_ec2_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  | def test_create_cluster_in_subnet_group(): | 
					
						
							|  |  |  |     vpc_conn = boto.connect_vpc() | 
					
						
							|  |  |  |     vpc = vpc_conn.create_vpc("10.0.0.0/16") | 
					
						
							|  |  |  |     subnet = vpc_conn.create_subnet(vpc.id, "10.0.0.0/24") | 
					
						
							|  |  |  |     redshift_conn = boto.connect_redshift() | 
					
						
							|  |  |  |     redshift_conn.create_cluster_subnet_group( | 
					
						
							|  |  |  |         "my_subnet_group", | 
					
						
							|  |  |  |         "This is my subnet group", | 
					
						
							|  |  |  |         subnet_ids=[subnet.id], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     redshift_conn.create_cluster( | 
					
						
							|  |  |  |         "my_cluster", | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |         cluster_subnet_group_name='my_subnet_group', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = redshift_conn.describe_clusters("my_cluster") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  |     cluster['ClusterSubnetGroupName'].should.equal('my_subnet_group') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-02 11:45:27 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | @mock_ec2 | 
					
						
							|  |  |  | def test_create_cluster_in_subnet_group_boto3(): | 
					
						
							|  |  |  |     ec2 = boto3.resource('ec2', region_name='us-east-1') | 
					
						
							|  |  |  |     vpc = ec2.create_vpc(CidrBlock='10.0.0.0/16') | 
					
						
							|  |  |  |     subnet = ec2.create_subnet(VpcId=vpc.id, CidrBlock='10.0.0.0/24') | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     client.create_cluster_subnet_group( | 
					
						
							|  |  |  |         ClusterSubnetGroupName='my_subnet_group', | 
					
						
							|  |  |  |         Description='This is my subnet group', | 
					
						
							|  |  |  |         SubnetIds=[subnet.id] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         ClusterIdentifier="my_cluster", | 
					
						
							|  |  |  |         NodeType="dw.hs1.xlarge", | 
					
						
							|  |  |  |         MasterUsername="username", | 
					
						
							|  |  |  |         MasterUserPassword="password", | 
					
						
							|  |  |  |         ClusterSubnetGroupName='my_subnet_group', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = client.describe_clusters(ClusterIdentifier="my_cluster") | 
					
						
							|  |  |  |     cluster = cluster_response['Clusters'][0] | 
					
						
							|  |  |  |     cluster['ClusterSubnetGroupName'].should.equal('my_subnet_group') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | def test_create_cluster_with_security_group(): | 
					
						
							|  |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							|  |  |  |     conn.create_cluster_security_group( | 
					
						
							|  |  |  |         "security_group1", | 
					
						
							|  |  |  |         "This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     conn.create_cluster_security_group( | 
					
						
							|  |  |  |         "security_group2", | 
					
						
							|  |  |  |         "This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     conn.create_cluster( | 
					
						
							|  |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |         cluster_security_groups=["security_group1", "security_group2"] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = conn.describe_clusters(cluster_identifier) | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							|  |  |  |     group_names = [group['ClusterSecurityGroupName'] | 
					
						
							|  |  |  |                    for group in cluster['ClusterSecurityGroups']] | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  |     set(group_names).should.equal(set(["security_group1", "security_group2"])) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-30 21:51:05 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_with_security_group_boto3(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     client.create_cluster_security_group( | 
					
						
							|  |  |  |         ClusterSecurityGroupName="security_group1", | 
					
						
							|  |  |  |         Description="This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster_security_group( | 
					
						
							|  |  |  |         ClusterSecurityGroupName="security_group2", | 
					
						
							|  |  |  |         Description="This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         NodeType="dw.hs1.xlarge", | 
					
						
							|  |  |  |         MasterUsername="username", | 
					
						
							|  |  |  |         MasterUserPassword="password", | 
					
						
							|  |  |  |         ClusterSecurityGroups=["security_group1", "security_group2"] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response = client.describe_clusters(ClusterIdentifier=cluster_identifier) | 
					
						
							|  |  |  |     cluster = response['Clusters'][0] | 
					
						
							|  |  |  |     group_names = [group['ClusterSecurityGroupName'] | 
					
						
							|  |  |  |                    for group in cluster['ClusterSecurityGroups']] | 
					
						
							|  |  |  |     set(group_names).should.equal({"security_group1", "security_group2"}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							|  |  |  | @mock_ec2_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 22:33:53 -05:00
										 |  |  | def test_create_cluster_with_vpc_security_groups(): | 
					
						
							|  |  |  |     vpc_conn = boto.connect_vpc() | 
					
						
							|  |  |  |     ec2_conn = boto.connect_ec2() | 
					
						
							|  |  |  |     redshift_conn = boto.connect_redshift() | 
					
						
							|  |  |  |     vpc = vpc_conn.create_vpc("10.0.0.0/16") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     security_group = ec2_conn.create_security_group( | 
					
						
							|  |  |  |         "vpc_security_group", "a group", vpc_id=vpc.id) | 
					
						
							| 
									
										
										
										
											2014-11-23 22:33:53 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     redshift_conn.create_cluster( | 
					
						
							|  |  |  |         "my_cluster", | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |         vpc_security_group_ids=[security_group.id], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = redshift_conn.describe_clusters("my_cluster") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							|  |  |  |     group_ids = [group['VpcSecurityGroupId'] | 
					
						
							|  |  |  |                  for group in cluster['VpcSecurityGroups']] | 
					
						
							| 
									
										
										
										
											2014-11-23 22:33:53 -05:00
										 |  |  |     list(group_ids).should.equal([security_group.id]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-30 21:51:05 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | @mock_ec2 | 
					
						
							|  |  |  | def test_create_cluster_with_vpc_security_groups_boto3(): | 
					
						
							|  |  |  |     ec2 = boto3.resource('ec2', region_name='us-east-1') | 
					
						
							|  |  |  |     vpc = ec2.create_vpc(CidrBlock='10.0.0.0/16') | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_id = 'my_cluster' | 
					
						
							|  |  |  |     security_group = ec2.create_security_group( | 
					
						
							|  |  |  |         Description="vpc_security_group", | 
					
						
							|  |  |  |         GroupName="a group", | 
					
						
							|  |  |  |         VpcId=vpc.id) | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_id, | 
					
						
							|  |  |  |         NodeType="dw.hs1.xlarge", | 
					
						
							|  |  |  |         MasterUsername="username", | 
					
						
							|  |  |  |         MasterUserPassword="password", | 
					
						
							|  |  |  |         VpcSecurityGroupIds=[security_group.id], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response = client.describe_clusters(ClusterIdentifier=cluster_id) | 
					
						
							|  |  |  |     cluster = response['Clusters'][0] | 
					
						
							|  |  |  |     group_ids = [group['VpcSecurityGroupId'] | 
					
						
							|  |  |  |                  for group in cluster['VpcSecurityGroups']] | 
					
						
							|  |  |  |     list(group_ids).should.equal([security_group.id]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | def test_create_cluster_with_parameter_group(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     conn.create_cluster_parameter_group( | 
					
						
							|  |  |  |         "my_parameter_group", | 
					
						
							|  |  |  |         "redshift-1.0", | 
					
						
							|  |  |  |         "This is my parameter group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.create_cluster( | 
					
						
							|  |  |  |         "my_cluster", | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |         cluster_parameter_group_name='my_parameter_group', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = conn.describe_clusters("my_cluster") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							|  |  |  |     cluster['ClusterParameterGroups'][0][ | 
					
						
							|  |  |  |         'ParameterGroupName'].should.equal("my_parameter_group") | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | def test_describe_non_existent_cluster(): | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.describe_clusters.when.called_with( | 
					
						
							|  |  |  |         "not-a-cluster").should.throw(ClusterNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | def test_delete_cluster(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.create_cluster( | 
					
						
							|  |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         node_type='single-node', | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     clusters = conn.describe_clusters()['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'] | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     list(clusters).should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.delete_cluster(cluster_identifier) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     clusters = conn.describe_clusters()['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'] | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     list(clusters).should.have.length_of(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Delete invalid id | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.delete_cluster.when.called_with( | 
					
						
							|  |  |  |         "not-a-cluster").should.throw(ClusterNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | def test_modify_cluster(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  |     conn.create_cluster_security_group( | 
					
						
							|  |  |  |         "security_group", | 
					
						
							|  |  |  |         "This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  |     conn.create_cluster_parameter_group( | 
					
						
							|  |  |  |         "my_parameter_group", | 
					
						
							|  |  |  |         "redshift-1.0", | 
					
						
							|  |  |  |         "This is my parameter group", | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     conn.create_cluster( | 
					
						
							|  |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         node_type='single-node', | 
					
						
							|  |  |  |         master_username="username", | 
					
						
							|  |  |  |         master_user_password="password", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.modify_cluster( | 
					
						
							|  |  |  |         cluster_identifier, | 
					
						
							|  |  |  |         cluster_type="multi-node", | 
					
						
							|  |  |  |         node_type="dw.hs1.xlarge", | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  |         cluster_security_groups="security_group", | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |         master_user_password="new_password", | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  |         cluster_parameter_group_name="my_parameter_group", | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |         automated_snapshot_retention_period=7, | 
					
						
							|  |  |  |         preferred_maintenance_window="Tue:03:00-Tue:11:00", | 
					
						
							|  |  |  |         allow_version_upgrade=False, | 
					
						
							|  |  |  |         new_cluster_identifier="new_identifier", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = conn.describe_clusters("new_identifier") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster = cluster_response['DescribeClustersResponse'][ | 
					
						
							|  |  |  |         'DescribeClustersResult']['Clusters'][0] | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     cluster['ClusterIdentifier'].should.equal("new_identifier") | 
					
						
							|  |  |  |     cluster['NodeType'].should.equal("dw.hs1.xlarge") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster['ClusterSecurityGroups'][0][ | 
					
						
							|  |  |  |         'ClusterSecurityGroupName'].should.equal("security_group") | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     cluster['PreferredMaintenanceWindow'].should.equal("Tue:03:00-Tue:11:00") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     cluster['ClusterParameterGroups'][0][ | 
					
						
							|  |  |  |         'ParameterGroupName'].should.equal("my_parameter_group") | 
					
						
							| 
									
										
										
										
											2014-11-22 14:03:09 -05:00
										 |  |  |     cluster['AutomatedSnapshotRetentionPeriod'].should.equal(7) | 
					
						
							|  |  |  |     cluster['AllowVersionUpgrade'].should.equal(False) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     # This one should remain unmodified. | 
					
						
							|  |  |  |     cluster['NumberOfNodes'].should.equal(1) | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							|  |  |  | @mock_ec2_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  | def test_create_cluster_subnet_group(): | 
					
						
							|  |  |  |     vpc_conn = boto.connect_vpc() | 
					
						
							|  |  |  |     vpc = vpc_conn.create_vpc("10.0.0.0/16") | 
					
						
							|  |  |  |     subnet1 = vpc_conn.create_subnet(vpc.id, "10.0.0.0/24") | 
					
						
							|  |  |  |     subnet2 = vpc_conn.create_subnet(vpc.id, "10.0.1.0/24") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     redshift_conn = boto.connect_redshift() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     redshift_conn.create_cluster_subnet_group( | 
					
						
							|  |  |  |         "my_subnet", | 
					
						
							|  |  |  |         "This is my subnet group", | 
					
						
							|  |  |  |         subnet_ids=[subnet1.id, subnet2.id], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     subnets_response = redshift_conn.describe_cluster_subnet_groups( | 
					
						
							|  |  |  |         "my_subnet") | 
					
						
							|  |  |  |     my_subnet = subnets_response['DescribeClusterSubnetGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterSubnetGroupsResult']['ClusterSubnetGroups'][0] | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     my_subnet['ClusterSubnetGroupName'].should.equal("my_subnet") | 
					
						
							|  |  |  |     my_subnet['Description'].should.equal("This is my subnet group") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     subnet_ids = [subnet['SubnetIdentifier'] | 
					
						
							|  |  |  |                   for subnet in my_subnet['Subnets']] | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  |     set(subnet_ids).should.equal(set([subnet1.id, subnet2.id])) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							|  |  |  | @mock_ec2_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 23:20:02 -05:00
										 |  |  | def test_create_invalid_cluster_subnet_group(): | 
					
						
							|  |  |  |     redshift_conn = boto.connect_redshift() | 
					
						
							|  |  |  |     redshift_conn.create_cluster_subnet_group.when.called_with( | 
					
						
							|  |  |  |         "my_subnet", | 
					
						
							|  |  |  |         "This is my subnet group", | 
					
						
							|  |  |  |         subnet_ids=["subnet-1234"], | 
					
						
							|  |  |  |     ).should.throw(InvalidSubnet) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | def test_describe_non_existent_subnet_group(): | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.describe_cluster_subnet_groups.when.called_with( | 
					
						
							|  |  |  |         "not-a-subnet-group").should.throw(ClusterSubnetGroupNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							|  |  |  | @mock_ec2_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  | def test_delete_cluster_subnet_group(): | 
					
						
							|  |  |  |     vpc_conn = boto.connect_vpc() | 
					
						
							|  |  |  |     vpc = vpc_conn.create_vpc("10.0.0.0/16") | 
					
						
							|  |  |  |     subnet = vpc_conn.create_subnet(vpc.id, "10.0.0.0/24") | 
					
						
							|  |  |  |     redshift_conn = boto.connect_redshift() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     redshift_conn.create_cluster_subnet_group( | 
					
						
							|  |  |  |         "my_subnet", | 
					
						
							|  |  |  |         "This is my subnet group", | 
					
						
							|  |  |  |         subnet_ids=[subnet.id], | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     subnets_response = redshift_conn.describe_cluster_subnet_groups() | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     subnets = subnets_response['DescribeClusterSubnetGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterSubnetGroupsResult']['ClusterSubnetGroups'] | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  |     subnets.should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     redshift_conn.delete_cluster_subnet_group("my_subnet") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     subnets_response = redshift_conn.describe_cluster_subnet_groups() | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     subnets = subnets_response['DescribeClusterSubnetGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterSubnetGroupsResult']['ClusterSubnetGroups'] | 
					
						
							| 
									
										
										
										
											2014-11-23 21:36:19 -05:00
										 |  |  |     subnets.should.have.length_of(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Delete invalid id | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     redshift_conn.delete_cluster_subnet_group.when.called_with( | 
					
						
							|  |  |  |         "not-a-subnet-group").should.throw(ClusterSubnetGroupNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | def test_create_cluster_security_group(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     conn.create_cluster_security_group( | 
					
						
							|  |  |  |         "my_security_group", | 
					
						
							|  |  |  |         "This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     groups_response = conn.describe_cluster_security_groups( | 
					
						
							|  |  |  |         "my_security_group") | 
					
						
							|  |  |  |     my_group = groups_response['DescribeClusterSecurityGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterSecurityGroupsResult']['ClusterSecurityGroups'][0] | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     my_group['ClusterSecurityGroupName'].should.equal("my_security_group") | 
					
						
							|  |  |  |     my_group['Description'].should.equal("This is my security group") | 
					
						
							|  |  |  |     list(my_group['IPRanges']).should.equal([]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | def test_describe_non_existent_security_group(): | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.describe_cluster_security_groups.when.called_with( | 
					
						
							|  |  |  |         "not-a-security-group").should.throw(ClusterSecurityGroupNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | def test_delete_cluster_security_group(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     conn.create_cluster_security_group( | 
					
						
							|  |  |  |         "my_security_group", | 
					
						
							|  |  |  |         "This is my security group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     groups_response = conn.describe_cluster_security_groups() | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     groups = groups_response['DescribeClusterSecurityGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterSecurityGroupsResult']['ClusterSecurityGroups'] | 
					
						
							| 
									
										
										
										
											2014-11-23 22:21:29 -05:00
										 |  |  |     groups.should.have.length_of(2)  # The default group already exists | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     conn.delete_cluster_security_group("my_security_group") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     groups_response = conn.describe_cluster_security_groups() | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     groups = groups_response['DescribeClusterSecurityGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterSecurityGroupsResult']['ClusterSecurityGroups'] | 
					
						
							| 
									
										
										
										
											2014-11-23 22:21:29 -05:00
										 |  |  |     groups.should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2014-11-23 22:17:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Delete invalid id | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.delete_cluster_security_group.when.called_with( | 
					
						
							|  |  |  |         "not-a-security-group").should.throw(ClusterSecurityGroupNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | def test_create_cluster_parameter_group(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     conn.create_cluster_parameter_group( | 
					
						
							|  |  |  |         "my_parameter_group", | 
					
						
							|  |  |  |         "redshift-1.0", | 
					
						
							|  |  |  |         "This is my parameter group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     groups_response = conn.describe_cluster_parameter_groups( | 
					
						
							|  |  |  |         "my_parameter_group") | 
					
						
							|  |  |  |     my_group = groups_response['DescribeClusterParameterGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterParameterGroupsResult']['ParameterGroups'][0] | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     my_group['ParameterGroupName'].should.equal("my_parameter_group") | 
					
						
							|  |  |  |     my_group['ParameterGroupFamily'].should.equal("redshift-1.0") | 
					
						
							|  |  |  |     my_group['Description'].should.equal("This is my parameter group") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | def test_describe_non_existent_parameter_group(): | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  |     conn = boto.redshift.connect_to_region("us-east-1") | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.describe_cluster_parameter_groups.when.called_with( | 
					
						
							|  |  |  |         "not-a-parameter-group").should.throw(ClusterParameterGroupNotFound) | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 22:35:45 -05:00
										 |  |  | @mock_redshift_deprecated | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  | def test_delete_cluster_parameter_group(): | 
					
						
							|  |  |  |     conn = boto.connect_redshift() | 
					
						
							|  |  |  |     conn.create_cluster_parameter_group( | 
					
						
							|  |  |  |         "my_parameter_group", | 
					
						
							|  |  |  |         "redshift-1.0", | 
					
						
							|  |  |  |         "This is my parameter group", | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     groups_response = conn.describe_cluster_parameter_groups() | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     groups = groups_response['DescribeClusterParameterGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterParameterGroupsResult']['ParameterGroups'] | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  |     groups.should.have.length_of(2)  # The default group already exists | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     conn.delete_cluster_parameter_group("my_parameter_group") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     groups_response = conn.describe_cluster_parameter_groups() | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     groups = groups_response['DescribeClusterParameterGroupsResponse'][ | 
					
						
							|  |  |  |         'DescribeClusterParameterGroupsResult']['ParameterGroups'] | 
					
						
							| 
									
										
										
										
											2014-11-23 23:03:10 -05:00
										 |  |  |     groups.should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Delete invalid id | 
					
						
							| 
									
										
										
										
											2017-02-23 21:37:43 -05:00
										 |  |  |     conn.delete_cluster_parameter_group.when.called_with( | 
					
						
							|  |  |  |         "not-a-parameter-group").should.throw(ClusterParameterGroupNotFound) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_snapshot_of_non_existent_cluster(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'non-existent-cluster-id' | 
					
						
							|  |  |  |     client.create_cluster_snapshot.when.called_with( | 
					
						
							|  |  |  |         SnapshotIdentifier='snapshot-id', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'Cluster {} not found.'.format(cluster_identifier)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_snapshot(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     snapshot_identifier = 'my_snapshot' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_response = client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     cluster_response['Cluster']['NodeType'].should.equal('ds2.xlarge') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     snapshot_response = client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         Tags=[{'Key': 'test-tag-key', | 
					
						
							|  |  |  |                'Value': 'test-tag-value'}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     snapshot = snapshot_response['Snapshot'] | 
					
						
							|  |  |  |     snapshot['SnapshotIdentifier'].should.equal(snapshot_identifier) | 
					
						
							|  |  |  |     snapshot['ClusterIdentifier'].should.equal(cluster_identifier) | 
					
						
							|  |  |  |     snapshot['NumberOfNodes'].should.equal(1) | 
					
						
							|  |  |  |     snapshot['NodeType'].should.equal('ds2.xlarge') | 
					
						
							|  |  |  |     snapshot['MasterUsername'].should.equal('username') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_describe_cluster_snapshots(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     snapshot_identifier = 'my_snapshot' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp_clust = client.describe_cluster_snapshots(ClusterIdentifier=cluster_identifier) | 
					
						
							|  |  |  |     resp_snap = client.describe_cluster_snapshots(SnapshotIdentifier=snapshot_identifier) | 
					
						
							|  |  |  |     resp_clust['Snapshots'][0].should.equal(resp_snap['Snapshots'][0]) | 
					
						
							|  |  |  |     snapshot = resp_snap['Snapshots'][0] | 
					
						
							|  |  |  |     snapshot['SnapshotIdentifier'].should.equal(snapshot_identifier) | 
					
						
							|  |  |  |     snapshot['ClusterIdentifier'].should.equal(cluster_identifier) | 
					
						
							|  |  |  |     snapshot['NumberOfNodes'].should.equal(1) | 
					
						
							|  |  |  |     snapshot['NodeType'].should.equal('ds2.xlarge') | 
					
						
							|  |  |  |     snapshot['MasterUsername'].should.equal('username') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_describe_cluster_snapshots_not_found_error(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     snapshot_identifier = 'my_snapshot' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.describe_cluster_snapshots.when.called_with( | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'Cluster {} not found.'.format(cluster_identifier)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.describe_cluster_snapshots.when.called_with( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'Snapshot {} not found.'.format(snapshot_identifier)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_delete_cluster_snapshot(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     snapshot_identifier = 'my_snapshot' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     snapshots = client.describe_cluster_snapshots()['Snapshots'] | 
					
						
							|  |  |  |     list(snapshots).should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.delete_cluster_snapshot(SnapshotIdentifier=snapshot_identifier)[ | 
					
						
							|  |  |  |         'Snapshot']['Status'].should.equal('deleted') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     snapshots = client.describe_cluster_snapshots()['Snapshots'] | 
					
						
							|  |  |  |     list(snapshots).should.have.length_of(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Delete invalid id | 
					
						
							|  |  |  |     client.delete_cluster_snapshot.when.called_with( | 
					
						
							|  |  |  |         SnapshotIdentifier="not-a-snapshot").should.throw(ClientError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_cluster_snapshot_already_exists(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							|  |  |  |     snapshot_identifier = 'my_snapshot' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster_snapshot.when.called_with( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier | 
					
						
							|  |  |  |     ).should.throw(ClientError) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_from_snapshot(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     original_cluster_identifier = 'original-cluster' | 
					
						
							|  |  |  |     original_snapshot_identifier = 'original-snapshot' | 
					
						
							|  |  |  |     new_cluster_identifier = 'new-cluster' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         ClusterIdentifier=original_cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=original_snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=original_cluster_identifier | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response = client.restore_from_cluster_snapshot( | 
					
						
							|  |  |  |         ClusterIdentifier=new_cluster_identifier, | 
					
						
							|  |  |  |         SnapshotIdentifier=original_snapshot_identifier, | 
					
						
							|  |  |  |         Port=1234 | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response['Cluster']['ClusterStatus'].should.equal('creating') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response = client.describe_clusters( | 
					
						
							|  |  |  |         ClusterIdentifier=new_cluster_identifier | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     new_cluster = response['Clusters'][0] | 
					
						
							|  |  |  |     new_cluster['NodeType'].should.equal('ds2.xlarge') | 
					
						
							|  |  |  |     new_cluster['MasterUsername'].should.equal('username') | 
					
						
							|  |  |  |     new_cluster['Endpoint']['Port'].should.equal(1234) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_from_non_existent_snapshot(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     client.restore_from_cluster_snapshot.when.called_with( | 
					
						
							|  |  |  |         ClusterIdentifier='cluster-id', | 
					
						
							|  |  |  |         SnapshotIdentifier='non-existent-snapshot', | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'Snapshot non-existent-snapshot not found.') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_cluster_status_update(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'test-cluster' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response = client.create_cluster( | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response['Cluster']['ClusterStatus'].should.equal('creating') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     response = client.describe_clusters( | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response['Clusters'][0]['ClusterStatus'].should.equal('available') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | def test_describe_tags_with_resource_type(): | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'my_cluster' | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     cluster_arn = 'arn:aws:redshift:us-east-1:123456789012:' \ | 
					
						
							|  |  |  |                   'cluster:{}'.format(cluster_identifier) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     snapshot_identifier = 'my_snapshot' | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     snapshot_arn = 'arn:aws:redshift:us-east-1:123456789012:' \ | 
					
						
							|  |  |  |                    'snapshot:{}/{}'.format(cluster_identifier, | 
					
						
							|  |  |  |                                            snapshot_identifier) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     tag_key = 'test-tag-key' | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     tag_value = 'test-tag-value' | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |         Tags=[{'Key': tag_key, | 
					
						
							|  |  |  |                'Value': tag_value}] | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     tags_response = client.describe_tags(ResourceType='cluster') | 
					
						
							|  |  |  |     tagged_resources = tags_response['TaggedResources'] | 
					
						
							|  |  |  |     list(tagged_resources).should.have.length_of(1) | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceType'].should.equal('cluster') | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceName'].should.equal(cluster_arn) | 
					
						
							|  |  |  |     tag = tagged_resources[0]['Tag'] | 
					
						
							|  |  |  |     tag['Key'].should.equal(tag_key) | 
					
						
							|  |  |  |     tag['Value'].should.equal(tag_value) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         Tags=[{'Key': tag_key, | 
					
						
							|  |  |  |                'Value': tag_value}] | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     tags_response = client.describe_tags(ResourceType='snapshot') | 
					
						
							|  |  |  |     tagged_resources = tags_response['TaggedResources'] | 
					
						
							|  |  |  |     list(tagged_resources).should.have.length_of(1) | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceType'].should.equal('snapshot') | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceName'].should.equal(snapshot_arn) | 
					
						
							|  |  |  |     tag = tagged_resources[0]['Tag'] | 
					
						
							|  |  |  |     tag['Key'].should.equal(tag_key) | 
					
						
							|  |  |  |     tag['Value'].should.equal(tag_value) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_describe_tags_cannot_specify_resource_type_and_resource_name(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     resource_name = 'arn:aws:redshift:us-east-1:123456789012:cluster:cluster-id' | 
					
						
							|  |  |  |     resource_type = 'cluster' | 
					
						
							|  |  |  |     client.describe_tags.when.called_with( | 
					
						
							|  |  |  |         ResourceName=resource_name, | 
					
						
							|  |  |  |         ResourceType=resource_type | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'using either an ARN or a resource type') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_describe_tags_with_resource_name(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'cluster-id' | 
					
						
							|  |  |  |     cluster_arn = 'arn:aws:redshift:us-east-1:123456789012:' \ | 
					
						
							|  |  |  |                   'cluster:{}'.format(cluster_identifier) | 
					
						
							|  |  |  |     snapshot_identifier = 'snapshot-id' | 
					
						
							|  |  |  |     snapshot_arn = 'arn:aws:redshift:us-east-1:123456789012:' \ | 
					
						
							|  |  |  |                    'snapshot:{}/{}'.format(cluster_identifier, | 
					
						
							|  |  |  |                                            snapshot_identifier) | 
					
						
							|  |  |  |     tag_key = 'test-tag-key' | 
					
						
							|  |  |  |     tag_value = 'test-tag-value' | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |         Tags=[{'Key': tag_key, | 
					
						
							|  |  |  |                'Value': tag_value}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     tags_response = client.describe_tags(ResourceName=cluster_arn) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     tagged_resources = tags_response['TaggedResources'] | 
					
						
							|  |  |  |     list(tagged_resources).should.have.length_of(1) | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  |     tagged_resources[0]['ResourceType'].should.equal('cluster') | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceName'].should.equal(cluster_arn) | 
					
						
							| 
									
										
										
										
											2017-08-09 18:43:21 -07:00
										 |  |  |     tag = tagged_resources[0]['Tag'] | 
					
						
							|  |  |  |     tag['Key'].should.equal(tag_key) | 
					
						
							|  |  |  |     tag['Value'].should.equal(tag_value) | 
					
						
							| 
									
										
										
										
											2017-09-27 17:18:28 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier=snapshot_identifier, | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         Tags=[{'Key': tag_key, | 
					
						
							|  |  |  |                'Value': tag_value}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     tags_response = client.describe_tags(ResourceName=snapshot_arn) | 
					
						
							|  |  |  |     tagged_resources = tags_response['TaggedResources'] | 
					
						
							|  |  |  |     list(tagged_resources).should.have.length_of(1) | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceType'].should.equal('snapshot') | 
					
						
							|  |  |  |     tagged_resources[0]['ResourceName'].should.equal(snapshot_arn) | 
					
						
							|  |  |  |     tag = tagged_resources[0]['Tag'] | 
					
						
							|  |  |  |     tag['Key'].should.equal(tag_key) | 
					
						
							|  |  |  |     tag['Value'].should.equal(tag_value) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_create_tags(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'cluster-id' | 
					
						
							|  |  |  |     cluster_arn = 'arn:aws:redshift:us-east-1:123456789012:' \ | 
					
						
							|  |  |  |                   'cluster:{}'.format(cluster_identifier) | 
					
						
							|  |  |  |     tag_key = 'test-tag-key' | 
					
						
							|  |  |  |     tag_value = 'test-tag-value' | 
					
						
							|  |  |  |     num_tags = 5 | 
					
						
							|  |  |  |     tags = [] | 
					
						
							|  |  |  |     for i in range(0, num_tags): | 
					
						
							|  |  |  |         tag = {'Key': '{}-{}'.format(tag_key, i), | 
					
						
							|  |  |  |                'Value': '{}-{}'.format(tag_value, i)} | 
					
						
							|  |  |  |         tags.append(tag) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_tags( | 
					
						
							|  |  |  |         ResourceName=cluster_arn, | 
					
						
							|  |  |  |         Tags=tags | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response = client.describe_clusters(ClusterIdentifier=cluster_identifier) | 
					
						
							|  |  |  |     cluster = response['Clusters'][0] | 
					
						
							|  |  |  |     list(cluster['Tags']).should.have.length_of(num_tags) | 
					
						
							|  |  |  |     response = client.describe_tags(ResourceName=cluster_arn) | 
					
						
							|  |  |  |     list(response['TaggedResources']).should.have.length_of(num_tags) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_delete_tags(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     cluster_identifier = 'cluster-id' | 
					
						
							|  |  |  |     cluster_arn = 'arn:aws:redshift:us-east-1:123456789012:' \ | 
					
						
							|  |  |  |                   'cluster:{}'.format(cluster_identifier) | 
					
						
							|  |  |  |     tag_key = 'test-tag-key' | 
					
						
							|  |  |  |     tag_value = 'test-tag-value' | 
					
						
							|  |  |  |     tags = [] | 
					
						
							|  |  |  |     for i in range(1, 2): | 
					
						
							|  |  |  |         tag = {'Key': '{}-{}'.format(tag_key, i), | 
					
						
							|  |  |  |                'Value': '{}-{}'.format(tag_value, i)} | 
					
						
							|  |  |  |         tags.append(tag) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test-db', | 
					
						
							|  |  |  |         ClusterIdentifier=cluster_identifier, | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='username', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |         Tags=tags | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.delete_tags( | 
					
						
							|  |  |  |         ResourceName=cluster_arn, | 
					
						
							|  |  |  |         TagKeys=[tag['Key'] for tag in tags | 
					
						
							|  |  |  |                  if tag['Key'] != '{}-1'.format(tag_key)] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response = client.describe_clusters(ClusterIdentifier=cluster_identifier) | 
					
						
							|  |  |  |     cluster = response['Clusters'][0] | 
					
						
							|  |  |  |     list(cluster['Tags']).should.have.length_of(1) | 
					
						
							|  |  |  |     response = client.describe_tags(ResourceName=cluster_arn) | 
					
						
							|  |  |  |     list(response['TaggedResources']).should.have.length_of(1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_ec2 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_describe_tags_all_resource_types(): | 
					
						
							|  |  |  |     ec2 = boto3.resource('ec2', region_name='us-east-1') | 
					
						
							|  |  |  |     vpc = ec2.create_vpc(CidrBlock='10.0.0.0/16') | 
					
						
							|  |  |  |     subnet = ec2.create_subnet(VpcId=vpc.id, CidrBlock='10.0.0.0/24') | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  |     response = client.describe_tags() | 
					
						
							|  |  |  |     list(response['TaggedResources']).should.have.length_of(0) | 
					
						
							|  |  |  |     client.create_cluster_subnet_group( | 
					
						
							|  |  |  |         ClusterSubnetGroupName='my_subnet_group', | 
					
						
							|  |  |  |         Description='This is my subnet group', | 
					
						
							|  |  |  |         SubnetIds=[subnet.id], | 
					
						
							|  |  |  |         Tags=[{'Key': 'tag_key', | 
					
						
							|  |  |  |                'Value': 'tag_value'}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster_security_group( | 
					
						
							|  |  |  |         ClusterSecurityGroupName="security_group1", | 
					
						
							|  |  |  |         Description="This is my security group", | 
					
						
							|  |  |  |         Tags=[{'Key': 'tag_key', | 
					
						
							|  |  |  |                'Value': 'tag_value'}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster( | 
					
						
							|  |  |  |         DBName='test', | 
					
						
							|  |  |  |         ClusterIdentifier='my_cluster', | 
					
						
							|  |  |  |         ClusterType='single-node', | 
					
						
							|  |  |  |         NodeType='ds2.xlarge', | 
					
						
							|  |  |  |         MasterUsername='user', | 
					
						
							|  |  |  |         MasterUserPassword='password', | 
					
						
							|  |  |  |         Tags=[{'Key': 'tag_key', | 
					
						
							|  |  |  |                'Value': 'tag_value'}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster_snapshot( | 
					
						
							|  |  |  |         SnapshotIdentifier='my_snapshot', | 
					
						
							|  |  |  |         ClusterIdentifier='my_cluster', | 
					
						
							|  |  |  |         Tags=[{'Key': 'tag_key', | 
					
						
							|  |  |  |                'Value': 'tag_value'}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     client.create_cluster_parameter_group( | 
					
						
							|  |  |  |         ParameterGroupName="my_parameter_group", | 
					
						
							|  |  |  |         ParameterGroupFamily="redshift-1.0", | 
					
						
							|  |  |  |         Description="This is my parameter group", | 
					
						
							|  |  |  |         Tags=[{'Key': 'tag_key', | 
					
						
							|  |  |  |                'Value': 'tag_value'}] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     response = client.describe_tags() | 
					
						
							|  |  |  |     expected_types = ['cluster', 'parametergroup', 'securitygroup', 'snapshot', 'subnetgroup'] | 
					
						
							|  |  |  |     tagged_resources = response['TaggedResources'] | 
					
						
							|  |  |  |     returned_types = [resource['ResourceType'] for resource in tagged_resources] | 
					
						
							|  |  |  |     list(tagged_resources).should.have.length_of(len(expected_types)) | 
					
						
							|  |  |  |     set(returned_types).should.equal(set(expected_types)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_redshift | 
					
						
							|  |  |  | def test_tagged_resource_not_found_error(): | 
					
						
							|  |  |  |     client = boto3.client('redshift', region_name='us-east-1') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     cluster_arn = 'arn:aws:redshift:us-east-1::cluster:fake' | 
					
						
							|  |  |  |     client.describe_tags.when.called_with( | 
					
						
							|  |  |  |         ResourceName=cluster_arn | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'cluster (fake) not found.') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     snapshot_arn = 'arn:aws:redshift:us-east-1::snapshot:cluster-id/snap-id' | 
					
						
							|  |  |  |     client.delete_tags.when.called_with( | 
					
						
							|  |  |  |         ResourceName=snapshot_arn, | 
					
						
							|  |  |  |         TagKeys=['test'] | 
					
						
							|  |  |  |     ).should.throw(ClientError, 'snapshot (snap-id) not found.') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.describe_tags.when.called_with( | 
					
						
							|  |  |  |         ResourceType='cluster' | 
					
						
							|  |  |  |     ).should.throw(ClientError, "resource of type 'cluster' not found.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.describe_tags.when.called_with( | 
					
						
							|  |  |  |         ResourceName='bad:arn' | 
					
						
							|  |  |  |     ).should.throw(ClientError, "Tagging is not supported for this type of resource") | 
					
						
							|  |  |  | 
 |