X-Git-Url: https://git.xandkar.net/?a=blobdiff_plain;f=test%2Fbeam_stats_consumer_statsd_SUITE.erl;h=20a2de7bb7dc92ad62d1951276e6f22caad59dce;hb=5acc9b7d2c0966e92e539f9906ae9f0786ae3389;hp=0f5f3d771e52961f84c06d2fc19f9ea96567e3d5;hpb=b0ab6ee2c0bea2f50a60d2260fc2e71dfb01320b;p=beam_stats.git diff --git a/test/beam_stats_consumer_statsd_SUITE.erl b/test/beam_stats_consumer_statsd_SUITE.erl index 0f5f3d7..20a2de7 100644 --- a/test/beam_stats_consumer_statsd_SUITE.erl +++ b/test/beam_stats_consumer_statsd_SUITE.erl @@ -1,5 +1,8 @@ -module(beam_stats_consumer_statsd_SUITE). +-include_lib("beam_stats/include/beam_stats.hrl"). +-include_lib("beam_stats/include/beam_stats_ets_table.hrl"). + -export( [ all/0 , groups/0 @@ -7,15 +10,10 @@ %% Test cases -export( - [ ct_test__beam_stats_to_bins/1 - , ct_test__memory_component_to_statsd_msg/1 - , ct_test__statsd_msg_add_name_prefix/1 - , ct_test__statsd_msg_to_bin/1 - , ct_test__node_id_to_bin/1 + [ t_send/1 ]). --define(statsd_module, beam_stats_consumer_statsd). --define(GROUP, ?statsd_module). +-define(GROUP, beam_stats_consumer_statsd). %% ============================================================================ %% Common Test callbacks @@ -26,11 +24,7 @@ all() -> groups() -> Tests = - [ ct_test__beam_stats_to_bins - , ct_test__memory_component_to_statsd_msg - , ct_test__statsd_msg_add_name_prefix - , ct_test__statsd_msg_to_bin - , ct_test__node_id_to_bin + [ t_send ], Properties = [], [{?GROUP, Properties, Tests}]. @@ -39,17 +33,71 @@ groups() -> %% Test cases %% ============================================================================= -ct_test__beam_stats_to_bins(_Cfg) -> - ?statsd_module:ct_test__beam_stats_to_bins(_Cfg). - -ct_test__memory_component_to_statsd_msg(_Cfg) -> - ?statsd_module:ct_test__memory_component_to_statsd_msg(_Cfg). - -ct_test__statsd_msg_add_name_prefix(_Cfg) -> - ?statsd_module:ct_test__statsd_msg_add_name_prefix(_Cfg). - -ct_test__statsd_msg_to_bin(_Cfg) -> - ?statsd_module:ct_test__statsd_msg_to_bin(_Cfg). - -ct_test__node_id_to_bin(_Cfg) -> - ?statsd_module:ct_test__node_id_to_bin(_Cfg). +t_send(_Cfg) -> + ETSTableStatsFoo = + #beam_stats_ets_table + { id = foo + , name = foo + , size = 5 + , memory = 25 + }, + ETSTableStatsBar = + #beam_stats_ets_table + { id = 37 + , name = bar + , size = 8 + , memory = 38 + }, + % TODO: Indent #beam_stats as #beam_stats_ets_table + BEAMStats = #beam_stats + { timestamp = {1, 2, 3} + , node_id = 'node_foo@host_bar' + , memory = [{mem_type_foo, 1}, {mem_type_bar, 2}, {mem_type_baz, 3}] + , io_bytes_in = 3 + , io_bytes_out = 7 + , context_switches = 5 + , reductions = 9 + , run_queue = 17 + , ets = [ETSTableStatsFoo, ETSTableStatsBar] + }, + ServerPort = 8125, + {ok, ServerSocket} = gen_udp:open(ServerPort, [binary, {active, false}]), + BEAMStatsQ = queue:in(BEAMStats, queue:new()), + Options = [{dst_port, ServerPort}], + {_, State1} = beam_stats_consumer_statsd:init(Options), + State2 = beam_stats_consumer_statsd:consume(BEAMStatsQ, State1), + {} = beam_stats_consumer_statsd:terminate(State2), + ResultOfReceive1 = gen_udp:recv(ServerSocket, 0), + {ok, {_, _, PacketReceived1}} = ResultOfReceive1, + ResultOfReceive2 = gen_udp:recv(ServerSocket, 0), + {ok, {_, _, PacketReceived2}} = ResultOfReceive2, + ok = gen_udp:close(ServerSocket), + ct:log("PacketReceived1: ~n~s~n", [PacketReceived1]), + ct:log("PacketReceived2: ~n~s~n", [PacketReceived2]), + PacketsCombined = <>, + ct:log("PacketsCombined: ~n~s~n", [PacketsCombined]), + MsgsExpected = + [ <<"beam_stats.node_foo_host_bar.io.bytes_in:3|g">> + , <<"beam_stats.node_foo_host_bar.io.bytes_out:7|g">> + , <<"beam_stats.node_foo_host_bar.context_switches:5|g">> + , <<"beam_stats.node_foo_host_bar.reductions:9|g">> + , <<"beam_stats.node_foo_host_bar.run_queue:17|g">> + , <<"beam_stats.node_foo_host_bar.memory.mem_type_foo:1|g">> + , <<"beam_stats.node_foo_host_bar.memory.mem_type_bar:2|g">> + , <<"beam_stats.node_foo_host_bar.memory.mem_type_baz:3|g">> + , <<"beam_stats.node_foo_host_bar.ets_table.size.foo.foo:5|g">> + , <<"beam_stats.node_foo_host_bar.ets_table.memory.foo.foo:25|g">> + , <<"beam_stats.node_foo_host_bar.ets_table.size.bar.37:8|g">> + , <<"beam_stats.node_foo_host_bar.ets_table.memory.bar.37:38|g">> + ], + MsgsReceived = binary:split(PacketsCombined, <<"\n">>, [global, trim]), + RemoveExpectedFromReceived = + fun (Expected, Received) -> + ct:log( + "Looking for expected msg ~p in remaining received ~p~n", + [Expected, Received] + ), + true = lists:member(Expected, Received), + Received -- [Expected] + end, + [] = lists:foldl(RemoveExpectedFromReceived, MsgsReceived, MsgsExpected).