youtubebeat/vendor/github.com/elastic/beats/metricbeat/module/ceph/cluster_status/cluster_status_test.go

119 lines
4.2 KiB
Go

// Licensed to Elasticsearch B.V. under one or more contributor
// license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright
// ownership. Elasticsearch B.V. licenses this file to you under
// the Apache License, Version 2.0 (the "License"); you may
// not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
package cluster_status
import (
"io/ioutil"
"net/http"
"net/http/httptest"
"path/filepath"
"testing"
"github.com/elastic/beats/libbeat/common"
mbtest "github.com/elastic/beats/metricbeat/mb/testing"
"github.com/stretchr/testify/assert"
)
func TestFetchEventContents(t *testing.T) {
absPath, err := filepath.Abs("../_meta/testdata/")
assert.NoError(t, err)
response, err := ioutil.ReadFile(absPath + "/status_sample_response.json")
assert.NoError(t, err)
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(200)
w.Header().Set("Content-Type", "application/json;")
w.Write([]byte(response))
}))
defer server.Close()
config := map[string]interface{}{
"module": "ceph",
"metricsets": []string{"cluster_status"},
"hosts": []string{server.URL},
}
f := mbtest.NewEventsFetcher(t, config)
events, err := f.Fetch()
event := events[0]
t.Logf("%s/%s event: %+v", f.Module().Name(), f.Name(), event.StringToPrint())
//check status version number
assert.EqualValues(t, 813, event["version"])
//check osd info
osdmap := event["osd"].(common.MapStr)
assert.EqualValues(t, false, osdmap["full"])
assert.EqualValues(t, false, osdmap["nearfull"])
assert.EqualValues(t, 6, osdmap["osd_count"])
assert.EqualValues(t, 3, osdmap["up_osd_count"])
assert.EqualValues(t, 4, osdmap["in_osd_count"])
assert.EqualValues(t, 240, osdmap["remapped_pg_count"])
assert.EqualValues(t, 264, osdmap["epoch"])
//check traffic info
trafficInfo := event["traffic"].(common.MapStr)
assert.EqualValues(t, 55667788, trafficInfo["read_bytes"])
assert.EqualValues(t, 1234, trafficInfo["read_op_per_sec"])
assert.EqualValues(t, 11996158, trafficInfo["write_bytes"])
assert.EqualValues(t, 10, trafficInfo["write_op_per_sec"])
//check misplace info
misplaceInfo := event["misplace"].(common.MapStr)
assert.EqualValues(t, 768, misplaceInfo["total"])
assert.EqualValues(t, 88, misplaceInfo["objects"])
assert.EqualValues(t, 0.114583, misplaceInfo["pct"])
//check degraded info
degradedInfo := event["degraded"].(common.MapStr)
assert.EqualValues(t, 768, degradedInfo["total"])
assert.EqualValues(t, 294, degradedInfo["objects"])
assert.EqualValues(t, 0.382812, degradedInfo["pct"])
//check pg info
pgInfo := event["pg"].(common.MapStr)
assert.EqualValues(t, 1054023794, pgInfo["data_bytes"])
assert.EqualValues(t, 9965821952, pgInfo["avail_bytes"])
assert.EqualValues(t, 12838682624, pgInfo["total_bytes"])
assert.EqualValues(t, 2872860672, pgInfo["used_bytes"])
//check pg_state info
pg_stateInfo := events[1]["pg_state"].(common.MapStr)
assert.EqualValues(t, "active+undersized+degraded", pg_stateInfo["state_name"])
assert.EqualValues(t, 109, pg_stateInfo["count"])
assert.EqualValues(t, 813, pg_stateInfo["version"])
pg_stateInfo = events[2]["pg_state"].(common.MapStr)
assert.EqualValues(t, "undersized+degraded+peered", pg_stateInfo["state_name"])
assert.EqualValues(t, 101, pg_stateInfo["count"])
assert.EqualValues(t, 813, pg_stateInfo["version"])
pg_stateInfo = events[3]["pg_state"].(common.MapStr)
assert.EqualValues(t, "active+remapped", pg_stateInfo["state_name"])
assert.EqualValues(t, 55, pg_stateInfo["count"])
assert.EqualValues(t, 813, pg_stateInfo["version"])
pg_stateInfo = events[4]["pg_state"].(common.MapStr)
assert.EqualValues(t, "active+undersized+degraded+remapped", pg_stateInfo["state_name"])
assert.EqualValues(t, 55, pg_stateInfo["count"])
assert.EqualValues(t, 813, pg_stateInfo["version"])
}