| 
									
										
										
										
											2015-12-06 13:33:47 -08: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.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-15 02:38:13 -07:00
										 |  |  | //go:build !nosystemd
 | 
					
						
							|  |  |  | // +build !nosystemd
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-12-06 13:33:47 -08:00
										 |  |  | package collector | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2024-09-11 01:51:28 -07:00
										 |  |  | 	"io" | 
					
						
							|  |  |  | 	"log/slog" | 
					
						
							| 
									
										
										
										
											2016-08-15 23:39:49 -07:00
										 |  |  | 	"regexp" | 
					
						
							| 
									
										
										
										
											2015-12-06 13:33:47 -08:00
										 |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-04 13:14:18 -07:00
										 |  |  | 	"github.com/coreos/go-systemd/v22/dbus" | 
					
						
							| 
									
										
										
										
											2015-12-06 13:33:47 -08:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Creates mock UnitLists
 | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08:00
										 |  |  | func getUnitListFixtures() [][]unit { | 
					
						
							|  |  |  | 	fixture1 := []unit{ | 
					
						
							| 
									
										
										
										
											2017-02-28 09:50:45 -08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08: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 13:33:47 -08:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2017-02-28 09:50:45 -08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08: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 13:33:47 -08:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2017-02-28 09:50:45 -08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08: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-15 23:39:49 -07:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2017-02-28 09:50:45 -08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08: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-15 23:39:49 -07:00
										 |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2015-12-06 13:33:47 -08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08:00
										 |  |  | 	fixture2 := []unit{} | 
					
						
							| 
									
										
										
										
											2015-12-06 13:33:47 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-31 07:22:17 -08:00
										 |  |  | 	return [][]unit{fixture1, fixture2} | 
					
						
							| 
									
										
										
										
											2015-12-06 13:33:47 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-15 23:39:49 -07:00
										 |  |  | func TestSystemdIgnoreFilter(t *testing.T) { | 
					
						
							|  |  |  | 	fixtures := getUnitListFixtures() | 
					
						
							| 
									
										
										
										
											2020-06-11 23:24:29 -07:00
										 |  |  | 	includePattern := regexp.MustCompile("^foo$") | 
					
						
							|  |  |  | 	excludePattern := regexp.MustCompile("^bar$") | 
					
						
							| 
									
										
										
										
											2024-09-11 01:51:28 -07:00
										 |  |  | 	filtered := filterUnits(fixtures[0], includePattern, excludePattern, slog.New(slog.NewTextHandler(io.Discard, nil))) | 
					
						
							| 
									
										
										
										
											2016-08-15 23:39:49 -07:00
										 |  |  | 	for _, unit := range filtered { | 
					
						
							| 
									
										
										
										
											2020-06-11 23:24:29 -07:00
										 |  |  | 		if excludePattern.MatchString(unit.Name) || !includePattern.MatchString(unit.Name) { | 
					
						
							| 
									
										
										
										
											2016-08-15 23:39:49 -07:00
										 |  |  | 			t.Error(unit.Name, "should not be in the filtered list") | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | func TestSystemdIgnoreFilterDefaultKeepsAll(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2024-09-11 01:51:28 -07:00
										 |  |  | 	logger := slog.New(slog.NewTextHandler(io.Discard, nil)) | 
					
						
							| 
									
										
										
										
											2019-12-31 08:19:37 -08:00
										 |  |  | 	c, err := NewSystemdCollector(logger) | 
					
						
							| 
									
										
										
										
											2016-08-15 23:39:49 -07:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	fixtures := getUnitListFixtures() | 
					
						
							|  |  |  | 	collector := c.(*systemdCollector) | 
					
						
							| 
									
										
										
										
											2023-07-10 03:25:18 -07:00
										 |  |  | 	filtered := filterUnits(fixtures[0], collector.systemdUnitIncludePattern, collector.systemdUnitExcludePattern, logger) | 
					
						
							| 
									
										
										
										
											2018-09-24 06:04:55 -07:00
										 |  |  | 	// Adjust fixtures by 3 "not-found" units.
 | 
					
						
							|  |  |  | 	if len(filtered) != len(fixtures[0])-3 { | 
					
						
							| 
									
										
										
										
											2016-08-15 23:39:49 -07:00
										 |  |  | 		t.Error("Default filters removed units") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-01-04 02:49:36 -08: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) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |