1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00
fog--fog/lib/fog/aws/requests/elasticache/create_cache_security_group.rb
Brian Nelson 8948156ee0 More fixes to AWS::Elasticache mocking
* Implemented recommendations from @jbence review
 * Enabled tests which revealed a bug in create_cache_security_group response
2013-09-08 18:36:35 -07:00

54 lines
1.6 KiB
Ruby

module Fog
module AWS
class Elasticache
class Real
require 'fog/aws/parsers/elasticache/single_security_group'
# creates a cache security group
#
# === Parameters
# * name <~String> - The name for the Cache Security Group
# * description <~String> - The description for the Cache Security Group
# === Returns
# * response <~Excon::Response>:
# * body <~Hash>
def create_cache_security_group(name, description = name)
request({
'Action' => 'CreateCacheSecurityGroup',
'CacheSecurityGroupName' => name,
'Description' => description,
:parser => Fog::Parsers::AWS::Elasticache::SingleSecurityGroup.new
})
end
end
class Mock
def create_cache_security_group(name, description = name)
if self.data[:security_groups][name]
raise Fog::AWS::Elasticache::IdentifierTaken.new("CacheClusterAlreadyExists => The security group '#{name}' already exists")
end
data = {
'CacheSecurityGroupName' => name,
'Description' => description,
'EC2SecurityGroups' => [],
'OwnerId' => '0123456789'
}
self.data[:security_groups][name] = data
Excon::Response.new(
{
:body => {
'ResponseMetadata'=>{ 'RequestId'=> Fog::AWS::Mock.request_id },
'CacheSecurityGroup' => data
}
}
)
end
end
end
end
end