quality: Add test cases for group_stats messages
This commit is contained in:
parent
2557778042
commit
87ff193b63
4 changed files with 89 additions and 18 deletions
|
|
@ -19,7 +19,7 @@ defmodule Openflow.GroupMod do
|
||||||
@type t :: %GroupMod{
|
@type t :: %GroupMod{
|
||||||
version: 4,
|
version: 4,
|
||||||
datapath_id: String.t() | nil,
|
datapath_id: String.t() | nil,
|
||||||
aux_id: 0..0xF | nil,
|
aux_id: 0..0xFF | nil,
|
||||||
xid: 0..0xFFFFFFFF,
|
xid: 0..0xFFFFFFFF,
|
||||||
command: command(),
|
command: command(),
|
||||||
type: type(),
|
type: type(),
|
||||||
|
|
|
||||||
|
|
@ -11,14 +11,21 @@ defmodule Openflow.Multipart.Group.Reply do
|
||||||
|
|
||||||
alias __MODULE__
|
alias __MODULE__
|
||||||
|
|
||||||
|
@type t :: %Reply{
|
||||||
|
version: 4,
|
||||||
|
xid: 0..0xFFFFFFFF,
|
||||||
|
datapath_id: String.t() | nil,
|
||||||
|
aux_id: 0..0xFF | nil,
|
||||||
|
flags: [:more],
|
||||||
|
groups: [Openflow.Multipart.GroupStats.t()]
|
||||||
|
}
|
||||||
|
|
||||||
|
@spec ofp_type() :: 18
|
||||||
def ofp_type, do: 18
|
def ofp_type, do: 18
|
||||||
|
|
||||||
def new(groups \\ []) do
|
@spec read(binary()) :: t()
|
||||||
%Reply{groups: groups}
|
|
||||||
end
|
|
||||||
|
|
||||||
def read(<<groups_bin::bytes>>) do
|
def read(<<groups_bin::bytes>>) do
|
||||||
groups = Openflow.Multipart.Group.read(groups_bin)
|
groups = Openflow.Multipart.GroupStats.read(groups_bin)
|
||||||
%Reply{groups: groups}
|
%Reply{groups: groups}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
@ -36,7 +43,7 @@ defmodule Openflow.Multipart.Group.Reply do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
defmodule Openflow.Multipart.Group do
|
defmodule Openflow.Multipart.GroupStats do
|
||||||
defstruct(
|
defstruct(
|
||||||
group_id: 0,
|
group_id: 0,
|
||||||
ref_count: 0,
|
ref_count: 0,
|
||||||
|
|
@ -51,6 +58,15 @@ defmodule Openflow.Multipart.Group do
|
||||||
|
|
||||||
alias __MODULE__
|
alias __MODULE__
|
||||||
|
|
||||||
|
@type t :: %GroupStats{
|
||||||
|
group_id: 0..0xFFFFFFFF,
|
||||||
|
ref_count: 0..0xFFFFFFFF,
|
||||||
|
packet_count: 0..0xFFFFFFFFFFFFFFFF,
|
||||||
|
byte_count: 0..0xFFFFFFFFFFFFFFFF,
|
||||||
|
duration_sec: 0..0xFFFFFFFF,
|
||||||
|
duration_nsec: 0..0xFFFFFFFF
|
||||||
|
}
|
||||||
|
|
||||||
def read(binary) do
|
def read(binary) do
|
||||||
do_read([], binary)
|
do_read([], binary)
|
||||||
end
|
end
|
||||||
|
|
@ -72,11 +88,10 @@ defmodule Openflow.Multipart.Group do
|
||||||
<<bucket_stats_bin::size(bucket_stats_size)-bytes, _rest::bytes>> = tail
|
<<bucket_stats_bin::size(bucket_stats_size)-bytes, _rest::bytes>> = tail
|
||||||
|
|
||||||
bucket_stats =
|
bucket_stats =
|
||||||
for <<packet_count::64, byte_count::64 <- bucket_stats_bin>> do
|
for <<packet_count::64, byte_count::64 <- bucket_stats_bin>>,
|
||||||
%{packet_count: packet_count, byte_count: byte_count}
|
do: %{packet_count: packet_count, byte_count: byte_count}
|
||||||
end
|
|
||||||
|
|
||||||
%Group{
|
%GroupStats{
|
||||||
group_id: group_id,
|
group_id: group_id,
|
||||||
ref_count: ref_count,
|
ref_count: ref_count,
|
||||||
packet_count: packet_count,
|
packet_count: packet_count,
|
||||||
|
|
|
||||||
|
|
@ -4,34 +4,43 @@ defmodule Openflow.Multipart.Group.Request do
|
||||||
xid: 0,
|
xid: 0,
|
||||||
# virtual field
|
# virtual field
|
||||||
datapath_id: nil,
|
datapath_id: nil,
|
||||||
|
aux_id: nil,
|
||||||
flags: [],
|
flags: [],
|
||||||
group_id: :all
|
group_id: :all
|
||||||
)
|
)
|
||||||
|
|
||||||
alias __MODULE__
|
alias __MODULE__
|
||||||
|
|
||||||
|
@type t :: %Request{
|
||||||
|
version: 4,
|
||||||
|
xid: 0..0xFFFFFFFF,
|
||||||
|
datapath_id: String.t() | nil,
|
||||||
|
aux_id: 0..0xFF | nil,
|
||||||
|
flags: [],
|
||||||
|
group_id: Openflow.GroupMod.id()
|
||||||
|
}
|
||||||
|
|
||||||
|
@spec ofp_type() :: 18
|
||||||
def ofp_type, do: 18
|
def ofp_type, do: 18
|
||||||
|
|
||||||
def new(options) when is_list(options) do
|
@spec new(xid: 0..0xFFFFFFFF, group_id: Openflow.GroupMod.id()) :: t()
|
||||||
|
def new(options \\ []) do
|
||||||
%Request{
|
%Request{
|
||||||
xid: options[:xid] || 0,
|
xid: options[:xid] || 0,
|
||||||
group_id: options[:group_id] || :all
|
group_id: options[:group_id] || :all
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def new(group_id) when is_integer(group_id) or is_atom(group_id) do
|
@spec read(<<_::32, _::_*8>>) :: t()
|
||||||
%Request{group_id: group_id}
|
|
||||||
end
|
|
||||||
|
|
||||||
def read(<<group_id_int::32, _::size(4)-unit(8)>>) do
|
def read(<<group_id_int::32, _::size(4)-unit(8)>>) do
|
||||||
group_id = Openflow.Utils.get_enum(group_id_int, :group_id)
|
group_id = Openflow.Utils.get_enum(group_id_int, :group_id)
|
||||||
%Request{group_id: group_id}
|
%Request{group_id: group_id}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@spec to_binary(t()) :: binary()
|
||||||
def to_binary(%Request{group_id: group_id} = msg) do
|
def to_binary(%Request{group_id: group_id} = msg) do
|
||||||
group_id_int = Openflow.Utils.get_enum(group_id, :group_id)
|
group_id_int = Openflow.Utils.get_enum(group_id, :group_id)
|
||||||
body_bin = <<group_id_int::32, 0::size(4)-unit(8)>>
|
|
||||||
header_bin = Openflow.Multipart.Request.header(msg)
|
header_bin = Openflow.Multipart.Request.header(msg)
|
||||||
<<header_bin::bytes, body_bin::bytes>>
|
<<header_bin::bytes, group_id_int::32, 0::size(4)-unit(8)>>
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
47
test/lib/openflow/ofp_group_stats_test.exs
Normal file
47
test/lib/openflow/ofp_group_stats_test.exs
Normal file
|
|
@ -0,0 +1,47 @@
|
||||||
|
defmodule OfpGroupStatsTest do
|
||||||
|
use ExUnit.Case
|
||||||
|
|
||||||
|
describe "Openflow.Multipart.Group.Request" do
|
||||||
|
test "with default values" do
|
||||||
|
group_stats =
|
||||||
|
%Openflow.Multipart.Group.Request{}
|
||||||
|
|> Map.to_list()
|
||||||
|
|> Openflow.Multipart.Group.Request.new()
|
||||||
|
|> Openflow.to_binary()
|
||||||
|
|> Openflow.read()
|
||||||
|
|> Kernel.elem(1)
|
||||||
|
|
||||||
|
assert group_stats.xid == 0
|
||||||
|
assert group_stats.group_id == :all
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe "Openflow.Multipart.Group.Reply" do
|
||||||
|
test "with test packet_data" do
|
||||||
|
group_stats =
|
||||||
|
"test/packet_data/4-58-ofp_group_stats_reply.packet"
|
||||||
|
|> File.read!()
|
||||||
|
|> Openflow.read()
|
||||||
|
|> Kernel.elem(1)
|
||||||
|
|
||||||
|
%Openflow.Multipart.Group.Reply{
|
||||||
|
aux_id: nil,
|
||||||
|
datapath_id: nil,
|
||||||
|
flags: [],
|
||||||
|
groups: [
|
||||||
|
%Openflow.Multipart.GroupStats{
|
||||||
|
bucket_stats: [%{byte_count: 2345, packet_count: 234}],
|
||||||
|
byte_count: 12345,
|
||||||
|
duration_nsec: 609_036_000,
|
||||||
|
duration_sec: 9,
|
||||||
|
group_id: 1,
|
||||||
|
packet_count: 123,
|
||||||
|
ref_count: 2
|
||||||
|
}
|
||||||
|
],
|
||||||
|
version: 4,
|
||||||
|
xid: 0
|
||||||
|
} = group_stats
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
Loading…
Add table
Add a link
Reference in a new issue