package logstash import ( "fmt" "net" "net/http" "net/http/httptest" "net/url" "testing" "github.com/influxdata/telegraf/testutil" "github.com/stretchr/testify/assert" ) var logstashTest = NewLogstash() var ( logstash5accPipelineStats testutil.Accumulator logstash6accPipelinesStats testutil.Accumulator logstash5accProcessStats testutil.Accumulator logstash6accProcessStats testutil.Accumulator logstash5accJVMStats testutil.Accumulator logstash6accJVMStats testutil.Accumulator ) func Test_Logstash5GatherProcessStats(test *testing.T) { fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash5ProcessJSON)) })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } if err := logstashTest.gatherProcessStats(logstashTest.URL+processStats, &logstash5accProcessStats); err != nil { test.Logf("Can't gather Process stats") } logstash5accProcessStats.AssertContainsTaggedFields( test, "logstash_process", map[string]interface{}{ "open_file_descriptors": float64(89.0), "max_file_descriptors": float64(1.048576e+06), "cpu_percent": float64(3.0), "cpu_load_average_5m": float64(0.61), "cpu_load_average_15m": float64(0.54), "mem_total_virtual_in_bytes": float64(4.809506816e+09), "cpu_total_in_millis": float64(1.5526e+11), "cpu_load_average_1m": float64(0.49), "peak_open_file_descriptors": float64(100.0), }, map[string]string{ "node_id": string("a360d8cf-6289-429d-8419-6145e324b574"), "node_name": string("node-5-test"), "node_host": string("node-5"), "node_version": string("5.3.0"), }, ) } func Test_Logstash6GatherProcessStats(test *testing.T) { fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash6ProcessJSON)) })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } if err := logstashTest.gatherProcessStats(logstashTest.URL+processStats, &logstash6accProcessStats); err != nil { test.Logf("Can't gather Process stats") } logstash6accProcessStats.AssertContainsTaggedFields( test, "logstash_process", map[string]interface{}{ "open_file_descriptors": float64(133.0), "max_file_descriptors": float64(262144.0), "cpu_percent": float64(0.0), "cpu_load_average_5m": float64(42.4), "cpu_load_average_15m": float64(38.95), "mem_total_virtual_in_bytes": float64(17923452928.0), "cpu_total_in_millis": float64(5841460), "cpu_load_average_1m": float64(48.2), "peak_open_file_descriptors": float64(145.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), }, ) } func Test_Logstash5GatherPipelineStats(test *testing.T) { //logstash5accPipelineStats.SetDebug(true) fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash5PipelineJSON)) })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } if err := logstashTest.gatherPipelineStats(logstashTest.URL+pipelineStats, &logstash5accPipelineStats); err != nil { test.Logf("Can't gather Pipeline stats") } logstash5accPipelineStats.AssertContainsTaggedFields( test, "logstash_events", map[string]interface{}{ "duration_in_millis": float64(1151.0), "in": float64(1269.0), "filtered": float64(1269.0), "out": float64(1269.0), }, map[string]string{ "node_id": string("a360d8cf-6289-429d-8419-6145e324b574"), "node_name": string("node-5-test"), "node_host": string("node-5"), "node_version": string("5.3.0"), }, ) fields := make(map[string]interface{}) fields["queue_push_duration_in_millis"] = float64(32.0) fields["out"] = float64(2.0) logstash5accPipelineStats.AssertContainsTaggedFields( test, "logstash_plugins", fields, map[string]string{ "node_id": string("a360d8cf-6289-429d-8419-6145e324b574"), "node_name": string("node-5-test"), "node_host": string("node-5"), "node_version": string("5.3.0"), "plugin_name": string("beats"), "plugin_id": string("a35197a509596954e905e38521bae12b1498b17d-1"), "plugin_type": string("input"), }, ) logstash5accPipelineStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(360.0), "in": float64(1269.0), "out": float64(1269.0), }, map[string]string{ "node_id": string("a360d8cf-6289-429d-8419-6145e324b574"), "node_name": string("node-5-test"), "node_host": string("node-5"), "node_version": string("5.3.0"), "plugin_name": string("stdout"), "plugin_id": string("582d5c2becb582a053e1e9a6bcc11d49b69a6dfd-2"), "plugin_type": string("output"), }, ) logstash5accPipelineStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(228.0), "in": float64(1269.0), "out": float64(1269.0), }, map[string]string{ "node_id": string("a360d8cf-6289-429d-8419-6145e324b574"), "node_name": string("node-5-test"), "node_host": string("node-5"), "node_version": string("5.3.0"), "plugin_name": string("s3"), "plugin_id": string("582d5c2becb582a053e1e9a6bcc11d49b69a6dfd-3"), "plugin_type": string("output"), }, ) } func Test_Logstash6GatherPipelinesStats(test *testing.T) { //logstash6accPipelinesStats.SetDebug(true) fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash6PipelinesJSON)) })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } if err := logstashTest.gatherPipelinesStats(logstashTest.URL+pipelineStats, &logstash6accPipelinesStats); err != nil { test.Logf("Can't gather Pipeline stats") } fields := make(map[string]interface{}) fields["duration_in_millis"] = float64(8540751.0) fields["queue_push_duration_in_millis"] = float64(366.0) fields["in"] = float64(180659.0) fields["filtered"] = float64(180659.0) fields["out"] = float64(180659.0) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_events", fields, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), }, ) fields = make(map[string]interface{}) fields["queue_push_duration_in_millis"] = float64(366.0) fields["out"] = float64(180659.0) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", fields, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("kafka"), "plugin_id": string("input-kafka"), "plugin_type": string("input"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(2117.0), "in": float64(27641.0), "out": float64(27641.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("mutate"), "plugin_id": string("155b0ad18abbf3df1e0cb7bddef0d77c5ba699efe5a0f8a28502d140549baf54"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(2117.0), "in": float64(27641.0), "out": float64(27641.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("mutate"), "plugin_id": string("155b0ad18abbf3df1e0cb7bddef0d77c5ba699efe5a0f8a28502d140549baf54"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(13149.0), "in": float64(180659.0), "out": float64(177549.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("date"), "plugin_id": string("d079424bb6b7b8c7c61d9c5e0ddae445e92fa9ffa2e8690b0a669f7c690542f0"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(2814.0), "in": float64(76602.0), "out": float64(76602.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("mutate"), "plugin_id": string("25afa60ab6dc30512fe80efa3493e4928b5b1b109765b7dc46a3e4bbf293d2d4"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(9.0), "in": float64(934.0), "out": float64(934.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("mutate"), "plugin_id": string("2d9fa8f74eeb137bfa703b8050bad7d76636fface729e4585b789b5fc9bed668"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(173.0), "in": float64(3110.0), "out": float64(0.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("drop"), "plugin_id": string("4ed14c9ef0198afe16c31200041e98d321cb5c2e6027e30b077636b8c4842110"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(5605.0), "in": float64(75482.0), "out": float64(75482.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("mutate"), "plugin_id": string("358ce1eb387de7cd5711c2fb4de64cd3b12e5ca9a4c45f529516bcb053a31df4"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(313992.0), "in": float64(180659.0), "out": float64(180659.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("csv"), "plugin_id": string("82a9bbb02fff37a63c257c1f146b0a36273c7cbbebe83c0a51f086e5280bf7bb"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(0.0), "in": float64(0.0), "out": float64(0.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("mutate"), "plugin_id": string("8fb13a8cdd4257b52724d326aa1549603ffdd4e4fde6d20720c96b16238c18c3"), "plugin_type": string("filter"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(651386.0), "in": float64(177549.0), "out": float64(177549.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("elasticsearch"), "plugin_id": string("output-elk"), "plugin_type": string("output"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(186751.0), "in": float64(177549.0), "out": float64(177549.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("kafka"), "plugin_id": string("output-kafka1"), "plugin_type": string("output"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_plugins", map[string]interface{}{ "duration_in_millis": float64(7335196.0), "in": float64(177549.0), "out": float64(177549.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "plugin_name": string("kafka"), "plugin_id": string("output-kafka2"), "plugin_type": string("output"), }, ) logstash6accPipelinesStats.AssertContainsTaggedFields( test, "logstash_queue", map[string]interface{}{ "events": float64(103), "free_space_in_bytes": float64(36307369984), "max_queue_size_in_bytes": float64(1073741824), "max_unread_events": float64(0), "page_capacity_in_bytes": float64(67108864), "queue_size_in_bytes": float64(1872391), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), "pipeline": string("main"), "queue_type": string("persisted"), }, ) } func Test_Logstash5GatherJVMStats(test *testing.T) { fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash5JvmJSON)) })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } if err := logstashTest.gatherJVMStats(logstashTest.URL+jvmStats, &logstash5accJVMStats); err != nil { test.Logf("Can't gather JVM stats") } logstash5accJVMStats.AssertContainsTaggedFields( test, "logstash_jvm", map[string]interface{}{ "mem_pools_young_max_in_bytes": float64(5.5836672e+08), "mem_pools_young_committed_in_bytes": float64(1.43261696e+08), "mem_heap_committed_in_bytes": float64(5.1904512e+08), "threads_count": float64(29.0), "mem_pools_old_peak_used_in_bytes": float64(1.27900864e+08), "mem_pools_old_peak_max_in_bytes": float64(7.2482816e+08), "mem_heap_used_percent": float64(16.0), "gc_collectors_young_collection_time_in_millis": float64(3235.0), "mem_pools_survivor_committed_in_bytes": float64(1.7825792e+07), "mem_pools_young_used_in_bytes": float64(7.6049384e+07), "mem_non_heap_committed_in_bytes": float64(2.91487744e+08), "mem_pools_survivor_peak_max_in_bytes": float64(3.4865152e+07), "mem_pools_young_peak_max_in_bytes": float64(2.7918336e+08), "uptime_in_millis": float64(4.803461e+06), "mem_pools_survivor_peak_used_in_bytes": float64(8.912896e+06), "mem_pools_survivor_max_in_bytes": float64(6.9730304e+07), "gc_collectors_old_collection_count": float64(2.0), "mem_pools_survivor_used_in_bytes": float64(9.419672e+06), "mem_pools_old_used_in_bytes": float64(2.55801728e+08), "mem_pools_old_max_in_bytes": float64(1.44965632e+09), "mem_pools_young_peak_used_in_bytes": float64(7.1630848e+07), "mem_heap_used_in_bytes": float64(3.41270784e+08), "mem_heap_max_in_bytes": float64(2.077753344e+09), "gc_collectors_young_collection_count": float64(616.0), "threads_peak_count": float64(31.0), "mem_pools_old_committed_in_bytes": float64(3.57957632e+08), "gc_collectors_old_collection_time_in_millis": float64(114.0), "mem_non_heap_used_in_bytes": float64(2.68905936e+08), }, map[string]string{ "node_id": string("a360d8cf-6289-429d-8419-6145e324b574"), "node_name": string("node-5-test"), "node_host": string("node-5"), "node_version": string("5.3.0"), }, ) } func Test_Logstash6GatherJVMStats(test *testing.T) { fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash6JvmJSON)) })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } if err := logstashTest.gatherJVMStats(logstashTest.URL+jvmStats, &logstash6accJVMStats); err != nil { test.Logf("Can't gather JVM stats") } logstash6accJVMStats.AssertContainsTaggedFields( test, "logstash_jvm", map[string]interface{}{ "mem_pools_young_max_in_bytes": float64(1605304320.0), "mem_pools_young_committed_in_bytes": float64(71630848.0), "mem_heap_committed_in_bytes": float64(824963072.0), "threads_count": float64(60.0), "mem_pools_old_peak_used_in_bytes": float64(696572600.0), "mem_pools_old_peak_max_in_bytes": float64(6583418880.0), "mem_heap_used_percent": float64(2.0), "gc_collectors_young_collection_time_in_millis": float64(107321.0), "mem_pools_survivor_committed_in_bytes": float64(8912896.0), "mem_pools_young_used_in_bytes": float64(11775120.0), "mem_non_heap_committed_in_bytes": float64(222986240.0), "mem_pools_survivor_peak_max_in_bytes": float64(200605696), "mem_pools_young_peak_max_in_bytes": float64(1605304320.0), "uptime_in_millis": float64(281850926.0), "mem_pools_survivor_peak_used_in_bytes": float64(8912896.0), "mem_pools_survivor_max_in_bytes": float64(200605696.0), "gc_collectors_old_collection_count": float64(37.0), "mem_pools_survivor_used_in_bytes": float64(835008.0), "mem_pools_old_used_in_bytes": float64(189750576.0), "mem_pools_old_max_in_bytes": float64(6583418880.0), "mem_pools_young_peak_used_in_bytes": float64(71630848.0), "mem_heap_used_in_bytes": float64(202360704.0), "mem_heap_max_in_bytes": float64(8389328896.0), "gc_collectors_young_collection_count": float64(2094.0), "threads_peak_count": float64(62.0), "mem_pools_old_committed_in_bytes": float64(744419328.0), "gc_collectors_old_collection_time_in_millis": float64(7492.0), "mem_non_heap_used_in_bytes": float64(197878896.0), }, map[string]string{ "node_id": string("3044f675-21ce-4335-898a-8408aa678245"), "node_name": string("node-6-test"), "node_host": string("node-6"), "node_version": string("6.4.2"), }, ) } func Test_LogstashRequests(test *testing.T) { fakeServer := httptest.NewUnstartedServer(http.HandlerFunc(func(writer http.ResponseWriter, request *http.Request) { writer.Header().Set("Content-Type", "application/json") fmt.Fprintf(writer, "%s", string(logstash6JvmJSON)) assert.Equal(test, request.Host, "logstash.test.local") assert.Equal(test, request.Method, "POST") assert.Equal(test, request.Header.Get("X-Test"), "test-header") })) requestURL, err := url.Parse(logstashTest.URL) if err != nil { test.Logf("Can't connect to: %s", logstashTest.URL) } fakeServer.Listener, _ = net.Listen("tcp", fmt.Sprintf("%s:%s", requestURL.Hostname(), requestURL.Port())) fakeServer.Start() defer fakeServer.Close() if logstashTest.client == nil { client, err := logstashTest.createHttpClient() if err != nil { test.Logf("Can't createHttpClient") } logstashTest.client = client } logstashTest.Method = "POST" logstashTest.Headers["X-Test"] = "test-header" logstashTest.HostHeader = "logstash.test.local" if err := logstashTest.gatherJsonData(logstashTest.URL+jvmStats, &logstash6accJVMStats); err != nil { test.Logf("Can't gather JVM stats") } }