1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/tests/aws/requests/rds/instance_tests.rb

128 lines
4.7 KiB
Ruby
Raw Normal View History

2011-02-27 16:09:12 -05:00
Shindo.tests('AWS::RDS | instance requests', ['aws', 'rds']) do
# random_differentiator
# Useful when rapidly re-running tests, so we don't have to wait
# serveral minutes for deleted servers to disappear
suffix = rand(65536).to_s(16)
@db_instance_id = "fog-test-#{suffix}"
@db_replica_id = "fog-replica-#{suffix}"
@db_snapshot_id = "fog-snapshot"
@db_final_snapshot_id = "fog-final-snapshot"
2011-02-27 16:09:12 -05:00
tests('success') do
pending if Fog.mocking?
2011-02-27 16:09:12 -05:00
tests("#create_db_instance").formats(AWS::RDS::Formats::CREATE_DB_INSTANCE) do
result = AWS[:rds].create_db_instance(@db_instance_id, 'AllocatedStorage' => 5,
'DBInstanceClass' => 'db.m1.small',
'Engine' => 'mysql',
'EngineVersion' => '5.1.50',
'MasterUsername' => 'foguser',
'BackupRetentionPeriod' => 1,
'MasterUserPassword' => 'fogpassword').body
2011-02-27 16:09:12 -05:00
instance = result['CreateDBInstanceResult']['DBInstance']
returns('creating'){ instance['DBInstanceStatus']}
result
end
2011-02-27 16:09:12 -05:00
tests("#describe_db_instances").formats(AWS::RDS::Formats::DESCRIBE_DB_INSTANCES) do
AWS[:rds].describe_db_instances.body
end
2011-02-27 16:09:12 -05:00
server = AWS[:rds].servers.get(@db_instance_id)
server.wait_for {ready?}
new_storage = 6
2011-02-27 16:09:12 -05:00
tests("#modify_db_instance with immediate apply").formats(AWS::RDS::Formats::MODIFY_DB_INSTANCE) do
body = AWS[:rds].modify_db_instance(@db_instance_id, true, 'AllocatedStorage'=> new_storage).body
2011-02-27 16:09:12 -05:00
tests 'pending storage' do
instance = body['ModifyDBInstanceResult']['DBInstance']
returns(new_storage){instance['PendingModifiedValues']['AllocatedStorage']}
2011-02-27 16:09:12 -05:00
end
body
2011-02-27 16:09:12 -05:00
end
server.wait_for { state == 'modifying' }
server.wait_for { state == 'available' }
2011-02-27 16:09:12 -05:00
tests 'new storage' do
returns(new_storage){ server.allocated_storage}
2011-02-27 16:09:12 -05:00
end
2011-02-27 16:09:12 -05:00
tests("reboot db instance") do
tests("#reboot").formats(AWS::RDS::Formats::REBOOT_DB_INSTANCE) do
AWS[:rds].reboot_db_instance(@db_instance_id).body
2011-02-27 16:09:12 -05:00
end
server.wait_for { state == 'rebooting' }
2011-02-27 16:09:12 -05:00
server.wait_for { state == 'available'}
end
2011-02-27 16:09:12 -05:00
tests("#create_db_snapshot").formats(AWS::RDS::Formats::CREATE_DB_SNAPSHOT) do
body = AWS[:rds].create_db_snapshot(@db_instance_id, @db_snapshot_id).body
2011-02-27 16:09:12 -05:00
returns('creating'){ body['CreateDBSnapshotResult']['DBSnapshot']['Status']}
body
end
2011-02-27 16:09:12 -05:00
tests("#describe_db_snapshots").formats(AWS::RDS::Formats::DESCRIBE_DB_SNAPSHOTS) do
body = AWS[:rds].describe_db_snapshots.body
2011-02-27 16:09:12 -05:00
end
2011-02-27 16:09:12 -05:00
tests( "#create read replica").formats(AWS::RDS::Formats::CREATE_READ_REPLICA) do
AWS[:rds].servers.get(@db_instance_id).wait_for { ready? }
2011-02-27 16:09:12 -05:00
AWS[:rds].create_db_instance_read_replica(@db_replica_id, @db_instance_id).body
end
2011-02-27 16:09:12 -05:00
replica = AWS[:rds].servers.get(@db_replica_id)
replica.wait_for {ready?}
2011-02-27 16:09:12 -05:00
tests("replica source") do
returns(@db_instance_id){replica.read_replica_source}
end
server.reload
2011-02-27 16:09:12 -05:00
tests("replica identifiers") do
returns([@db_replica_id]){server.read_replica_identifiers}
end
2011-02-27 16:09:12 -05:00
tests("#delete_db_instance").formats(AWS::RDS::Formats::DELETE_DB_INSTANCE) do
#server.wait_for { state == 'available'}
2011-02-27 16:09:12 -05:00
AWS[:rds].delete_db_instance(@db_replica_id, nil, true)
body = AWS[:rds].delete_db_instance(@db_instance_id, @db_final_snapshot_id).body
2011-02-27 16:09:12 -05:00
tests "final snapshot" do
returns('creating'){AWS[:rds].describe_db_snapshots(:snapshot_id => @db_final_snapshot_id).body['DescribeDBSnapshotsResult']['DBSnapshots'].first['Status']}
2011-02-27 16:09:12 -05:00
end
body
end
2011-02-27 16:09:12 -05:00
tests("#delete_db_snapshot").formats(AWS::RDS::Formats::DELETE_DB_SNAPSHOT) do
AWS[:rds].snapshots.get(@db_snapshot_id).wait_for { ready? }
AWS[:rds].delete_db_snapshot(@db_snapshot_id).body
end
tests("snapshot.destroy") do
snapshot = AWS[:rds].snapshots.get(@db_final_snapshot_id)
snapshot.wait_for { ready? }
snapshot.destroy
returns(nil) { AWS[:rds].snapshots.get(@db_final_snapshot_id) }
2011-02-27 16:09:12 -05:00
end
2011-02-27 16:09:12 -05:00
end
2011-02-27 16:09:12 -05:00
tests('failure') do
pending if Fog.mocking?
2011-02-27 16:09:12 -05:00
tests "deleting nonexisting instance" do
raises(Fog::AWS::RDS::NotFound) {AWS[:rds].delete_db_instance('doesnexist', 'irrelevant')}
2011-02-27 16:09:12 -05:00
end
tests "deleting non existing snapshot" do
raises(Fog::AWS::RDS::NotFound) {AWS[:rds].delete_db_snapshot('doesntexist')}
2011-02-27 16:09:12 -05:00
end
tests "modifying non existing instance" do
raises(Fog::AWS::RDS::NotFound) { AWS[:rds].modify_db_instance 'doesntexit', true, 'AllocatedStorage'=> 10}
end
end
end