quality: Add test cases for meter_mod message

This commit is contained in:
Eishun Kondoh 2019-04-29 03:07:31 +09:00
parent a0ee397921
commit c5e38155e1
4 changed files with 102 additions and 21 deletions

View file

@ -6,17 +6,17 @@ defmodule Openflow.MeterBand.Drop do
alias __MODULE__ alias __MODULE__
def new(options) do @type t :: %Drop{rate: 0..0xFFFFFFFF, burst_size: 0..0xFFFFFFFF}
rate = Keyword.get(options, :rate, 0)
burst_size = Keyword.get(options, :burst_size, 0)
%Drop{rate: rate, burst_size: burst_size}
end
def read(<<1::16, 16::16, rate::32, burst_size::32, _::size(4)-unit(8)>>) do @spec new(rate: 0..0xFFFFFFFF, burst_size: 0..0xFFFFFFFF) :: t()
%Drop{rate: rate, burst_size: burst_size} def new(options),
end do: %Drop{rate: options[:rate] || 0, burst_size: options[:burst_size] || 0}
def to_binary(%Drop{rate: rate, burst_size: burst_size}) do @spec read(<<_::128>>) :: t()
<<1::16, 16::16, rate::32, burst_size::32, 0::size(4)-unit(8)>> def read(<<1::16, 16::16, rate::32, burst_size::32, _::size(4)-unit(8)>>),
end do: %Drop{rate: rate, burst_size: burst_size}
@spec to_binary(t()) :: <<_::128>>
def to_binary(%Drop{rate: rate, burst_size: burst_size}),
do: <<1::16, 16::16, rate::32, burst_size::32, 0::size(4)-unit(8)>>
end end

View file

@ -7,18 +7,30 @@ defmodule Openflow.MeterBand.Remark do
alias __MODULE__ alias __MODULE__
@type t :: %Remark{
rate: 0..0xFFFFFFFF,
burst_size: 0..0xFFFFFFFF,
prec_level: 0..0xFF
}
@spec new(
rate: 0..0xFFFFFFFF,
burst_size: 0..0xFFFFFFFF,
prec_level: 0..0xFF
) :: t()
def new(options) do def new(options) do
rate = Keyword.get(options, :rate, 0) %Remark{
burst_size = Keyword.get(options, :burst_size, 0) rate: options[:rate] || 0,
prec_level = Keyword.get(options, :prec_level, 0) burst_size: options[:burst_size] || 0,
%Remark{rate: rate, burst_size: burst_size, prec_level: prec_level} prec_level: options[:prec_level] || 0
}
end end
def read(<<2::16, 16::16, rate::32, burst_size::32, prec_level::8, _::size(3)-unit(8)>>) do @spec read(<<_::128>>) :: t()
%Remark{rate: rate, burst_size: burst_size, prec_level: prec_level} def read(<<2::16, 16::16, rate::32, burst_size::32, prec_level::8, _::size(3)-unit(8)>>),
end do: %Remark{rate: rate, burst_size: burst_size, prec_level: prec_level}
def to_binary(%Remark{rate: rate, burst_size: burst_size, prec_level: prec_level}) do @spec to_binary(t()) :: <<_::128>>
<<2::16, 16::16, rate::32, burst_size::32, prec_level::8, 0::size(3)-unit(8)>> def to_binary(%Remark{rate: rate, burst_size: burst_size, prec_level: prec_level}),
end do: <<2::16, 16::16, rate::32, burst_size::32, prec_level::8, 0::size(3)-unit(8)>>
end end

View file

@ -12,10 +12,33 @@ defmodule Openflow.MeterMod do
alias __MODULE__ alias __MODULE__
@type command :: :add | :modify | :delete
@type t :: %MeterMod{
version: 4,
xid: 0..0xFFFFFFFF,
datapath_id: String.t() | nil,
aux_id: 0..0xFF | nil,
command: command(),
flags: [:kbps | :pktps | :burst | :stats],
bands: [Openflow.MeterBand.Drop.t() | Openflow.MeterBand.Remark.t()]
}
@spec ofp_type() :: 29
def ofp_type, do: 29 def ofp_type, do: 29
@spec new(
version: 4,
xid: 0..0xFFFFFFFF,
datapath_id: String.t() | nil,
aux_id: 0..0xFF | nil,
command: command(),
flags: [:kbps | :pktps | :burst | :stats],
bands: [Openflow.MeterBand.Drop.t() | Openflow.MeterBand.Remark.t()]
) :: t()
def new(options \\ []) do def new(options \\ []) do
%MeterMod{ %MeterMod{
xid: options[:xid] || 0,
command: options[:command] || :add, command: options[:command] || :add,
flags: options[:flags] || [], flags: options[:flags] || [],
meter_id: options[:meter_id] || 0, meter_id: options[:meter_id] || 0,
@ -23,6 +46,7 @@ defmodule Openflow.MeterMod do
} }
end end
@spec read(<<_::64, _::_*128>>) :: t()
def read(<<command_int::16, flags_int::16, meter_id_int::32, bands_bin::bytes>>) do def read(<<command_int::16, flags_int::16, meter_id_int::32, bands_bin::bytes>>) do
command = Openflow.Enums.to_atom(command_int, :meter_mod_command) command = Openflow.Enums.to_atom(command_int, :meter_mod_command)
flags = Openflow.Enums.int_to_flags(flags_int, :meter_flags) flags = Openflow.Enums.int_to_flags(flags_int, :meter_flags)
@ -31,6 +55,7 @@ defmodule Openflow.MeterMod do
%MeterMod{command: command, flags: flags, meter_id: meter_id, bands: bands} %MeterMod{command: command, flags: flags, meter_id: meter_id, bands: bands}
end end
@spec to_binary(t()) :: <<_::64, _::_*128>>
def to_binary(%MeterMod{command: command, flags: flags, meter_id: meter_id, bands: bands}) do def to_binary(%MeterMod{command: command, flags: flags, meter_id: meter_id, bands: bands}) do
command_int = Openflow.Enums.to_int(command, :meter_mod_command) command_int = Openflow.Enums.to_int(command, :meter_mod_command)
flags_int = Openflow.Enums.flags_to_int(flags, :meter_flags) flags_int = Openflow.Enums.flags_to_int(flags, :meter_flags)

View file

@ -0,0 +1,44 @@
defmodule OfpMeterModTest do
use ExUnit.Case
doctest Openflow
describe "Openflow.MeterMod" do
test "with packet_data" do
meter_mod =
"test/packet_data/libofproto-OFP13-meter_mod.packet"
|> File.read!()
|> Openflow.read()
|> Kernel.elem(1)
|> Map.to_list()
|> Openflow.MeterMod.new()
|> Openflow.to_binary()
|> Openflow.read()
|> Kernel.elem(1)
expect =
Openflow.MeterMod.new(
xid: 0,
meter_id: 100,
command: :add,
flags: [:pktps, :burst, :stats],
bands: [
Openflow.MeterBand.Drop.new(
burst_size: 10,
rate: 1000
),
Openflow.MeterBand.Remark.new(
burst_size: 10,
prec_level: 1,
rate: 1000
)
]
)
assert expect.xid == meter_mod.xid
assert expect.meter_id == meter_mod.meter_id
assert expect.command == meter_mod.command
assert expect.flags == meter_mod.flags
assert expect.bands == meter_mod.bands
end
end
end