mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
10c0b8006c
Server#modify and #create_read_replica allow options to be passed as symbols or strings. This allows the same hash of attributes to be used for creating & modifying servers. For example, the following lines are equivalent: server.modify(true, :allocated_storage => 10) server.modify(true, 'AllocatedStorage' => 10)
104 lines
3.4 KiB
Ruby
104 lines
3.4 KiB
Ruby
Shindo.tests("AWS::RDS | server", ['aws', 'rds']) do
|
|
|
|
pending if Fog.mocking?
|
|
|
|
model_tests(AWS[:rds].servers, rds_default_server_params, false) do
|
|
# We'll need this later; create it early to avoid waiting
|
|
@instance_with_final_snapshot = AWS[:rds].servers.create(rds_default_server_params.merge(:id => uniq_id("fog-snapshot-test"), :backup_retention_period => 1))
|
|
|
|
@instance.wait_for(20*60) { ready? }
|
|
|
|
tests('#snapshots') do
|
|
snapshot = nil
|
|
|
|
tests('#create').succeeds do
|
|
snapshot = @instance.snapshots.create(:id => 'fog-test-snapshot')
|
|
end
|
|
|
|
snapshot.wait_for {ready?}
|
|
|
|
@instance.reload
|
|
@instance.wait_for { ready? }
|
|
|
|
returns(true) { @instance.snapshots.map{|s| s.id}.include?(snapshot.id) }
|
|
snapshot.destroy
|
|
end
|
|
|
|
tests("#modify").succeeds do
|
|
orig_parameter_group = @instance.db_parameter_groups.first['DBParameterGroupName']
|
|
parameter_group = AWS[:rds].parameter_groups.create(:id => uniq_id, :family => 'mysql5.1', :description => 'fog-test')
|
|
|
|
orig_security_groups = @instance.db_security_groups.map{|h| h['DBSecurityGroupName']}
|
|
security_group = AWS[:rds].security_groups.create(:id => uniq_id, :description => 'fog-test')
|
|
|
|
modify_options = {
|
|
'DBParameterGroupName' => parameter_group.id,
|
|
'DBSecurityGroups' => orig_security_groups + [security_group.id]
|
|
}
|
|
|
|
@instance.modify(true, modify_options)
|
|
@instance.reload
|
|
|
|
returns(parameter_group.id, 'new parameter group') do
|
|
@instance.db_parameter_groups.first['DBParameterGroupName']
|
|
end
|
|
|
|
returns(true, "new security group") do
|
|
@instance.db_security_groups.any?{|hash| hash['DBSecurityGroupName'] == security_group.id}
|
|
end
|
|
|
|
@instance.reboot
|
|
@instance.reload.wait_for { state == 'rebooting' }
|
|
@instance.reload.wait_for { ready? }
|
|
|
|
# Restore back to original state using symbols
|
|
restore_options = {
|
|
:parameter_group_name => orig_parameter_group,
|
|
:security_group_names => orig_security_groups
|
|
}
|
|
@instance.modify(true, restore_options)
|
|
|
|
@instance.reboot
|
|
@instance.reload.wait_for { state == 'rebooting' }
|
|
@instance.reload.wait_for do
|
|
ready? &&
|
|
db_security_groups.all? {|hash| hash['Status'] == 'active'} &&
|
|
db_parameter_groups.all? {|hash| hash['ParameterApplyStatus'] == 'in-sync' }
|
|
end
|
|
|
|
parameter_group.destroy
|
|
security_group.destroy
|
|
end
|
|
|
|
tests("#reboot").succeeds do
|
|
@instance.reboot
|
|
end
|
|
@instance.reload.wait_for {state == 'rebooting'}
|
|
@instance.reload.wait_for { ready? }
|
|
|
|
tests('#create_read_replica').succeeds do
|
|
replica = @instance_with_final_snapshot.create_read_replica(uniq_id('fog-replica'))
|
|
@instance_with_final_snapshot.reload
|
|
returns([replica.id]) { @instance_with_final_snapshot.read_replica_identifiers }
|
|
returns(@instance_with_final_snapshot.id) { replica.read_replica_source }
|
|
|
|
replica.wait_for { ready? }
|
|
replica.destroy
|
|
end
|
|
|
|
test("Destroying with a final snapshot") do
|
|
final_snapshot_id = 'fog-test-snapshot'
|
|
|
|
@instance_with_final_snapshot.wait_for { ready? }
|
|
@instance_with_final_snapshot.destroy(final_snapshot_id)
|
|
returns(true, "Final snapshot created") do
|
|
@final_snapshot = AWS[:rds].snapshots.get(final_snapshot_id)
|
|
!@final_snapshot.nil?
|
|
end
|
|
|
|
@final_snapshot.wait_for { ready? }
|
|
@final_snapshot.destroy
|
|
end
|
|
|
|
end
|
|
end
|