mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-27 13:37:30 +00:00
Merge pull request #83299 from RainbowMango/pr_provide_testutil
Introduce testutil package to support metrics testing
This commit is contained in:
commit
d38e97b4bf
@ -73,6 +73,7 @@ filegroup(
|
|||||||
"//staging/src/k8s.io/component-base/metrics/prometheus/restclient:all-srcs",
|
"//staging/src/k8s.io/component-base/metrics/prometheus/restclient:all-srcs",
|
||||||
"//staging/src/k8s.io/component-base/metrics/prometheus/version:all-srcs",
|
"//staging/src/k8s.io/component-base/metrics/prometheus/version:all-srcs",
|
||||||
"//staging/src/k8s.io/component-base/metrics/prometheus/workqueue:all-srcs",
|
"//staging/src/k8s.io/component-base/metrics/prometheus/workqueue:all-srcs",
|
||||||
|
"//staging/src/k8s.io/component-base/metrics/testutil:all-srcs",
|
||||||
],
|
],
|
||||||
tags = ["automanaged"],
|
tags = ["automanaged"],
|
||||||
)
|
)
|
||||||
|
@ -26,7 +26,7 @@ import (
|
|||||||
var (
|
var (
|
||||||
defaultRegistry = metrics.NewKubeRegistry()
|
defaultRegistry = metrics.NewKubeRegistry()
|
||||||
// DefaultGatherer exposes the global registry gatherer
|
// DefaultGatherer exposes the global registry gatherer
|
||||||
DefaultGatherer prometheus.Gatherer = defaultRegistry
|
DefaultGatherer metrics.Gatherer = defaultRegistry
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
27
staging/src/k8s.io/component-base/metrics/testutil/BUILD
Normal file
27
staging/src/k8s.io/component-base/metrics/testutil/BUILD
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
load("@io_bazel_rules_go//go:def.bzl", "go_library")
|
||||||
|
|
||||||
|
go_library(
|
||||||
|
name = "go_default_library",
|
||||||
|
srcs = ["testutil.go"],
|
||||||
|
importmap = "k8s.io/kubernetes/vendor/k8s.io/component-base/metrics/testutil",
|
||||||
|
importpath = "k8s.io/component-base/metrics/testutil",
|
||||||
|
visibility = ["//visibility:public"],
|
||||||
|
deps = [
|
||||||
|
"//staging/src/k8s.io/component-base/metrics:go_default_library",
|
||||||
|
"//vendor/github.com/prometheus/client_golang/prometheus/testutil:go_default_library",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
filegroup(
|
||||||
|
name = "package-srcs",
|
||||||
|
srcs = glob(["**"]),
|
||||||
|
tags = ["automanaged"],
|
||||||
|
visibility = ["//visibility:private"],
|
||||||
|
)
|
||||||
|
|
||||||
|
filegroup(
|
||||||
|
name = "all-srcs",
|
||||||
|
srcs = [":package-srcs"],
|
||||||
|
tags = ["automanaged"],
|
||||||
|
visibility = ["//visibility:public"],
|
||||||
|
)
|
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2019 The Kubernetes 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 testutil
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
|
||||||
|
"github.com/prometheus/client_golang/prometheus/testutil"
|
||||||
|
|
||||||
|
"k8s.io/component-base/metrics"
|
||||||
|
)
|
||||||
|
|
||||||
|
// GatherAndCompare gathers all metrics from the provided Gatherer and compares
|
||||||
|
// it to an expected output read from the provided Reader in the Prometheus text
|
||||||
|
// exposition format. If any metricNames are provided, only metrics with those
|
||||||
|
// names are compared.
|
||||||
|
func GatherAndCompare(g metrics.Gatherer, expected io.Reader, metricNames ...string) error {
|
||||||
|
return testutil.GatherAndCompare(g, expected, metricNames...)
|
||||||
|
}
|
@ -79,3 +79,9 @@ type PromRegistry interface {
|
|||||||
Unregister(prometheus.Collector) bool
|
Unregister(prometheus.Collector) bool
|
||||||
Gather() ([]*dto.MetricFamily, error)
|
Gather() ([]*dto.MetricFamily, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Gatherer is the interface for the part of a registry in charge of gathering
|
||||||
|
// the collected metrics into a number of MetricFamilies.
|
||||||
|
type Gatherer interface {
|
||||||
|
prometheus.Gatherer
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user