quality: Add test cases for meter stats messages
This commit is contained in:
parent
b5d0a5654a
commit
2e3f772b1f
3 changed files with 48 additions and 42 deletions
|
|
@ -12,11 +12,7 @@ defmodule Openflow.Multipart.Meter.Request do
|
||||||
|
|
||||||
def ofp_type, do: 18
|
def ofp_type, do: 18
|
||||||
|
|
||||||
def new(meter_id) when is_integer(meter_id) or is_atom(meter_id) do
|
def new(options \\ []) do
|
||||||
%Request{meter_id: meter_id}
|
|
||||||
end
|
|
||||||
|
|
||||||
def new(options) when is_list(options) do
|
|
||||||
%Request{
|
%Request{
|
||||||
xid: options[:xid] || 0,
|
xid: options[:xid] || 0,
|
||||||
meter_id: options[:meter_id] || :all
|
meter_id: options[:meter_id] || :all
|
||||||
|
|
|
||||||
|
|
@ -1,37 +0,0 @@
|
||||||
defmodule Openflow.Multipart.MeterConfig.Request do
|
|
||||||
defstruct(
|
|
||||||
version: 4,
|
|
||||||
xid: 0,
|
|
||||||
# virtual field
|
|
||||||
datapath_id: nil,
|
|
||||||
flags: [],
|
|
||||||
meter_id: :all
|
|
||||||
)
|
|
||||||
|
|
||||||
alias __MODULE__
|
|
||||||
|
|
||||||
def ofp_type, do: 18
|
|
||||||
|
|
||||||
def new(meter_id) when is_integer(meter_id) or is_atom(meter_id) do
|
|
||||||
%Request{meter_id: meter_id}
|
|
||||||
end
|
|
||||||
|
|
||||||
def new(options) when is_list(options) do
|
|
||||||
%Request{
|
|
||||||
xid: options[:xid] || 0,
|
|
||||||
meter_id: options[:meter_id] || :all
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
def read(<<meter_id_int::32, _::size(4)-unit(8)>>) do
|
|
||||||
meter_id = Openflow.Utils.get_enum(meter_id_int, :meter_id)
|
|
||||||
%Request{meter_id: meter_id}
|
|
||||||
end
|
|
||||||
|
|
||||||
def to_binary(%Request{meter_id: meter_id} = msg) do
|
|
||||||
meter_id_int = Openflow.Utils.get_enum(meter_id, :meter_id)
|
|
||||||
body_bin = <<meter_id_int::32, 0::size(4)-unit(8)>>
|
|
||||||
header_bin = Openflow.Multipart.Request.header(msg)
|
|
||||||
<<header_bin::bytes, body_bin::bytes>>
|
|
||||||
end
|
|
||||||
end
|
|
||||||
47
test/lib/openflow/ofp_meter_stats_test.exs
Normal file
47
test/lib/openflow/ofp_meter_stats_test.exs
Normal file
|
|
@ -0,0 +1,47 @@
|
||||||
|
defmodule OfpMeterStatsTest do
|
||||||
|
use ExUnit.Case
|
||||||
|
|
||||||
|
describe "Openflow.Multipart.Meter.Request" do
|
||||||
|
test "with default values" do
|
||||||
|
meter_stats =
|
||||||
|
%Openflow.Multipart.Meter.Request{}
|
||||||
|
|> Map.to_list()
|
||||||
|
|> Openflow.Multipart.Meter.Request.new()
|
||||||
|
|> Openflow.to_binary()
|
||||||
|
|> Openflow.read()
|
||||||
|
|> Kernel.elem(1)
|
||||||
|
|
||||||
|
assert meter_stats.xid == 0
|
||||||
|
assert meter_stats.meter_id == :all
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "Openflow.Multipart.Meter.Reply" do
|
||||||
|
test "with test packet_data" do
|
||||||
|
meter_stats =
|
||||||
|
"test/packet_data/4-50-ofp_meter_stats_reply.packet"
|
||||||
|
|> File.read!()
|
||||||
|
|> Openflow.read()
|
||||||
|
|> Kernel.elem(1)
|
||||||
|
|
||||||
|
%Openflow.Multipart.Meter.Reply{
|
||||||
|
aux_id: nil,
|
||||||
|
datapath_id: nil,
|
||||||
|
flags: [],
|
||||||
|
meters: [
|
||||||
|
%Openflow.Multipart.Meter{
|
||||||
|
band_stats: [%{byte_band_count: 0, packet_band_count: 0}],
|
||||||
|
byte_in_count: 0,
|
||||||
|
duration_nsec: 480000,
|
||||||
|
duration_sec: 0,
|
||||||
|
flow_count: 0,
|
||||||
|
meter_id: 100,
|
||||||
|
packet_in_count: 0
|
||||||
|
}
|
||||||
|
],
|
||||||
|
version: 4,
|
||||||
|
xid: 0
|
||||||
|
} = meter_stats
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
Loading…
Add table
Add a link
Reference in a new issue