mirror of
https://github.com/fog/fog-aws.git
synced 2022-11-09 13:50:52 -05:00
rds enhancements
* default engine parameters * mocks around parameter groups
This commit is contained in:
parent
b823dbf522
commit
f7849095b0
10 changed files with 169 additions and 6 deletions
|
@ -29,6 +29,12 @@ module Fog
|
||||||
end
|
end
|
||||||
load(result) # data is an array of attribute hashes
|
load(result) # data is an array of attribute hashes
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def defaults(family)
|
||||||
|
data = service.describe_engine_default_parameters(family).body['DescribeEngineDefaultParametersResult']['Parameters']
|
||||||
|
|
||||||
|
load(data)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
30
lib/fog/aws/parsers/rds/db_parameter_parser.rb
Normal file
30
lib/fog/aws/parsers/rds/db_parameter_parser.rb
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
module Fog
|
||||||
|
module Parsers
|
||||||
|
module AWS
|
||||||
|
module RDS
|
||||||
|
class DBParameterParser < Fog::Parsers::Base
|
||||||
|
def reset
|
||||||
|
@db_parameter = new_db_parameter
|
||||||
|
end
|
||||||
|
|
||||||
|
def new_db_parameter
|
||||||
|
{}
|
||||||
|
end
|
||||||
|
|
||||||
|
def start_element(name, attrs = [])
|
||||||
|
super
|
||||||
|
end
|
||||||
|
|
||||||
|
def end_element(name)
|
||||||
|
case name
|
||||||
|
when 'IsModifiable'
|
||||||
|
@value == "true" ? true : false
|
||||||
|
else
|
||||||
|
@db_parameter[name] = @value.strip
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,34 @@
|
||||||
|
module Fog
|
||||||
|
module Parsers
|
||||||
|
module AWS
|
||||||
|
module RDS
|
||||||
|
require 'fog/aws/parsers/rds/db_parameter_parser'
|
||||||
|
|
||||||
|
class DescribeEngineDefaultParameters < Fog::Parsers::AWS::RDS::DBParameterParser
|
||||||
|
def reset
|
||||||
|
@response = {'DescribeEngineDefaultParametersResult' => {'Parameters' => []}, 'ResponseMetadata' => {}}
|
||||||
|
super
|
||||||
|
end
|
||||||
|
|
||||||
|
def start_element(name, attrs = [])
|
||||||
|
super
|
||||||
|
end
|
||||||
|
|
||||||
|
def end_element(name)
|
||||||
|
case name
|
||||||
|
when 'Parameter'
|
||||||
|
@response['DescribeEngineDefaultParametersResult']['Parameters'] << @db_parameter
|
||||||
|
@db_parameter = new_db_parameter
|
||||||
|
when 'Marker'
|
||||||
|
@response['DescribeEngineDefaultParametersResult']['Marker'] = @value
|
||||||
|
when 'RequestId'
|
||||||
|
@response['ResponseMetadata'][name] = @value
|
||||||
|
else
|
||||||
|
super
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -62,6 +62,8 @@ module Fog
|
||||||
request :create_event_subscription
|
request :create_event_subscription
|
||||||
request :delete_event_subscription
|
request :delete_event_subscription
|
||||||
|
|
||||||
|
request :describe_engine_default_parameters
|
||||||
|
|
||||||
model_path 'fog/aws/models/rds'
|
model_path 'fog/aws/models/rds'
|
||||||
model :server
|
model :server
|
||||||
collection :servers
|
collection :servers
|
||||||
|
@ -100,6 +102,18 @@ module Fog
|
||||||
:subnet_groups => {},
|
:subnet_groups => {},
|
||||||
:snapshots => {},
|
:snapshots => {},
|
||||||
:event_subscriptions => {},
|
:event_subscriptions => {},
|
||||||
|
:default_parameters => {
|
||||||
|
"mysql5.5" => [
|
||||||
|
{
|
||||||
|
"DataType" => "integer",
|
||||||
|
"Source" => "engine-default",
|
||||||
|
"Description" => "Intended for use with master-to-master replication, and can be used to control the operation of AUTO_INCREMENT columns",
|
||||||
|
"ApplyType" => "dynamic",
|
||||||
|
"AllowedValues" => "1-65535",
|
||||||
|
"ParameterName" => "auto_increment_increment"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
},
|
||||||
:db_engine_versions => [
|
:db_engine_versions => [
|
||||||
{
|
{
|
||||||
'Engine' => "mysql",
|
'Engine' => "mysql",
|
||||||
|
|
|
@ -84,6 +84,16 @@ module Fog
|
||||||
|
|
||||||
ec2 = Fog::Compute::AWS::Mock.data[@region][@aws_access_key_id]
|
ec2 = Fog::Compute::AWS::Mock.data[@region][@aws_access_key_id]
|
||||||
|
|
||||||
|
db_parameter_groups = if pg_name = options.delete("DBParameterGroupName")
|
||||||
|
group = self.data[:parameter_groups][pg_name]
|
||||||
|
if group
|
||||||
|
[{"DBParameterGroupName" => pg_name, "ParameterApplyStatus" => "in-sync" }]
|
||||||
|
else
|
||||||
|
raise Fog::AWS::RDS::NotFound.new("Parameter group does not exist")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
[{ "DBParameterGroupName" => "default.mysql5.5", "ParameterApplyStatus" => "in-sync" }]
|
||||||
|
end
|
||||||
db_security_group_names = Array(options.delete("DBSecurityGroups"))
|
db_security_group_names = Array(options.delete("DBSecurityGroups"))
|
||||||
rds_security_groups = self.data[:security_groups].values
|
rds_security_groups = self.data[:security_groups].values
|
||||||
ec2_security_groups = ec2[:security_groups].values
|
ec2_security_groups = ec2[:security_groups].values
|
||||||
|
@ -119,7 +129,7 @@ module Fog
|
||||||
"DBInstanceIdentifier" => db_name,
|
"DBInstanceIdentifier" => db_name,
|
||||||
"DBInstanceStatus" =>"creating",
|
"DBInstanceStatus" =>"creating",
|
||||||
"DBName" => options["DBName"],
|
"DBName" => options["DBName"],
|
||||||
"DBParameterGroups" => [{ "DBParameterGroupName" => "default.mysql5.5", "ParameterApplyStatus" => "in-sync" }],
|
"DBParameterGroups" => db_parameter_groups,
|
||||||
"DBSecurityGroups" => db_security_groups,
|
"DBSecurityGroups" => db_security_groups,
|
||||||
"DBSubnetGroupName" => options["DBSubnetGroupName"],
|
"DBSubnetGroupName" => options["DBSubnetGroupName"],
|
||||||
"Endpoint" =>{},
|
"Endpoint" =>{},
|
||||||
|
|
|
@ -34,7 +34,21 @@ module Fog
|
||||||
|
|
||||||
class Mock
|
class Mock
|
||||||
def describe_db_parameters(name, opts={})
|
def describe_db_parameters(name, opts={})
|
||||||
Fog::Mock.not_implemented
|
group = self.data[:parameter_groups][name]
|
||||||
|
|
||||||
|
unless group
|
||||||
|
raise Fog::AWS::RDS::NotFound.new("parameter group does not exist")
|
||||||
|
end
|
||||||
|
|
||||||
|
parameters = group[:parameters]
|
||||||
|
|
||||||
|
response = Excon::Response.new
|
||||||
|
response.body = {
|
||||||
|
"ResponseMetadata" => { "RequestId" => Fog::AWS::Mock.request_id },
|
||||||
|
"DescribeDBParametersResult" => { "Parameters" => parameters }
|
||||||
|
}
|
||||||
|
response.status = 200
|
||||||
|
response
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,30 @@
|
||||||
|
module Fog
|
||||||
|
module AWS
|
||||||
|
class RDS
|
||||||
|
class Real
|
||||||
|
require 'fog/aws/parsers/rds/describe_engine_default_parameters'
|
||||||
|
|
||||||
|
def describe_engine_default_parameters(family, opts={})
|
||||||
|
request({
|
||||||
|
'Action' => 'DescribeEngineDefaultParameters',
|
||||||
|
'DBParameterGroupFamily' => family,
|
||||||
|
:parser => Fog::Parsers::AWS::RDS::DescribeEngineDefaultParameters.new,
|
||||||
|
}.merge(opts))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class Mock
|
||||||
|
def describe_engine_default_parameters(family, opts={})
|
||||||
|
response = Excon::Response.new
|
||||||
|
|
||||||
|
response.status = 200
|
||||||
|
response.body = {
|
||||||
|
"ResponseMetadata" => { "RequestId" => Fog::AWS::Mock.request_id },
|
||||||
|
"DescribeEngineDefaultParametersResult" => { "Parameters" => self.data[:default_parameters][family]}
|
||||||
|
}
|
||||||
|
response
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -42,7 +42,34 @@ module Fog
|
||||||
|
|
||||||
class Mock
|
class Mock
|
||||||
def modify_db_parameter_group(group_name, parameters)
|
def modify_db_parameter_group(group_name, parameters)
|
||||||
Fog::Mock.not_implemented
|
group = self.data[:parameter_groups][group_name]
|
||||||
|
|
||||||
|
unless group
|
||||||
|
raise Fog::AWS::RDS::NotFound.new("Parameter group not found")
|
||||||
|
end
|
||||||
|
|
||||||
|
parameters.each do |p|
|
||||||
|
p.merge!(
|
||||||
|
"Source" => "user",
|
||||||
|
"IsModifiable" => true,
|
||||||
|
"Description" => "some string",
|
||||||
|
"DataType" => "string",
|
||||||
|
"AllowedValues" => p["ParameterValue"],
|
||||||
|
"ApplyType" => "dynamic"
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
group[:parameters] = parameters
|
||||||
|
|
||||||
|
self.data[:parameter_groups][group_name] = group
|
||||||
|
|
||||||
|
response = Excon::Response.new
|
||||||
|
response.body = {
|
||||||
|
"ResponseMetadata" => {"RequestId" => Fog::AWS::Mock.request_id},
|
||||||
|
"ModifyDBParameterGroupResult" => {"DBParameterGroupName" => group_name}
|
||||||
|
}
|
||||||
|
response.status = 200
|
||||||
|
response
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -21,7 +21,7 @@ Shindo.tests('AWS::RDS | parameter group requests', ['aws', 'rds']) do
|
||||||
body
|
body
|
||||||
end
|
end
|
||||||
|
|
||||||
tests("#describe_db_parameter_groups('fog-group)").formats(AWS::RDS::Formats::DESCRIBE_DB_PARAMETER_GROUP) do
|
tests("#describe_db_parameter_groups('fog-group')").formats(AWS::RDS::Formats::DESCRIBE_DB_PARAMETER_GROUP) do
|
||||||
|
|
||||||
body = Fog::AWS[:rds].describe_db_parameter_groups('fog-group').body
|
body = Fog::AWS[:rds].describe_db_parameter_groups('fog-group').body
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
Shindo.tests('AWS::RDS | parameter requests', ['aws', 'rds']) do
|
Shindo.tests('AWS::RDS | parameter requests', ['aws', 'rds']) do
|
||||||
tests('success') do
|
tests('success') do
|
||||||
pending if Fog.mocking?
|
|
||||||
|
|
||||||
Fog::AWS[:rds].create_db_parameter_group('fog-group', 'MySQL5.1', 'Some description')
|
Fog::AWS[:rds].create_db_parameter_group('fog-group', 'MySQL5.1', 'Some description')
|
||||||
|
|
||||||
tests('#modify_db_parameter_group').formats(AWS::RDS::Formats::MODIFY_PARAMETER_GROUP) do
|
tests('#modify_db_parameter_group').formats(AWS::RDS::Formats::MODIFY_PARAMETER_GROUP) do
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue