119 lines
4.2 KiB
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"])
|
|
}
|