mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
58 lines
2.1 KiB
Ruby
58 lines
2.1 KiB
Ruby
Shindo.tests('HP::Network | networking security group rule requests', ['hp', 'networking', 'securitygroup']) do
|
|
|
|
@security_group_rule_format = {
|
|
'id' => String,
|
|
'remote_group_id' => Fog::Nullable::String,
|
|
'direction' => String,
|
|
'remote_ip_prefix' => Fog::Nullable::String,
|
|
'protocol' => Fog::Nullable::String,
|
|
'ethertype' => String,
|
|
'port_range_max' => Fog::Nullable::Integer,
|
|
'port_range_min' => Fog::Nullable::Integer,
|
|
'security_group_id' => String,
|
|
'tenant_id' => String
|
|
}
|
|
|
|
tests('success') do
|
|
|
|
attributes = {:name => 'my_security_group', :description => 'tests group'}
|
|
data = HP[:network].create_security_group(attributes).body['security_group']
|
|
@sec_group_id = data['id']
|
|
|
|
@sec_group_rule_id = nil
|
|
|
|
tests("#create_security_group_rule(#{@sec_group_id}, 'ingress', attributes)").formats(@security_group_rule_format) do
|
|
attributes = {:remote_ip_prefix => '0.0.0.0/0', :protocol => 'tcp', :port_range_min => 22, :port_range_max => 22}
|
|
data = HP[:network].create_security_group_rule(@sec_group_id, 'ingress', attributes).body['security_group_rule']
|
|
@sec_group_rule_id = data['id']
|
|
data
|
|
end
|
|
|
|
tests("#get_security_group_rule('#{@sec_group_rule_id}')").formats(@security_group_rule_format) do
|
|
HP[:network].get_security_group_rule(@sec_group_rule_id).body['security_group_rule']
|
|
end
|
|
|
|
tests("#list_security_group_rules").formats('security_group_rules' => [@security_group_rule_format]) do
|
|
HP[:network].list_security_group_rules.body
|
|
end
|
|
|
|
tests("#delete_security_group_rule('#{@sec_group_rule_id}')").succeeds do
|
|
HP[:network].delete_security_group_rule(@sec_group_rule_id)
|
|
end
|
|
|
|
end
|
|
|
|
tests('failure') do
|
|
|
|
tests('#get_security_group_rule(0)').raises(Fog::HP::Network::NotFound) do
|
|
HP[:network].get_security_group_rule(0)
|
|
end
|
|
|
|
tests('#delete_security_group_rule(0)').raises(Fog::HP::Network::NotFound) do
|
|
HP[:network].delete_security_group_rule(0)
|
|
end
|
|
|
|
end
|
|
|
|
HP[:network].delete_security_group(@sec_group_id)
|
|
end
|