mirror of
https://github.com/yunionio/cloudpods.git
synced 2026-06-24 21:39:13 +08:00
1.通过cronman 调用eipUnused相关的driver,查询未使用的eip 2.依据对步骤1中的中的数据,对资源列表就行create、update、delete进行三种类型的操作 deal with comments gencopyright climc for SuggestSysRule and SuggestSysAlert monitor: fix sysrule related models not generated eip未使用的监控参数结构调整
171 lines
4.2 KiB
Go
171 lines
4.2 KiB
Go
// Copyright 2019 Yunion
|
|
//
|
|
// Licensed 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 monitor
|
|
|
|
import (
|
|
"testing"
|
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
"yunion.io/x/onecloud/pkg/apis/monitor"
|
|
"yunion.io/x/onecloud/pkg/monitor/tsdb/driver/influxdb"
|
|
)
|
|
|
|
func TestHelperWhere(t *testing.T) {
|
|
Convey("Alert query where", t, func() {
|
|
q := NewAlertCondition("", "").Query()
|
|
w1 := q.Where()
|
|
w1.Equal("hostname", "server1").NotEqual("hypervisor", "kvm").
|
|
OR().GT("key", "val").LT("key1", "val2")
|
|
So(w1.ToTags(), ShouldResemble, []monitor.MetricQueryTag{
|
|
{
|
|
Operator: "=",
|
|
Key: "hostname",
|
|
Value: "server1",
|
|
},
|
|
{
|
|
Condition: "AND",
|
|
Operator: "!=",
|
|
Key: "hypervisor",
|
|
Value: "kvm",
|
|
},
|
|
{
|
|
Condition: "OR",
|
|
Operator: ">",
|
|
Key: "key",
|
|
Value: "val",
|
|
},
|
|
{
|
|
Condition: "OR",
|
|
Operator: "<",
|
|
Key: "key1",
|
|
Value: "val2",
|
|
},
|
|
})
|
|
})
|
|
}
|
|
|
|
func TestHelperSelects(t *testing.T) {
|
|
Convey("Alert query selects", t, func() {
|
|
sels := NewAlertCondition("", "").Query().Selects()
|
|
sels.Select("name").COUNT().MATH("/", "100")
|
|
sels.Select("io_util")
|
|
|
|
So(sels.parts[0].MetricQuerySelect, ShouldResemble, monitor.MetricQuerySelect{
|
|
{
|
|
Type: "field",
|
|
Params: []string{"name"},
|
|
},
|
|
{
|
|
Type: "count",
|
|
},
|
|
{
|
|
Type: "math",
|
|
Params: []string{"/ 100"},
|
|
},
|
|
})
|
|
|
|
So(sels.parts[1].MetricQuerySelect, ShouldResemble, monitor.MetricQuerySelect{
|
|
{
|
|
Type: "field",
|
|
Params: []string{"io_util"},
|
|
},
|
|
})
|
|
})
|
|
}
|
|
|
|
func TestAlertQuery(t *testing.T) {
|
|
Convey("Alert query test", t, func() {
|
|
parser := new(influxdb.InfluxdbQueryParser)
|
|
q := NewAlertQuery("telegraf", "diskio").From("5m").To("now")
|
|
q.Selects().Select("await").MEAN()
|
|
q.Where().Equal("hostname", "host1").Equal("provider", "kvm")
|
|
q.GroupBy().TAG("*").FILL_NULL()
|
|
qCtx := q.ToTsdbQuery()
|
|
influxdbQ, err := parser.Parse(qCtx.Queries[0], nil)
|
|
So(err, ShouldBeNil)
|
|
rawQuery, err := influxdbQ.Build(qCtx)
|
|
So(err, ShouldBeNil)
|
|
So(rawQuery, ShouldEqual, `SELECT mean("await") FROM "diskio" WHERE ("hostname" = 'host1' AND "provider" = 'kvm') AND time > now() - 5m GROUP BY * fill(null)`)
|
|
})
|
|
}
|
|
|
|
func TestAlertConfig(t *testing.T) {
|
|
Convey("Alert config test", t, func() {
|
|
enabled := true
|
|
// disabled := false
|
|
conf, err := NewAlertConfig("alert1", "5s", true)
|
|
So(err, ShouldBeNil)
|
|
q := conf.Condition("telegraf", "cpu").Avg().LT(50).Query()
|
|
sels := q.Selects()
|
|
sels.Select("usage_active").MEAN()
|
|
sels.Select("usage_irq").COUNT()
|
|
q.Where().Equal("host_ip", "10.168.222.231")
|
|
So(conf.ToAlertCreateInput(), ShouldResemble, monitor.AlertCreateInput{
|
|
Name: "alert1",
|
|
Frequency: 5,
|
|
Settings: monitor.AlertSetting{
|
|
Conditions: []monitor.AlertCondition{
|
|
{
|
|
Type: "query",
|
|
Query: monitor.AlertQuery{
|
|
Model: monitor.MetricQuery{
|
|
Database: "telegraf",
|
|
Measurement: "cpu",
|
|
Selects: []monitor.MetricQuerySelect{
|
|
{
|
|
{
|
|
Type: "field",
|
|
Params: []string{"usage_active"},
|
|
},
|
|
{
|
|
Type: "mean",
|
|
},
|
|
},
|
|
{
|
|
{
|
|
Type: "field",
|
|
Params: []string{"usage_irq"},
|
|
},
|
|
{
|
|
Type: "count",
|
|
},
|
|
},
|
|
},
|
|
Tags: []monitor.MetricQueryTag{
|
|
{
|
|
Key: "host_ip",
|
|
Operator: "=",
|
|
Value: "10.168.222.231",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Reducer: monitor.Condition{
|
|
Type: "avg",
|
|
},
|
|
Evaluator: monitor.Condition{
|
|
Type: "lt",
|
|
Params: []float64{50},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
Enabled: &enabled,
|
|
Level: "",
|
|
})
|
|
})
|
|
}
|