1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
module Fog
module OpenStack
class Network
class Real
# Not all options can be updated
UPDATE_OPTIONS = [
:name,
:shared,
:admin_state_up,
:qos_policy_id,
:port_security_enabled
].freeze
# Not all extra options can be updated
UPDATE_EXTENTED_OPTIONS = [
:router_external
].freeze
def self.update(options)
data = {}
UPDATE_OPTIONS.select { |o| options.key?(o) }.each do |key|
data[key.to_s] = options[key]
end
UPDATE_EXTENTED_OPTIONS.reject { |o| options[o].nil? }.each do |key|
aliased_key = ALIASES[key] || key
data[aliased_key] = options[key]
end
data
end
def update_network(network_id, options = {})
data = {'network' => self.class.update(options)}
request(
:body => Fog::JSON.encode(data),
:expects => 200,
:method => 'PUT',
:path => "networks/#{network_id}.json"
)
end
end
class Mock
def update_network(network_id, options = {})
response = Excon::Response.new
if network = list_networks.body['networks'].find { |_| _['id'] == network_id }
network.merge!(Fog::OpenStack::Network::Real.update(options))
response.body = {'network' => network}
response.status = 200
response
else
raise Fog::OpenStack::Network::NotFound
end
end
end
end
end
end
|