2015-12-06 22:33:47 +01:00
|
|
|
// Copyright 2015 The Prometheus Authors
|
|
|
|
// 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 collector
|
|
|
|
|
|
|
|
import (
|
2019-12-31 17:19:37 +01:00
|
|
|
"github.com/go-kit/kit/log"
|
2016-08-16 08:39:49 +02:00
|
|
|
"regexp"
|
2015-12-06 22:33:47 +01:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/coreos/go-systemd/dbus"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Creates mock UnitLists
|
2018-01-31 16:22:17 +01:00
|
|
|
func getUnitListFixtures() [][]unit {
|
|
|
|
fixture1 := []unit{
|
2017-02-28 18:50:45 +01:00
|
|
|
{
|
2018-01-31 16:22:17 +01:00
|
|
|
UnitStatus: dbus.UnitStatus{
|
|
|
|
Name: "foo",
|
|
|
|
Description: "foo desc",
|
|
|
|
LoadState: "loaded",
|
|
|
|
ActiveState: "active",
|
|
|
|
SubState: "running",
|
|
|
|
Followed: "",
|
|
|
|
Path: "/org/freedesktop/systemd1/unit/foo",
|
|
|
|
JobId: 0,
|
|
|
|
JobType: "",
|
|
|
|
JobPath: "/",
|
|
|
|
},
|
2015-12-06 22:33:47 +01:00
|
|
|
},
|
2017-02-28 18:50:45 +01:00
|
|
|
{
|
2018-01-31 16:22:17 +01:00
|
|
|
UnitStatus: dbus.UnitStatus{
|
|
|
|
Name: "bar",
|
|
|
|
Description: "bar desc",
|
|
|
|
LoadState: "not-found",
|
|
|
|
ActiveState: "inactive",
|
|
|
|
SubState: "dead",
|
|
|
|
Followed: "",
|
|
|
|
Path: "/org/freedesktop/systemd1/unit/bar",
|
|
|
|
JobId: 0,
|
|
|
|
JobType: "",
|
|
|
|
JobPath: "/",
|
|
|
|
},
|
2015-12-06 22:33:47 +01:00
|
|
|
},
|
2017-02-28 18:50:45 +01:00
|
|
|
{
|
2018-01-31 16:22:17 +01:00
|
|
|
UnitStatus: dbus.UnitStatus{
|
|
|
|
Name: "foobar",
|
|
|
|
Description: "bar desc",
|
|
|
|
LoadState: "not-found",
|
|
|
|
ActiveState: "inactive",
|
|
|
|
SubState: "dead",
|
|
|
|
Followed: "",
|
|
|
|
Path: "/org/freedesktop/systemd1/unit/bar",
|
|
|
|
JobId: 0,
|
|
|
|
JobType: "",
|
|
|
|
JobPath: "/",
|
|
|
|
},
|
2016-08-16 08:39:49 +02:00
|
|
|
},
|
2017-02-28 18:50:45 +01:00
|
|
|
{
|
2018-01-31 16:22:17 +01:00
|
|
|
UnitStatus: dbus.UnitStatus{
|
|
|
|
Name: "baz",
|
|
|
|
Description: "bar desc",
|
|
|
|
LoadState: "not-found",
|
|
|
|
ActiveState: "inactive",
|
|
|
|
SubState: "dead",
|
|
|
|
Followed: "",
|
|
|
|
Path: "/org/freedesktop/systemd1/unit/bar",
|
|
|
|
JobId: 0,
|
|
|
|
JobType: "",
|
|
|
|
JobPath: "/",
|
|
|
|
},
|
2016-08-16 08:39:49 +02:00
|
|
|
},
|
2015-12-06 22:33:47 +01:00
|
|
|
}
|
|
|
|
|
2018-01-31 16:22:17 +01:00
|
|
|
fixture2 := []unit{}
|
2015-12-06 22:33:47 +01:00
|
|
|
|
2018-01-31 16:22:17 +01:00
|
|
|
return [][]unit{fixture1, fixture2}
|
2015-12-06 22:33:47 +01:00
|
|
|
}
|
|
|
|
|
2016-08-16 08:39:49 +02:00
|
|
|
func TestSystemdIgnoreFilter(t *testing.T) {
|
|
|
|
fixtures := getUnitListFixtures()
|
2018-07-30 07:57:18 +02:00
|
|
|
whitelistPattern := regexp.MustCompile("^foo$")
|
|
|
|
blacklistPattern := regexp.MustCompile("^bar$")
|
2019-12-31 17:19:37 +01:00
|
|
|
filtered := filterUnits(fixtures[0], whitelistPattern, blacklistPattern, log.NewNopLogger())
|
2016-08-16 08:39:49 +02:00
|
|
|
for _, unit := range filtered {
|
|
|
|
if blacklistPattern.MatchString(unit.Name) || !whitelistPattern.MatchString(unit.Name) {
|
|
|
|
t.Error(unit.Name, "should not be in the filtered list")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
func TestSystemdIgnoreFilterDefaultKeepsAll(t *testing.T) {
|
2019-12-31 17:19:37 +01:00
|
|
|
logger := log.NewNopLogger()
|
|
|
|
c, err := NewSystemdCollector(logger)
|
2016-08-16 08:39:49 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
fixtures := getUnitListFixtures()
|
|
|
|
collector := c.(*systemdCollector)
|
2019-12-31 17:19:37 +01:00
|
|
|
filtered := filterUnits(fixtures[0], collector.unitWhitelistPattern, collector.unitBlacklistPattern, logger)
|
2018-09-24 15:04:55 +02:00
|
|
|
// Adjust fixtures by 3 "not-found" units.
|
|
|
|
if len(filtered) != len(fixtures[0])-3 {
|
2016-08-16 08:39:49 +02:00
|
|
|
t.Error("Default filters removed units")
|
|
|
|
}
|
|
|
|
}
|
2018-01-04 11:49:36 +01:00
|
|
|
|
|
|
|
func TestSystemdSummary(t *testing.T) {
|
|
|
|
fixtures := getUnitListFixtures()
|
|
|
|
summary := summarizeUnits(fixtures[0])
|
|
|
|
|
|
|
|
for _, state := range unitStatesName {
|
|
|
|
if state == "inactive" {
|
|
|
|
testSummaryHelper(t, state, summary[state], 3.0)
|
|
|
|
} else if state == "active" {
|
|
|
|
testSummaryHelper(t, state, summary[state], 1.0)
|
|
|
|
} else {
|
|
|
|
testSummaryHelper(t, state, summary[state], 0.0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func testSummaryHelper(t *testing.T, state string, actual float64, expected float64) {
|
|
|
|
if actual != expected {
|
|
|
|
t.Errorf("Summary mode didn't count %s jobs correctly. Actual: %f, expected: %f", state, actual, expected)
|
|
|
|
}
|
|
|
|
}
|