mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-11 22:07:27 -08:00
Move away from testutil, refactor imports (#8087)
Signed-off-by: Julien Pivotto <roidelapluie@inuits.eu>
This commit is contained in:
parent
c5a832b394
commit
4e5b1722b3
|
@ -44,6 +44,7 @@ import (
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/common/promlog"
|
"github.com/prometheus/common/promlog"
|
||||||
|
promlogflag "github.com/prometheus/common/promlog/flag"
|
||||||
"github.com/prometheus/common/version"
|
"github.com/prometheus/common/version"
|
||||||
jcfg "github.com/uber/jaeger-client-go/config"
|
jcfg "github.com/uber/jaeger-client-go/config"
|
||||||
jprom "github.com/uber/jaeger-lib/metrics/prometheus"
|
jprom "github.com/uber/jaeger-lib/metrics/prometheus"
|
||||||
|
@ -52,9 +53,9 @@ import (
|
||||||
klog "k8s.io/klog"
|
klog "k8s.io/klog"
|
||||||
klogv2 "k8s.io/klog/v2"
|
klogv2 "k8s.io/klog/v2"
|
||||||
|
|
||||||
promlogflag "github.com/prometheus/common/promlog/flag"
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/discovery"
|
"github.com/prometheus/prometheus/discovery"
|
||||||
|
_ "github.com/prometheus/prometheus/discovery/install" // Register service discovery implementations.
|
||||||
"github.com/prometheus/prometheus/notifier"
|
"github.com/prometheus/prometheus/notifier"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/logging"
|
"github.com/prometheus/prometheus/pkg/logging"
|
||||||
|
@ -68,8 +69,6 @@ import (
|
||||||
"github.com/prometheus/prometheus/tsdb"
|
"github.com/prometheus/prometheus/tsdb"
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
"github.com/prometheus/prometheus/web"
|
"github.com/prometheus/prometheus/web"
|
||||||
|
|
||||||
_ "github.com/prometheus/prometheus/discovery/install" // Register service discovery implementations.
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
|
|
@ -28,10 +28,11 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/notifier"
|
"github.com/prometheus/prometheus/notifier"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/rules"
|
"github.com/prometheus/prometheus/rules"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var promPath = os.Args[0]
|
var promPath = os.Args[0]
|
||||||
|
@ -97,9 +98,9 @@ func TestComputeExternalURL(t *testing.T) {
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
_, err := computeExternalURL(test.input, "0.0.0.0:9090")
|
_, err := computeExternalURL(test.input, "0.0.0.0:9090")
|
||||||
if test.valid {
|
if test.valid {
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
} else {
|
} else {
|
||||||
testutil.NotOk(t, err, "input=%q", test.input)
|
assert.Error(t, err, "input=%q", test.input)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -115,11 +116,11 @@ func TestFailedStartupExitCode(t *testing.T) {
|
||||||
|
|
||||||
prom := exec.Command(promPath, "-test.main", "--config.file="+fakeInputFile)
|
prom := exec.Command(promPath, "-test.main", "--config.file="+fakeInputFile)
|
||||||
err := prom.Run()
|
err := prom.Run()
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
|
|
||||||
if exitError, ok := err.(*exec.ExitError); ok {
|
if exitError, ok := err.(*exec.ExitError); ok {
|
||||||
status := exitError.Sys().(syscall.WaitStatus)
|
status := exitError.Sys().(syscall.WaitStatus)
|
||||||
testutil.Equals(t, expectedExitStatus, status.ExitStatus())
|
assert.Equal(t, expectedExitStatus, status.ExitStatus())
|
||||||
} else {
|
} else {
|
||||||
t.Errorf("unable to retrieve the exit status for prometheus: %v", err)
|
t.Errorf("unable to retrieve the exit status for prometheus: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -188,7 +189,7 @@ func TestSendAlerts(t *testing.T) {
|
||||||
if len(tc.in) == 0 {
|
if len(tc.in) == 0 {
|
||||||
t.Fatalf("sender called with 0 alert")
|
t.Fatalf("sender called with 0 alert")
|
||||||
}
|
}
|
||||||
testutil.Equals(t, tc.exp, alerts)
|
assert.Equal(t, tc.exp, alerts)
|
||||||
})
|
})
|
||||||
sendAlerts(senderFunc, "http://localhost:9090")(context.TODO(), "up", tc.in...)
|
sendAlerts(senderFunc, "http://localhost:9090")(context.TODO(), "up", tc.in...)
|
||||||
})
|
})
|
||||||
|
@ -205,14 +206,14 @@ func TestWALSegmentSizeBounds(t *testing.T) {
|
||||||
|
|
||||||
// Log stderr in case of failure.
|
// Log stderr in case of failure.
|
||||||
stderr, err := prom.StderrPipe()
|
stderr, err := prom.StderrPipe()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
go func() {
|
go func() {
|
||||||
slurp, _ := ioutil.ReadAll(stderr)
|
slurp, _ := ioutil.ReadAll(stderr)
|
||||||
t.Log(string(slurp))
|
t.Log(string(slurp))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
err = prom.Start()
|
err = prom.Start()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
if expectedExitStatus == 0 {
|
if expectedExitStatus == 0 {
|
||||||
done := make(chan error, 1)
|
done := make(chan error, 1)
|
||||||
|
@ -227,10 +228,10 @@ func TestWALSegmentSizeBounds(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
err = prom.Wait()
|
err = prom.Wait()
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
if exitError, ok := err.(*exec.ExitError); ok {
|
if exitError, ok := err.(*exec.ExitError); ok {
|
||||||
status := exitError.Sys().(syscall.WaitStatus)
|
status := exitError.Sys().(syscall.WaitStatus)
|
||||||
testutil.Equals(t, expectedExitStatus, status.ExitStatus())
|
assert.Equal(t, expectedExitStatus, status.ExitStatus())
|
||||||
} else {
|
} else {
|
||||||
t.Errorf("unable to retrieve the exit status for prometheus: %v", err)
|
t.Errorf("unable to retrieve the exit status for prometheus: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -239,21 +240,21 @@ func TestWALSegmentSizeBounds(t *testing.T) {
|
||||||
|
|
||||||
func TestTimeMetrics(t *testing.T) {
|
func TestTimeMetrics(t *testing.T) {
|
||||||
tmpDir, err := ioutil.TempDir("", "time_metrics_e2e")
|
tmpDir, err := ioutil.TempDir("", "time_metrics_e2e")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(tmpDir))
|
assert.NoError(t, os.RemoveAll(tmpDir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
reg := prometheus.NewRegistry()
|
reg := prometheus.NewRegistry()
|
||||||
db, err := openDBWithMetrics(tmpDir, log.NewNopLogger(), reg, nil)
|
db, err := openDBWithMetrics(tmpDir, log.NewNopLogger(), reg, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, db.Close())
|
assert.NoError(t, db.Close())
|
||||||
}()
|
}()
|
||||||
|
|
||||||
// Check initial values.
|
// Check initial values.
|
||||||
testutil.Equals(t, map[string]float64{
|
assert.Equal(t, map[string]float64{
|
||||||
"prometheus_tsdb_lowest_timestamp_seconds": float64(math.MaxInt64) / 1000,
|
"prometheus_tsdb_lowest_timestamp_seconds": float64(math.MaxInt64) / 1000,
|
||||||
"prometheus_tsdb_head_min_time_seconds": float64(math.MaxInt64) / 1000,
|
"prometheus_tsdb_head_min_time_seconds": float64(math.MaxInt64) / 1000,
|
||||||
"prometheus_tsdb_head_max_time_seconds": float64(math.MinInt64) / 1000,
|
"prometheus_tsdb_head_max_time_seconds": float64(math.MinInt64) / 1000,
|
||||||
|
@ -265,14 +266,14 @@ func TestTimeMetrics(t *testing.T) {
|
||||||
|
|
||||||
app := db.Appender(context.Background())
|
app := db.Appender(context.Background())
|
||||||
_, err = app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 1000, 1)
|
_, err = app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 1000, 1)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 2000, 1)
|
_, err = app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 2000, 1)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 3000, 1)
|
_, err = app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 3000, 1)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, app.Commit())
|
assert.NoError(t, app.Commit())
|
||||||
|
|
||||||
testutil.Equals(t, map[string]float64{
|
assert.Equal(t, map[string]float64{
|
||||||
"prometheus_tsdb_lowest_timestamp_seconds": 1.0,
|
"prometheus_tsdb_lowest_timestamp_seconds": 1.0,
|
||||||
"prometheus_tsdb_head_min_time_seconds": 1.0,
|
"prometheus_tsdb_head_min_time_seconds": 1.0,
|
||||||
"prometheus_tsdb_head_max_time_seconds": 3.0,
|
"prometheus_tsdb_head_max_time_seconds": 3.0,
|
||||||
|
@ -285,7 +286,7 @@ func TestTimeMetrics(t *testing.T) {
|
||||||
|
|
||||||
func getCurrentGaugeValuesFor(t *testing.T, reg prometheus.Gatherer, metricNames ...string) map[string]float64 {
|
func getCurrentGaugeValuesFor(t *testing.T, reg prometheus.Gatherer, metricNames ...string) map[string]float64 {
|
||||||
f, err := reg.Gather()
|
f, err := reg.Gather()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res := make(map[string]float64, len(metricNames))
|
res := make(map[string]float64, len(metricNames))
|
||||||
for _, g := range f {
|
for _, g := range f {
|
||||||
|
@ -294,7 +295,7 @@ func getCurrentGaugeValuesFor(t *testing.T, reg prometheus.Gatherer, metricNames
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, 1, len(g.GetMetric()))
|
assert.Equal(t, 1, len(g.GetMetric()))
|
||||||
if _, ok := res[m]; ok {
|
if _, ok := res[m]; ok {
|
||||||
t.Error("expected only one metric family for", m)
|
t.Error("expected only one metric family for", m)
|
||||||
t.FailNow()
|
t.FailNow()
|
||||||
|
|
|
@ -30,7 +30,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type origin int
|
type origin int
|
||||||
|
@ -82,22 +82,22 @@ func (p *queryLogTest) waitForPrometheus() error {
|
||||||
// then reloads the configuration if needed.
|
// then reloads the configuration if needed.
|
||||||
func (p *queryLogTest) setQueryLog(t *testing.T, queryLogFile string) {
|
func (p *queryLogTest) setQueryLog(t *testing.T, queryLogFile string) {
|
||||||
err := p.configFile.Truncate(0)
|
err := p.configFile.Truncate(0)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = p.configFile.Seek(0, 0)
|
_, err = p.configFile.Seek(0, 0)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
if queryLogFile != "" {
|
if queryLogFile != "" {
|
||||||
_, err = p.configFile.Write([]byte(fmt.Sprintf("global:\n query_log_file: %s\n", queryLogFile)))
|
_, err = p.configFile.Write([]byte(fmt.Sprintf("global:\n query_log_file: %s\n", queryLogFile)))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
_, err = p.configFile.Write([]byte(p.configuration()))
|
_, err = p.configFile.Write([]byte(p.configuration()))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// reloadConfig reloads the configuration using POST.
|
// reloadConfig reloads the configuration using POST.
|
||||||
func (p *queryLogTest) reloadConfig(t *testing.T) {
|
func (p *queryLogTest) reloadConfig(t *testing.T) {
|
||||||
r, err := http.Post(fmt.Sprintf("http://%s:%d%s/-/reload", p.host, p.port, p.prefix), "text/plain", nil)
|
r, err := http.Post(fmt.Sprintf("http://%s:%d%s/-/reload", p.host, p.port, p.prefix), "text/plain", nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 200, r.StatusCode)
|
assert.Equal(t, 200, r.StatusCode)
|
||||||
}
|
}
|
||||||
|
|
||||||
// query runs a query according to the test origin.
|
// query runs a query according to the test origin.
|
||||||
|
@ -111,8 +111,8 @@ func (p *queryLogTest) query(t *testing.T) {
|
||||||
p.prefix,
|
p.prefix,
|
||||||
url.QueryEscape("query_with_api"),
|
url.QueryEscape("query_with_api"),
|
||||||
))
|
))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 200, r.StatusCode)
|
assert.Equal(t, 200, r.StatusCode)
|
||||||
case consoleOrigin:
|
case consoleOrigin:
|
||||||
r, err := http.Get(fmt.Sprintf(
|
r, err := http.Get(fmt.Sprintf(
|
||||||
"http://%s:%d%s/consoles/test.html",
|
"http://%s:%d%s/consoles/test.html",
|
||||||
|
@ -120,8 +120,8 @@ func (p *queryLogTest) query(t *testing.T) {
|
||||||
p.port,
|
p.port,
|
||||||
p.prefix,
|
p.prefix,
|
||||||
))
|
))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 200, r.StatusCode)
|
assert.Equal(t, 200, r.StatusCode)
|
||||||
case ruleOrigin:
|
case ruleOrigin:
|
||||||
time.Sleep(2 * time.Second)
|
time.Sleep(2 * time.Second)
|
||||||
default:
|
default:
|
||||||
|
@ -147,15 +147,15 @@ func (p *queryLogTest) queryString() string {
|
||||||
// test parameters.
|
// test parameters.
|
||||||
func (p *queryLogTest) validateLastQuery(t *testing.T, ql []queryLogLine) {
|
func (p *queryLogTest) validateLastQuery(t *testing.T, ql []queryLogLine) {
|
||||||
q := ql[len(ql)-1]
|
q := ql[len(ql)-1]
|
||||||
testutil.Equals(t, p.queryString(), q.Params.Query)
|
assert.Equal(t, p.queryString(), q.Params.Query)
|
||||||
|
|
||||||
switch p.origin {
|
switch p.origin {
|
||||||
case apiOrigin:
|
case apiOrigin:
|
||||||
testutil.Equals(t, 5, q.Params.Step)
|
assert.Equal(t, 5, q.Params.Step)
|
||||||
testutil.Equals(t, "1970-01-01T00:00:00.000Z", q.Params.Start)
|
assert.Equal(t, "1970-01-01T00:00:00.000Z", q.Params.Start)
|
||||||
testutil.Equals(t, "1970-01-01T01:00:00.000Z", q.Params.End)
|
assert.Equal(t, "1970-01-01T01:00:00.000Z", q.Params.End)
|
||||||
default:
|
default:
|
||||||
testutil.Equals(t, 0, q.Params.Step)
|
assert.Equal(t, 0, q.Params.Step)
|
||||||
}
|
}
|
||||||
|
|
||||||
if p.origin != ruleOrigin {
|
if p.origin != ruleOrigin {
|
||||||
|
@ -163,17 +163,17 @@ func (p *queryLogTest) validateLastQuery(t *testing.T, ql []queryLogLine) {
|
||||||
if host == "[::1]" {
|
if host == "[::1]" {
|
||||||
host = "::1"
|
host = "::1"
|
||||||
}
|
}
|
||||||
testutil.Equals(t, host, q.Request.ClientIP)
|
assert.Equal(t, host, q.Request.ClientIP)
|
||||||
}
|
}
|
||||||
|
|
||||||
switch p.origin {
|
switch p.origin {
|
||||||
case apiOrigin:
|
case apiOrigin:
|
||||||
testutil.Equals(t, p.prefix+"/api/v1/query_range", q.Request.Path)
|
assert.Equal(t, p.prefix+"/api/v1/query_range", q.Request.Path)
|
||||||
case consoleOrigin:
|
case consoleOrigin:
|
||||||
testutil.Equals(t, p.prefix+"/consoles/test.html", q.Request.Path)
|
assert.Equal(t, p.prefix+"/consoles/test.html", q.Request.Path)
|
||||||
case ruleOrigin:
|
case ruleOrigin:
|
||||||
testutil.Equals(t, "querylogtest", q.RuleGroup.Name)
|
assert.Equal(t, "querylogtest", q.RuleGroup.Name)
|
||||||
testutil.Equals(t, filepath.Join(p.cwd, "testdata", "rules", "test.yml"), q.RuleGroup.File)
|
assert.Equal(t, filepath.Join(p.cwd, "testdata", "rules", "test.yml"), q.RuleGroup.File)
|
||||||
default:
|
default:
|
||||||
panic("unknown origin")
|
panic("unknown origin")
|
||||||
}
|
}
|
||||||
|
@ -234,10 +234,10 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
|
|
||||||
// Setup temporary files for this test.
|
// Setup temporary files for this test.
|
||||||
queryLogFile, err := ioutil.TempFile("", "query")
|
queryLogFile, err := ioutil.TempFile("", "query")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.Remove(queryLogFile.Name())
|
defer os.Remove(queryLogFile.Name())
|
||||||
p.configFile, err = ioutil.TempFile("", "config")
|
p.configFile, err = ioutil.TempFile("", "config")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.Remove(p.configFile.Name())
|
defer os.Remove(p.configFile.Name())
|
||||||
|
|
||||||
if p.enabledAtStart {
|
if p.enabledAtStart {
|
||||||
|
@ -247,9 +247,9 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "query_log_test")
|
dir, err := ioutil.TempDir("", "query_log_test")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
params := append([]string{
|
params := append([]string{
|
||||||
|
@ -264,7 +264,7 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
|
|
||||||
// Log stderr in case of failure.
|
// Log stderr in case of failure.
|
||||||
stderr, err := prom.StderrPipe()
|
stderr, err := prom.StderrPipe()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
// We use a WaitGroup to avoid calling t.Log after the test is done.
|
// We use a WaitGroup to avoid calling t.Log after the test is done.
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
|
@ -276,17 +276,17 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
wg.Done()
|
wg.Done()
|
||||||
}()
|
}()
|
||||||
|
|
||||||
testutil.Ok(t, prom.Start())
|
assert.NoError(t, prom.Start())
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
prom.Process.Kill()
|
prom.Process.Kill()
|
||||||
prom.Wait()
|
prom.Wait()
|
||||||
}()
|
}()
|
||||||
testutil.Ok(t, p.waitForPrometheus())
|
assert.NoError(t, p.waitForPrometheus())
|
||||||
|
|
||||||
if !p.enabledAtStart {
|
if !p.enabledAtStart {
|
||||||
p.query(t)
|
p.query(t)
|
||||||
testutil.Equals(t, 0, len(readQueryLog(t, queryLogFile.Name())))
|
assert.Equal(t, 0, len(readQueryLog(t, queryLogFile.Name())))
|
||||||
p.setQueryLog(t, queryLogFile.Name())
|
p.setQueryLog(t, queryLogFile.Name())
|
||||||
p.reloadConfig(t)
|
p.reloadConfig(t)
|
||||||
}
|
}
|
||||||
|
@ -296,9 +296,9 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
ql := readQueryLog(t, queryLogFile.Name())
|
ql := readQueryLog(t, queryLogFile.Name())
|
||||||
qc := len(ql)
|
qc := len(ql)
|
||||||
if p.exactQueryCount() {
|
if p.exactQueryCount() {
|
||||||
testutil.Equals(t, 1, qc)
|
assert.Equal(t, 1, qc)
|
||||||
} else {
|
} else {
|
||||||
testutil.Assert(t, qc > 0, "no queries logged")
|
assert.True(t, qc > 0, "no queries logged")
|
||||||
}
|
}
|
||||||
p.validateLastQuery(t, ql)
|
p.validateLastQuery(t, ql)
|
||||||
|
|
||||||
|
@ -311,7 +311,7 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
p.query(t)
|
p.query(t)
|
||||||
|
|
||||||
ql = readQueryLog(t, queryLogFile.Name())
|
ql = readQueryLog(t, queryLogFile.Name())
|
||||||
testutil.Equals(t, qc, len(ql))
|
assert.Equal(t, qc, len(ql))
|
||||||
|
|
||||||
qc = len(ql)
|
qc = len(ql)
|
||||||
p.setQueryLog(t, queryLogFile.Name())
|
p.setQueryLog(t, queryLogFile.Name())
|
||||||
|
@ -322,9 +322,9 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
|
|
||||||
ql = readQueryLog(t, queryLogFile.Name())
|
ql = readQueryLog(t, queryLogFile.Name())
|
||||||
if p.exactQueryCount() {
|
if p.exactQueryCount() {
|
||||||
testutil.Equals(t, qc, len(ql))
|
assert.Equal(t, qc, len(ql))
|
||||||
} else {
|
} else {
|
||||||
testutil.Assert(t, len(ql) > qc, "no queries logged")
|
assert.True(t, len(ql) > qc, "no queries logged")
|
||||||
}
|
}
|
||||||
p.validateLastQuery(t, ql)
|
p.validateLastQuery(t, ql)
|
||||||
qc = len(ql)
|
qc = len(ql)
|
||||||
|
@ -336,13 +336,13 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
}
|
}
|
||||||
// Move the file, Prometheus should still write to the old file.
|
// Move the file, Prometheus should still write to the old file.
|
||||||
newFile, err := ioutil.TempFile("", "newLoc")
|
newFile, err := ioutil.TempFile("", "newLoc")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, newFile.Close())
|
assert.NoError(t, newFile.Close())
|
||||||
defer os.Remove(newFile.Name())
|
defer os.Remove(newFile.Name())
|
||||||
testutil.Ok(t, os.Rename(queryLogFile.Name(), newFile.Name()))
|
assert.NoError(t, os.Rename(queryLogFile.Name(), newFile.Name()))
|
||||||
ql = readQueryLog(t, newFile.Name())
|
ql = readQueryLog(t, newFile.Name())
|
||||||
if p.exactQueryCount() {
|
if p.exactQueryCount() {
|
||||||
testutil.Equals(t, qc, len(ql))
|
assert.Equal(t, qc, len(ql))
|
||||||
}
|
}
|
||||||
p.validateLastQuery(t, ql)
|
p.validateLastQuery(t, ql)
|
||||||
qc = len(ql)
|
qc = len(ql)
|
||||||
|
@ -353,9 +353,9 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
|
|
||||||
ql = readQueryLog(t, newFile.Name())
|
ql = readQueryLog(t, newFile.Name())
|
||||||
if p.exactQueryCount() {
|
if p.exactQueryCount() {
|
||||||
testutil.Equals(t, qc, len(ql))
|
assert.Equal(t, qc, len(ql))
|
||||||
} else {
|
} else {
|
||||||
testutil.Assert(t, len(ql) > qc, "no queries logged")
|
assert.True(t, len(ql) > qc, "no queries logged")
|
||||||
}
|
}
|
||||||
p.validateLastQuery(t, ql)
|
p.validateLastQuery(t, ql)
|
||||||
|
|
||||||
|
@ -366,9 +366,9 @@ func (p *queryLogTest) run(t *testing.T) {
|
||||||
ql = readQueryLog(t, queryLogFile.Name())
|
ql = readQueryLog(t, queryLogFile.Name())
|
||||||
qc = len(ql)
|
qc = len(ql)
|
||||||
if p.exactQueryCount() {
|
if p.exactQueryCount() {
|
||||||
testutil.Equals(t, 1, qc)
|
assert.Equal(t, 1, qc)
|
||||||
} else {
|
} else {
|
||||||
testutil.Assert(t, qc > 0, "no queries logged")
|
assert.True(t, qc > 0, "no queries logged")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -393,12 +393,12 @@ type queryLogLine struct {
|
||||||
func readQueryLog(t *testing.T, path string) []queryLogLine {
|
func readQueryLog(t *testing.T, path string) []queryLogLine {
|
||||||
ql := []queryLogLine{}
|
ql := []queryLogLine{}
|
||||||
file, err := os.Open(path)
|
file, err := os.Open(path)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer file.Close()
|
defer file.Close()
|
||||||
scanner := bufio.NewScanner(file)
|
scanner := bufio.NewScanner(file)
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
var q queryLogLine
|
var q queryLogLine
|
||||||
testutil.Ok(t, json.Unmarshal(scanner.Bytes(), &q))
|
assert.NoError(t, json.Unmarshal(scanner.Bytes(), &q))
|
||||||
ql = append(ql, q)
|
ql = append(ql, q)
|
||||||
}
|
}
|
||||||
return ql
|
return ql
|
||||||
|
@ -410,7 +410,7 @@ func TestQueryLog(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
cwd, err := os.Getwd()
|
cwd, err := os.Getwd()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
port := 15000
|
port := 15000
|
||||||
for _, host := range []string{"127.0.0.1", "[::1]"} {
|
for _, host := range []string{"127.0.0.1", "[::1]"} {
|
||||||
|
|
|
@ -41,10 +41,9 @@ import (
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/discovery/file"
|
"github.com/prometheus/prometheus/discovery/file"
|
||||||
|
_ "github.com/prometheus/prometheus/discovery/install" // Register service discovery implementations.
|
||||||
"github.com/prometheus/prometheus/discovery/kubernetes"
|
"github.com/prometheus/prometheus/discovery/kubernetes"
|
||||||
"github.com/prometheus/prometheus/pkg/rulefmt"
|
"github.com/prometheus/prometheus/pkg/rulefmt"
|
||||||
|
|
||||||
_ "github.com/prometheus/prometheus/discovery/install" // Register service discovery implementations.
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestQueryRange(t *testing.T) {
|
func TestQueryRange(t *testing.T) {
|
||||||
|
@ -29,18 +29,18 @@ func TestQueryRange(t *testing.T) {
|
||||||
|
|
||||||
p := &promqlPrinter{}
|
p := &promqlPrinter{}
|
||||||
exitCode := QueryRange(s.URL, map[string]string{}, "up", "0", "300", 0, p)
|
exitCode := QueryRange(s.URL, map[string]string{}, "up", "0", "300", 0, p)
|
||||||
testutil.Equals(t, "/api/v1/query_range", getRequest().URL.Path)
|
assert.Equal(t, "/api/v1/query_range", getRequest().URL.Path)
|
||||||
form := getRequest().Form
|
form := getRequest().Form
|
||||||
testutil.Equals(t, "up", form.Get("query"))
|
assert.Equal(t, "up", form.Get("query"))
|
||||||
testutil.Equals(t, "1", form.Get("step"))
|
assert.Equal(t, "1", form.Get("step"))
|
||||||
testutil.Equals(t, 0, exitCode)
|
assert.Equal(t, 0, exitCode)
|
||||||
|
|
||||||
exitCode = QueryRange(s.URL, map[string]string{}, "up", "0", "300", 10*time.Millisecond, p)
|
exitCode = QueryRange(s.URL, map[string]string{}, "up", "0", "300", 10*time.Millisecond, p)
|
||||||
testutil.Equals(t, "/api/v1/query_range", getRequest().URL.Path)
|
assert.Equal(t, "/api/v1/query_range", getRequest().URL.Path)
|
||||||
form = getRequest().Form
|
form = getRequest().Form
|
||||||
testutil.Equals(t, "up", form.Get("query"))
|
assert.Equal(t, "up", form.Get("query"))
|
||||||
testutil.Equals(t, "0.01", form.Get("step"))
|
assert.Equal(t, "0.01", form.Get("step"))
|
||||||
testutil.Equals(t, 0, exitCode)
|
assert.Equal(t, 0, exitCode)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestQueryInstant(t *testing.T) {
|
func TestQueryInstant(t *testing.T) {
|
||||||
|
@ -49,11 +49,11 @@ func TestQueryInstant(t *testing.T) {
|
||||||
|
|
||||||
p := &promqlPrinter{}
|
p := &promqlPrinter{}
|
||||||
exitCode := QueryInstant(s.URL, "up", "300", p)
|
exitCode := QueryInstant(s.URL, "up", "300", p)
|
||||||
testutil.Equals(t, "/api/v1/query", getRequest().URL.Path)
|
assert.Equal(t, "/api/v1/query", getRequest().URL.Path)
|
||||||
form := getRequest().Form
|
form := getRequest().Form
|
||||||
testutil.Equals(t, "up", form.Get("query"))
|
assert.Equal(t, "up", form.Get("query"))
|
||||||
testutil.Equals(t, "300", form.Get("time"))
|
assert.Equal(t, "300", form.Get("time"))
|
||||||
testutil.Equals(t, 0, exitCode)
|
assert.Equal(t, 0, exitCode)
|
||||||
}
|
}
|
||||||
|
|
||||||
func mockServer(code int, body string) (*httptest.Server, func() *http.Request) {
|
func mockServer(code int, body string) (*httptest.Server, func() *http.Request) {
|
||||||
|
|
|
@ -33,6 +33,7 @@ import (
|
||||||
"github.com/alecthomas/units"
|
"github.com/alecthomas/units"
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/tsdb"
|
"github.com/prometheus/prometheus/tsdb"
|
||||||
|
|
|
@ -27,9 +27,9 @@ import (
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
"github.com/prometheus/common/model"
|
||||||
yaml "gopkg.in/yaml.v2"
|
yaml "gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
|
|
|
@ -25,6 +25,7 @@ import (
|
||||||
|
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery"
|
"github.com/prometheus/prometheus/discovery"
|
||||||
|
@ -45,7 +46,6 @@ import (
|
||||||
"github.com/prometheus/prometheus/discovery/zookeeper"
|
"github.com/prometheus/prometheus/discovery/zookeeper"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/relabel"
|
"github.com/prometheus/prometheus/pkg/relabel"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func mustParseURL(u string) *config.URL {
|
func mustParseURL(u string) *config.URL {
|
||||||
|
@ -720,77 +720,77 @@ var expectedConf = &Config{
|
||||||
|
|
||||||
func TestYAMLRoundtrip(t *testing.T) {
|
func TestYAMLRoundtrip(t *testing.T) {
|
||||||
want, err := LoadFile("testdata/roundtrip.good.yml")
|
want, err := LoadFile("testdata/roundtrip.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
out, err := yaml.Marshal(want)
|
out, err := yaml.Marshal(want)
|
||||||
|
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
got := &Config{}
|
got := &Config{}
|
||||||
testutil.Ok(t, yaml.UnmarshalStrict(out, got))
|
assert.NoError(t, yaml.UnmarshalStrict(out, got))
|
||||||
|
|
||||||
testutil.Equals(t, want, got)
|
assert.Equal(t, want, got)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLoadConfig(t *testing.T) {
|
func TestLoadConfig(t *testing.T) {
|
||||||
// Parse a valid file that sets a global scrape timeout. This tests whether parsing
|
// Parse a valid file that sets a global scrape timeout. This tests whether parsing
|
||||||
// an overwritten default field in the global config permanently changes the default.
|
// an overwritten default field in the global config permanently changes the default.
|
||||||
_, err := LoadFile("testdata/global_timeout.good.yml")
|
_, err := LoadFile("testdata/global_timeout.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
c, err := LoadFile("testdata/conf.good.yml")
|
c, err := LoadFile("testdata/conf.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, expectedConf, c)
|
assert.Equal(t, expectedConf, c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeIntervalLarger(t *testing.T) {
|
func TestScrapeIntervalLarger(t *testing.T) {
|
||||||
c, err := LoadFile("testdata/scrape_interval_larger.good.yml")
|
c, err := LoadFile("testdata/scrape_interval_larger.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 1, len(c.ScrapeConfigs))
|
assert.Equal(t, 1, len(c.ScrapeConfigs))
|
||||||
for _, sc := range c.ScrapeConfigs {
|
for _, sc := range c.ScrapeConfigs {
|
||||||
testutil.Equals(t, true, sc.ScrapeInterval >= sc.ScrapeTimeout)
|
assert.Equal(t, true, sc.ScrapeInterval >= sc.ScrapeTimeout)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// YAML marshaling must not reveal authentication credentials.
|
// YAML marshaling must not reveal authentication credentials.
|
||||||
func TestElideSecrets(t *testing.T) {
|
func TestElideSecrets(t *testing.T) {
|
||||||
c, err := LoadFile("testdata/conf.good.yml")
|
c, err := LoadFile("testdata/conf.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
secretRe := regexp.MustCompile(`\\u003csecret\\u003e|<secret>`)
|
secretRe := regexp.MustCompile(`\\u003csecret\\u003e|<secret>`)
|
||||||
|
|
||||||
config, err := yaml.Marshal(c)
|
config, err := yaml.Marshal(c)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
yamlConfig := string(config)
|
yamlConfig := string(config)
|
||||||
|
|
||||||
matches := secretRe.FindAllStringIndex(yamlConfig, -1)
|
matches := secretRe.FindAllStringIndex(yamlConfig, -1)
|
||||||
testutil.Assert(t, len(matches) == 10, "wrong number of secret matches found")
|
assert.True(t, len(matches) == 10, "wrong number of secret matches found")
|
||||||
testutil.Assert(t, !strings.Contains(yamlConfig, "mysecret"),
|
assert.True(t, !strings.Contains(yamlConfig, "mysecret"),
|
||||||
"yaml marshal reveals authentication credentials.")
|
"yaml marshal reveals authentication credentials.")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLoadConfigRuleFilesAbsolutePath(t *testing.T) {
|
func TestLoadConfigRuleFilesAbsolutePath(t *testing.T) {
|
||||||
// Parse a valid file that sets a rule files with an absolute path
|
// Parse a valid file that sets a rule files with an absolute path
|
||||||
c, err := LoadFile(ruleFilesConfigFile)
|
c, err := LoadFile(ruleFilesConfigFile)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, ruleFilesExpectedConf, c)
|
assert.Equal(t, ruleFilesExpectedConf, c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestKubernetesEmptyAPIServer(t *testing.T) {
|
func TestKubernetesEmptyAPIServer(t *testing.T) {
|
||||||
_, err := LoadFile("testdata/kubernetes_empty_apiserver.good.yml")
|
_, err := LoadFile("testdata/kubernetes_empty_apiserver.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestKubernetesSelectors(t *testing.T) {
|
func TestKubernetesSelectors(t *testing.T) {
|
||||||
_, err := LoadFile("testdata/kubernetes_selectors_endpoints.good.yml")
|
_, err := LoadFile("testdata/kubernetes_selectors_endpoints.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = LoadFile("testdata/kubernetes_selectors_node.good.yml")
|
_, err = LoadFile("testdata/kubernetes_selectors_node.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = LoadFile("testdata/kubernetes_selectors_ingress.good.yml")
|
_, err = LoadFile("testdata/kubernetes_selectors_ingress.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = LoadFile("testdata/kubernetes_selectors_pod.good.yml")
|
_, err = LoadFile("testdata/kubernetes_selectors_pod.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
_, err = LoadFile("testdata/kubernetes_selectors_service.good.yml")
|
_, err = LoadFile("testdata/kubernetes_selectors_service.good.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
var expectedErrors = []struct {
|
var expectedErrors = []struct {
|
||||||
|
@ -1026,40 +1026,40 @@ var expectedErrors = []struct {
|
||||||
func TestBadConfigs(t *testing.T) {
|
func TestBadConfigs(t *testing.T) {
|
||||||
for _, ee := range expectedErrors {
|
for _, ee := range expectedErrors {
|
||||||
_, err := LoadFile("testdata/" + ee.filename)
|
_, err := LoadFile("testdata/" + ee.filename)
|
||||||
testutil.NotOk(t, err, "%s", ee.filename)
|
assert.Error(t, err, "%s", ee.filename)
|
||||||
testutil.Assert(t, strings.Contains(err.Error(), ee.errMsg),
|
assert.True(t, strings.Contains(err.Error(), ee.errMsg),
|
||||||
"Expected error for %s to contain %q but got: %s", ee.filename, ee.errMsg, err)
|
"Expected error for %s to contain %q but got: %s", ee.filename, ee.errMsg, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBadStaticConfigsJSON(t *testing.T) {
|
func TestBadStaticConfigsJSON(t *testing.T) {
|
||||||
content, err := ioutil.ReadFile("testdata/static_config.bad.json")
|
content, err := ioutil.ReadFile("testdata/static_config.bad.json")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
var tg targetgroup.Group
|
var tg targetgroup.Group
|
||||||
err = json.Unmarshal(content, &tg)
|
err = json.Unmarshal(content, &tg)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBadStaticConfigsYML(t *testing.T) {
|
func TestBadStaticConfigsYML(t *testing.T) {
|
||||||
content, err := ioutil.ReadFile("testdata/static_config.bad.yml")
|
content, err := ioutil.ReadFile("testdata/static_config.bad.yml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
var tg targetgroup.Group
|
var tg targetgroup.Group
|
||||||
err = yaml.UnmarshalStrict(content, &tg)
|
err = yaml.UnmarshalStrict(content, &tg)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEmptyConfig(t *testing.T) {
|
func TestEmptyConfig(t *testing.T) {
|
||||||
c, err := Load("")
|
c, err := Load("")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
exp := DefaultConfig
|
exp := DefaultConfig
|
||||||
testutil.Equals(t, exp, *c)
|
assert.Equal(t, exp, *c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEmptyGlobalBlock(t *testing.T) {
|
func TestEmptyGlobalBlock(t *testing.T) {
|
||||||
c, err := Load("global:\n")
|
c, err := Load("global:\n")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
exp := DefaultConfig
|
exp := DefaultConfig
|
||||||
testutil.Equals(t, exp, *c)
|
assert.Equal(t, exp, *c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func kubernetesSDHostURL() config.URL {
|
func kubernetesSDHostURL() config.URL {
|
||||||
|
|
|
@ -14,10 +14,10 @@
|
||||||
package azure
|
package azure
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"reflect"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/Azure/azure-sdk-for-go/services/compute/mgmt/2018-10-01/compute"
|
"github.com/Azure/azure-sdk-for-go/services/compute/mgmt/2018-10-01/compute"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"go.uber.org/goleak"
|
"go.uber.org/goleak"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -63,9 +63,7 @@ func TestMapFromVMWithEmptyTags(t *testing.T) {
|
||||||
|
|
||||||
actualVM := mapFromVM(testVM)
|
actualVM := mapFromVM(testVM)
|
||||||
|
|
||||||
if !reflect.DeepEqual(expectedVM, actualVM) {
|
assert.Equal(t, expectedVM, actualVM)
|
||||||
t.Errorf("Expected %v got %v", expectedVM, actualVM)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMapFromVMWithTags(t *testing.T) {
|
func TestMapFromVMWithTags(t *testing.T) {
|
||||||
|
@ -109,9 +107,7 @@ func TestMapFromVMWithTags(t *testing.T) {
|
||||||
|
|
||||||
actualVM := mapFromVM(testVM)
|
actualVM := mapFromVM(testVM)
|
||||||
|
|
||||||
if !reflect.DeepEqual(expectedVM, actualVM) {
|
assert.Equal(t, expectedVM, actualVM)
|
||||||
t.Errorf("Expected %v got %v", expectedVM, actualVM)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMapFromVMScaleSetVMWithEmptyTags(t *testing.T) {
|
func TestMapFromVMScaleSetVMWithEmptyTags(t *testing.T) {
|
||||||
|
@ -154,9 +150,7 @@ func TestMapFromVMScaleSetVMWithEmptyTags(t *testing.T) {
|
||||||
|
|
||||||
actualVM := mapFromVMScaleSetVM(testVM, scaleSet)
|
actualVM := mapFromVMScaleSetVM(testVM, scaleSet)
|
||||||
|
|
||||||
if !reflect.DeepEqual(expectedVM, actualVM) {
|
assert.Equal(t, expectedVM, actualVM)
|
||||||
t.Errorf("Expected %v got %v", expectedVM, actualVM)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMapFromVMScaleSetVMWithTags(t *testing.T) {
|
func TestMapFromVMScaleSetVMWithTags(t *testing.T) {
|
||||||
|
@ -202,9 +196,7 @@ func TestMapFromVMScaleSetVMWithTags(t *testing.T) {
|
||||||
|
|
||||||
actualVM := mapFromVMScaleSetVM(testVM, scaleSet)
|
actualVM := mapFromVMScaleSetVM(testVM, scaleSet)
|
||||||
|
|
||||||
if !reflect.DeepEqual(expectedVM, actualVM) {
|
assert.Equal(t, expectedVM, actualVM)
|
||||||
t.Errorf("Expected %v got %v", expectedVM, actualVM)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNewAzureResourceFromID(t *testing.T) {
|
func TestNewAzureResourceFromID(t *testing.T) {
|
||||||
|
@ -222,8 +214,6 @@ func TestNewAzureResourceFromID(t *testing.T) {
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
actual, _ := newAzureResourceFromID(tc.id, nil)
|
actual, _ := newAzureResourceFromID(tc.id, nil)
|
||||||
if !reflect.DeepEqual(tc.expected, actual) {
|
assert.Equal(t, tc.expected, actual)
|
||||||
t.Errorf("Expected %v got %v", tc.expected, actual)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,18 +15,18 @@ package consul
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"testing"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
"go.uber.org/goleak"
|
"go.uber.org/goleak"
|
||||||
|
|
||||||
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
@ -251,7 +251,7 @@ func newServer(t *testing.T) (*httptest.Server, *SDConfig) {
|
||||||
w.Write([]byte(response))
|
w.Write([]byte(response))
|
||||||
}))
|
}))
|
||||||
stuburl, err := url.Parse(stub.URL)
|
stuburl, err := url.Parse(stub.URL)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
config := &SDConfig{
|
config := &SDConfig{
|
||||||
Server: stuburl.Host,
|
Server: stuburl.Host,
|
||||||
|
@ -264,18 +264,18 @@ func newServer(t *testing.T) (*httptest.Server, *SDConfig) {
|
||||||
func newDiscovery(t *testing.T, config *SDConfig) *Discovery {
|
func newDiscovery(t *testing.T, config *SDConfig) *Discovery {
|
||||||
logger := log.NewNopLogger()
|
logger := log.NewNopLogger()
|
||||||
d, err := NewDiscovery(config, logger)
|
d, err := NewDiscovery(config, logger)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
return d
|
return d
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkOneTarget(t *testing.T, tg []*targetgroup.Group) {
|
func checkOneTarget(t *testing.T, tg []*targetgroup.Group) {
|
||||||
testutil.Equals(t, 1, len(tg))
|
assert.Equal(t, 1, len(tg))
|
||||||
target := tg[0]
|
target := tg[0]
|
||||||
testutil.Equals(t, "test-dc", string(target.Labels["__meta_consul_dc"]))
|
assert.Equal(t, "test-dc", string(target.Labels["__meta_consul_dc"]))
|
||||||
testutil.Equals(t, target.Source, string(target.Labels["__meta_consul_service"]))
|
assert.Equal(t, target.Source, string(target.Labels["__meta_consul_service"]))
|
||||||
if target.Source == "test" {
|
if target.Source == "test" {
|
||||||
// test service should have one node.
|
// test service should have one node.
|
||||||
testutil.Assert(t, len(target.Targets) > 0, "Test service should have one node")
|
assert.True(t, len(target.Targets) > 0, "Test service should have one node")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -359,7 +359,7 @@ func TestGetDatacenterShouldReturnError(t *testing.T) {
|
||||||
} {
|
} {
|
||||||
stub := httptest.NewServer(http.HandlerFunc(tc.handler))
|
stub := httptest.NewServer(http.HandlerFunc(tc.handler))
|
||||||
stuburl, err := url.Parse(stub.URL)
|
stuburl, err := url.Parse(stub.URL)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
config := &SDConfig{
|
config := &SDConfig{
|
||||||
Server: stuburl.Host,
|
Server: stuburl.Host,
|
||||||
|
@ -370,13 +370,13 @@ func TestGetDatacenterShouldReturnError(t *testing.T) {
|
||||||
d := newDiscovery(t, config)
|
d := newDiscovery(t, config)
|
||||||
|
|
||||||
// Should be empty if not initialized.
|
// Should be empty if not initialized.
|
||||||
testutil.Equals(t, "", d.clientDatacenter)
|
assert.Equal(t, "", d.clientDatacenter)
|
||||||
|
|
||||||
err = d.getDatacenter()
|
err = d.getDatacenter()
|
||||||
|
|
||||||
// An error should be returned.
|
// An error should be returned.
|
||||||
testutil.Equals(t, tc.errMessage, err.Error())
|
assert.Equal(t, tc.errMessage, err.Error())
|
||||||
// Should still be empty.
|
// Should still be empty.
|
||||||
testutil.Equals(t, "", d.clientDatacenter)
|
assert.Equal(t, "", d.clientDatacenter)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,7 +21,7 @@ import (
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type DigitalOceanSDTestSuite struct {
|
type DigitalOceanSDTestSuite struct {
|
||||||
|
@ -47,21 +47,21 @@ func TestDigitalOceanSDRefresh(t *testing.T) {
|
||||||
cfg := DefaultSDConfig
|
cfg := DefaultSDConfig
|
||||||
cfg.HTTPClientConfig.BearerToken = tokenID
|
cfg.HTTPClientConfig.BearerToken = tokenID
|
||||||
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
endpoint, err := url.Parse(sdmock.Mock.Endpoint())
|
endpoint, err := url.Parse(sdmock.Mock.Endpoint())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
d.client.BaseURL = endpoint
|
d.client.BaseURL = endpoint
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tgs, err := d.refresh(ctx)
|
tgs, err := d.refresh(ctx)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
|
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Assert(t, tg != nil, "tg should not be nil")
|
assert.NotNil(t, tg)
|
||||||
testutil.Assert(t, tg.Targets != nil, "tg.targets should not be nil")
|
assert.NotNil(t, tg.Targets)
|
||||||
testutil.Equals(t, 4, len(tg.Targets))
|
assert.Equal(t, 4, len(tg.Targets))
|
||||||
|
|
||||||
for i, lbls := range []model.LabelSet{
|
for i, lbls := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -119,7 +119,7 @@ func TestDigitalOceanSDRefresh(t *testing.T) {
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, lbls, tg.Targets[i])
|
assert.Equal(t, lbls, tg.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,8 +18,8 @@ import (
|
||||||
"reflect"
|
"reflect"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
|
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -22,12 +22,12 @@ import (
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/miekg/dns"
|
"github.com/miekg/dns"
|
||||||
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"go.uber.org/goleak"
|
"go.uber.org/goleak"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
@ -205,8 +205,8 @@ func TestDNS(t *testing.T) {
|
||||||
sd.lookupFn = tc.lookup
|
sd.lookupFn = tc.lookup
|
||||||
|
|
||||||
tgs, err := sd.refresh(context.Background())
|
tgs, err := sd.refresh(context.Background())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, tc.expected, tgs)
|
assert.Equal(t, tc.expected, tgs)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -296,7 +296,7 @@ func TestSDConfigUnmarshalYAML(t *testing.T) {
|
||||||
var config SDConfig
|
var config SDConfig
|
||||||
d := marshal(c.input)
|
d := marshal(c.input)
|
||||||
err := config.UnmarshalYAML(unmarshal(d))
|
err := config.UnmarshalYAML(unmarshal(d))
|
||||||
testutil.Equals(t, c.expectErr, err != nil)
|
assert.Equal(t, c.expectErr, err != nil)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,10 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
// SDMock is the interface for the DigitalOcean mock
|
// SDMock is the interface for the DigitalOcean mock
|
||||||
|
@ -63,7 +64,7 @@ func (m *SDMock) Setup() {
|
||||||
func (m *SDMock) SetupHandlers() {
|
func (m *SDMock) SetupHandlers() {
|
||||||
headers := make(map[string]string)
|
headers := make(map[string]string)
|
||||||
rawHeaders, err := ioutil.ReadFile(filepath.Join("testdata", m.directory, "headers.yml"))
|
rawHeaders, err := ioutil.ReadFile(filepath.Join("testdata", m.directory, "headers.yml"))
|
||||||
testutil.Ok(m.t, err)
|
assert.NoError(m.t, err)
|
||||||
yaml.Unmarshal(rawHeaders, &headers)
|
yaml.Unmarshal(rawHeaders, &headers)
|
||||||
|
|
||||||
prefix := "/"
|
prefix := "/"
|
||||||
|
|
|
@ -18,6 +18,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/docker/docker/api/types"
|
"github.com/docker/docker/api/types"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -36,21 +36,21 @@ role: nodes
|
||||||
host: %s
|
host: %s
|
||||||
`, url)
|
`, url)
|
||||||
var cfg SDConfig
|
var cfg SDConfig
|
||||||
testutil.Ok(t, yaml.Unmarshal([]byte(cfgString), &cfg))
|
assert.NoError(t, yaml.Unmarshal([]byte(cfgString), &cfg))
|
||||||
|
|
||||||
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tgs, err := d.refresh(ctx)
|
tgs, err := d.refresh(ctx)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
|
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Assert(t, tg != nil, "tg should not be nil")
|
assert.NotNil(t, tg)
|
||||||
testutil.Assert(t, tg.Targets != nil, "tg.targets should not be nil")
|
assert.NotNil(t, tg.Targets)
|
||||||
testutil.Equals(t, 5, len(tg.Targets))
|
assert.Equal(t, 5, len(tg.Targets))
|
||||||
|
|
||||||
for i, lbls := range []model.LabelSet{
|
for i, lbls := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -124,7 +124,7 @@ host: %s
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, lbls, tg.Targets[i])
|
assert.Equal(t, lbls, tg.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -36,21 +36,21 @@ role: services
|
||||||
host: %s
|
host: %s
|
||||||
`, url)
|
`, url)
|
||||||
var cfg SDConfig
|
var cfg SDConfig
|
||||||
testutil.Ok(t, yaml.Unmarshal([]byte(cfgString), &cfg))
|
assert.NoError(t, yaml.Unmarshal([]byte(cfgString), &cfg))
|
||||||
|
|
||||||
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tgs, err := d.refresh(ctx)
|
tgs, err := d.refresh(ctx)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
|
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Assert(t, tg != nil, "tg should not be nil")
|
assert.NotNil(t, tg)
|
||||||
testutil.Assert(t, tg.Targets != nil, "tg.targets should not be nil")
|
assert.NotNil(t, tg.Targets)
|
||||||
testutil.Equals(t, 15, len(tg.Targets))
|
assert.Equal(t, 15, len(tg.Targets))
|
||||||
|
|
||||||
for i, lbls := range []model.LabelSet{
|
for i, lbls := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -310,7 +310,7 @@ host: %s
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, lbls, tg.Targets[i])
|
assert.Equal(t, lbls, tg.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -36,21 +36,21 @@ role: tasks
|
||||||
host: %s
|
host: %s
|
||||||
`, url)
|
`, url)
|
||||||
var cfg SDConfig
|
var cfg SDConfig
|
||||||
testutil.Ok(t, yaml.Unmarshal([]byte(cfgString), &cfg))
|
assert.NoError(t, yaml.Unmarshal([]byte(cfgString), &cfg))
|
||||||
|
|
||||||
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tgs, err := d.refresh(ctx)
|
tgs, err := d.refresh(ctx)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
|
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Assert(t, tg != nil, "tg should not be nil")
|
assert.NotNil(t, tg)
|
||||||
testutil.Assert(t, tg.Targets != nil, "tg.targets should not be nil")
|
assert.NotNil(t, tg.Targets)
|
||||||
testutil.Equals(t, 27, len(tg.Targets))
|
assert.Equal(t, 27, len(tg.Targets))
|
||||||
|
|
||||||
for i, lbls := range []model.LabelSet{
|
for i, lbls := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -787,7 +787,7 @@ host: %s
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, lbls, tg.Targets[i])
|
assert.Equal(t, lbls, tg.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestFetchApps(t *testing.T) {
|
func TestFetchApps(t *testing.T) {
|
||||||
|
@ -182,19 +182,19 @@ func TestFetchApps(t *testing.T) {
|
||||||
defer ts.Close()
|
defer ts.Close()
|
||||||
|
|
||||||
apps, err := fetchApps(context.TODO(), ts.URL, &http.Client{})
|
apps, err := fetchApps(context.TODO(), ts.URL, &http.Client{})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
testutil.Equals(t, len(apps.Applications), 2)
|
assert.Equal(t, len(apps.Applications), 2)
|
||||||
testutil.Equals(t, apps.Applications[0].Name, "CONFIG-SERVICE")
|
assert.Equal(t, apps.Applications[0].Name, "CONFIG-SERVICE")
|
||||||
testutil.Equals(t, apps.Applications[1].Name, "META-SERVICE")
|
assert.Equal(t, apps.Applications[1].Name, "META-SERVICE")
|
||||||
|
|
||||||
testutil.Equals(t, len(apps.Applications[1].Instances), 2)
|
assert.Equal(t, len(apps.Applications[1].Instances), 2)
|
||||||
testutil.Equals(t, apps.Applications[1].Instances[0].InstanceID, "meta-service002.test.com:meta-service:8080")
|
assert.Equal(t, apps.Applications[1].Instances[0].InstanceID, "meta-service002.test.com:meta-service:8080")
|
||||||
testutil.Equals(t, apps.Applications[1].Instances[0].Metadata.Items[0].XMLName.Local, "project")
|
assert.Equal(t, apps.Applications[1].Instances[0].Metadata.Items[0].XMLName.Local, "project")
|
||||||
testutil.Equals(t, apps.Applications[1].Instances[0].Metadata.Items[0].Content, "meta-service")
|
assert.Equal(t, apps.Applications[1].Instances[0].Metadata.Items[0].Content, "meta-service")
|
||||||
testutil.Equals(t, apps.Applications[1].Instances[0].Metadata.Items[1].XMLName.Local, "management.port")
|
assert.Equal(t, apps.Applications[1].Instances[0].Metadata.Items[1].XMLName.Local, "management.port")
|
||||||
testutil.Equals(t, apps.Applications[1].Instances[0].Metadata.Items[1].Content, "8090")
|
assert.Equal(t, apps.Applications[1].Instances[0].Metadata.Items[1].Content, "8090")
|
||||||
testutil.Equals(t, apps.Applications[1].Instances[1].InstanceID, "meta-service001.test.com:meta-service:8080")
|
assert.Equal(t, apps.Applications[1].Instances[1].InstanceID, "meta-service001.test.com:meta-service:8080")
|
||||||
}
|
}
|
||||||
|
|
||||||
func Test500ErrorHttpResponse(t *testing.T) {
|
func Test500ErrorHttpResponse(t *testing.T) {
|
||||||
|
@ -209,5 +209,5 @@ func Test500ErrorHttpResponse(t *testing.T) {
|
||||||
defer ts.Close()
|
defer ts.Close()
|
||||||
|
|
||||||
_, err := fetchApps(context.TODO(), ts.URL, &http.Client{})
|
_, err := fetchApps(context.TODO(), ts.URL, &http.Client{})
|
||||||
testutil.NotOk(t, err, "5xx HTTP response")
|
assert.Error(t, err, "5xx HTTP response")
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,14 +15,14 @@ package eureka
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ func testUpdateServices(respHandler http.HandlerFunc) ([]*targetgroup.Group, err
|
||||||
|
|
||||||
func TestEurekaSDHandleError(t *testing.T) {
|
func TestEurekaSDHandleError(t *testing.T) {
|
||||||
var (
|
var (
|
||||||
errTesting = errors.Errorf("non 2xx status '%d' response during eureka service discovery", http.StatusInternalServerError)
|
errTesting = "non 2xx status '500' response during eureka service discovery"
|
||||||
respHandler = func(w http.ResponseWriter, r *http.Request) {
|
respHandler = func(w http.ResponseWriter, r *http.Request) {
|
||||||
w.WriteHeader(http.StatusInternalServerError)
|
w.WriteHeader(http.StatusInternalServerError)
|
||||||
w.Header().Set("Content-Type", "application/xml")
|
w.Header().Set("Content-Type", "application/xml")
|
||||||
|
@ -54,8 +54,8 @@ func TestEurekaSDHandleError(t *testing.T) {
|
||||||
)
|
)
|
||||||
tgs, err := testUpdateServices(respHandler)
|
tgs, err := testUpdateServices(respHandler)
|
||||||
|
|
||||||
testutil.ErrorEqual(t, err, errTesting)
|
assert.EqualError(t, err, errTesting)
|
||||||
testutil.Equals(t, len(tgs), 0)
|
assert.Equal(t, len(tgs), 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEurekaSDEmptyList(t *testing.T) {
|
func TestEurekaSDEmptyList(t *testing.T) {
|
||||||
|
@ -71,8 +71,8 @@ func TestEurekaSDEmptyList(t *testing.T) {
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
tgs, err := testUpdateServices(respHandler)
|
tgs, err := testUpdateServices(respHandler)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, len(tgs), 1)
|
assert.Equal(t, len(tgs), 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEurekaSDSendGroup(t *testing.T) {
|
func TestEurekaSDSendGroup(t *testing.T) {
|
||||||
|
@ -231,16 +231,16 @@ func TestEurekaSDSendGroup(t *testing.T) {
|
||||||
)
|
)
|
||||||
|
|
||||||
tgs, err := testUpdateServices(respHandler)
|
tgs, err := testUpdateServices(respHandler)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, len(tgs), 1)
|
assert.Equal(t, len(tgs), 1)
|
||||||
|
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Equals(t, tg.Source, "eureka")
|
assert.Equal(t, tg.Source, "eureka")
|
||||||
testutil.Equals(t, len(tg.Targets), 4)
|
assert.Equal(t, len(tg.Targets), 4)
|
||||||
|
|
||||||
tgt := tg.Targets[0]
|
tgt := tg.Targets[0]
|
||||||
testutil.Equals(t, tgt[model.AddressLabel], model.LabelValue("config-service001.test.com:8080"))
|
assert.Equal(t, tgt[model.AddressLabel], model.LabelValue("config-service001.test.com:8080"))
|
||||||
|
|
||||||
tgt = tg.Targets[2]
|
tgt = tg.Targets[2]
|
||||||
testutil.Equals(t, tgt[model.AddressLabel], model.LabelValue("meta-service002.test.com:8080"))
|
assert.Equal(t, tgt[model.AddressLabel], model.LabelValue("meta-service002.test.com:8080"))
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,10 +26,10 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"go.uber.org/goleak"
|
"go.uber.org/goleak"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
@ -54,7 +54,7 @@ func newTestRunner(t *testing.T) *testRunner {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
tmpDir, err := ioutil.TempDir("", "prometheus-file-sd")
|
tmpDir, err := ioutil.TempDir("", "prometheus-file-sd")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
return &testRunner{
|
return &testRunner{
|
||||||
T: t,
|
T: t,
|
||||||
|
@ -77,19 +77,19 @@ func (t *testRunner) copyFileTo(src string, name string) string {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
newf, err := ioutil.TempFile(t.dir, "")
|
newf, err := ioutil.TempFile(t.dir, "")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
f, err := os.Open(src)
|
f, err := os.Open(src)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
_, err = io.Copy(newf, f)
|
_, err = io.Copy(newf, f)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, f.Close())
|
assert.NoError(t, f.Close())
|
||||||
testutil.Ok(t, newf.Close())
|
assert.NoError(t, newf.Close())
|
||||||
|
|
||||||
dst := filepath.Join(t.dir, name)
|
dst := filepath.Join(t.dir, name)
|
||||||
err = os.Rename(newf.Name(), dst)
|
err = os.Rename(newf.Name(), dst)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
return dst
|
return dst
|
||||||
}
|
}
|
||||||
|
@ -99,14 +99,14 @@ func (t *testRunner) writeString(file string, data string) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
newf, err := ioutil.TempFile(t.dir, "")
|
newf, err := ioutil.TempFile(t.dir, "")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
_, err = newf.WriteString(data)
|
_, err = newf.WriteString(data)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, newf.Close())
|
assert.NoError(t, newf.Close())
|
||||||
|
|
||||||
err = os.Rename(newf.Name(), file)
|
err = os.Rename(newf.Name(), file)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// appendString appends a string to a file.
|
// appendString appends a string to a file.
|
||||||
|
@ -114,11 +114,11 @@ func (t *testRunner) appendString(file, data string) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
||||||
f, err := os.OpenFile(file, os.O_WRONLY|os.O_APPEND, 0)
|
f, err := os.OpenFile(file, os.O_WRONLY|os.O_APPEND, 0)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
_, err = f.WriteString(data)
|
_, err = f.WriteString(data)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// run starts the file SD and the loop receiving target groups updates.
|
// run starts the file SD and the loop receiving target groups updates.
|
||||||
|
@ -230,7 +230,7 @@ func (t *testRunner) requireTargetGroups(expected, got []*targetgroup.Group) {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, string(b1), string(b2))
|
assert.Equal(t, string(b1), string(b2))
|
||||||
}
|
}
|
||||||
|
|
||||||
// validTg() maps to fixtures/valid.{json,yml}.
|
// validTg() maps to fixtures/valid.{json,yml}.
|
||||||
|
@ -468,7 +468,7 @@ func TestRemoveFile(t *testing.T) {
|
||||||
|
|
||||||
// Verify that we receive the update about the target groups being removed.
|
// Verify that we receive the update about the target groups being removed.
|
||||||
ref := runner.lastReceive()
|
ref := runner.lastReceive()
|
||||||
testutil.Ok(t, os.Remove(sdFile))
|
assert.NoError(t, os.Remove(sdFile))
|
||||||
runner.requireUpdate(
|
runner.requireUpdate(
|
||||||
ref,
|
ref,
|
||||||
[]*targetgroup.Group{
|
[]*targetgroup.Group{
|
||||||
|
|
|
@ -26,6 +26,7 @@ import (
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/common/version"
|
"github.com/prometheus/common/version"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/refresh"
|
"github.com/prometheus/prometheus/discovery/refresh"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
|
|
|
@ -16,10 +16,11 @@ package hetzner
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
"testing"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type hcloudSDTestSuite struct {
|
type hcloudSDTestSuite struct {
|
||||||
|
@ -43,16 +44,16 @@ func TestHCloudSDRefresh(t *testing.T) {
|
||||||
cfg.hcloudEndpoint = suite.Mock.Endpoint()
|
cfg.hcloudEndpoint = suite.Mock.Endpoint()
|
||||||
|
|
||||||
d, err := newHcloudDiscovery(&cfg, log.NewNopLogger())
|
d, err := newHcloudDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
targetGroups, err := d.refresh(context.Background())
|
targetGroups, err := d.refresh(context.Background())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 1, len(targetGroups))
|
assert.Equal(t, 1, len(targetGroups))
|
||||||
|
|
||||||
targetGroup := targetGroups[0]
|
targetGroup := targetGroups[0]
|
||||||
testutil.Assert(t, targetGroup != nil, "targetGroup should not be nil")
|
assert.NotNil(t, targetGroup, "targetGroup should not be nil")
|
||||||
testutil.Assert(t, targetGroup.Targets != nil, "targetGroup.targets should not be nil")
|
assert.NotNil(t, targetGroup.Targets, "targetGroup.targets should not be nil")
|
||||||
testutil.Equals(t, 3, len(targetGroup.Targets))
|
assert.Equal(t, 3, len(targetGroup.Targets))
|
||||||
|
|
||||||
for i, labelSet := range []model.LabelSet{
|
for i, labelSet := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -118,7 +119,7 @@ func TestHCloudSDRefresh(t *testing.T) {
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, labelSet, targetGroup.Targets[i])
|
assert.Equal(t, labelSet, targetGroup.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,13 +15,14 @@ package hetzner
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"github.com/pkg/errors"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/hetznercloud/hcloud-go/hcloud"
|
"github.com/hetznercloud/hcloud-go/hcloud"
|
||||||
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery"
|
"github.com/prometheus/prometheus/discovery"
|
||||||
"github.com/prometheus/prometheus/discovery/refresh"
|
"github.com/prometheus/prometheus/discovery/refresh"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
|
|
|
@ -30,6 +30,7 @@ import (
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/common/version"
|
"github.com/prometheus/common/version"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/refresh"
|
"github.com/prometheus/prometheus/discovery/refresh"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
|
@ -16,11 +16,12 @@ package hetzner
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
"testing"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type robotSDTestSuite struct {
|
type robotSDTestSuite struct {
|
||||||
|
@ -42,16 +43,16 @@ func TestRobotSDRefresh(t *testing.T) {
|
||||||
cfg.robotEndpoint = suite.Mock.Endpoint()
|
cfg.robotEndpoint = suite.Mock.Endpoint()
|
||||||
|
|
||||||
d, err := newRobotDiscovery(&cfg, log.NewNopLogger())
|
d, err := newRobotDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
targetGroups, err := d.refresh(context.Background())
|
targetGroups, err := d.refresh(context.Background())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 1, len(targetGroups))
|
assert.Equal(t, 1, len(targetGroups))
|
||||||
|
|
||||||
targetGroup := targetGroups[0]
|
targetGroup := targetGroups[0]
|
||||||
testutil.Assert(t, targetGroup != nil, "targetGroup should not be nil")
|
assert.NotNil(t, targetGroup, "targetGroup should not be nil")
|
||||||
testutil.Assert(t, targetGroup.Targets != nil, "targetGroup.targets should not be nil")
|
assert.NotNil(t, targetGroup.Targets, "targetGroup.targets should not be nil")
|
||||||
testutil.Equals(t, 2, len(targetGroup.Targets))
|
assert.Equal(t, 2, len(targetGroup.Targets))
|
||||||
|
|
||||||
for i, labelSet := range []model.LabelSet{
|
for i, labelSet := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -79,7 +80,7 @@ func TestRobotSDRefresh(t *testing.T) {
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, labelSet, targetGroup.Targets[i])
|
assert.Equal(t, labelSet, targetGroup.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -91,11 +92,11 @@ func TestRobotSDRefreshHandleError(t *testing.T) {
|
||||||
cfg.robotEndpoint = suite.Mock.Endpoint()
|
cfg.robotEndpoint = suite.Mock.Endpoint()
|
||||||
|
|
||||||
d, err := newRobotDiscovery(&cfg, log.NewNopLogger())
|
d, err := newRobotDiscovery(&cfg, log.NewNopLogger())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
targetGroups, err := d.refresh(context.Background())
|
targetGroups, err := d.refresh(context.Background())
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Equals(t, "non 2xx status '401' response during hetzner service discovery with role robot", err.Error())
|
assert.Equal(t, "non 2xx status '401' response during hetzner service discovery with role robot", err.Error())
|
||||||
|
|
||||||
testutil.Equals(t, 0, len(targetGroups))
|
assert.Equal(t, 0, len(targetGroups))
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,12 +18,13 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
|
||||||
v1 "k8s.io/api/core/v1"
|
v1 "k8s.io/api/core/v1"
|
||||||
disv1beta1 "k8s.io/api/discovery/v1beta1"
|
disv1beta1 "k8s.io/api/discovery/v1beta1"
|
||||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||||
"k8s.io/apimachinery/pkg/runtime"
|
"k8s.io/apimachinery/pkg/runtime"
|
||||||
"k8s.io/apimachinery/pkg/types"
|
"k8s.io/apimachinery/pkg/types"
|
||||||
|
|
||||||
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
func strptr(str string) *string {
|
func strptr(str string) *string {
|
||||||
|
|
|
@ -20,6 +20,7 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"k8s.io/apimachinery/pkg/runtime"
|
"k8s.io/apimachinery/pkg/runtime"
|
||||||
"k8s.io/client-go/kubernetes"
|
"k8s.io/client-go/kubernetes"
|
||||||
"k8s.io/client-go/kubernetes/fake"
|
"k8s.io/client-go/kubernetes/fake"
|
||||||
|
@ -150,7 +151,7 @@ func requireTargetGroups(t *testing.T, expected, res map[string]*targetgroup.Gro
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, string(b1), string(b2))
|
assert.Equal(t, string(b1), string(b2))
|
||||||
}
|
}
|
||||||
|
|
||||||
type hasSynced interface {
|
type hasSynced interface {
|
||||||
|
|
|
@ -16,7 +16,6 @@ package discovery
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"reflect"
|
|
||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
"testing"
|
"testing"
|
||||||
|
@ -25,6 +24,8 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
client_testutil "github.com/prometheus/client_golang/prometheus/testutil"
|
client_testutil "github.com/prometheus/client_golang/prometheus/testutil"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/prometheus/prometheus/util/testutil"
|
||||||
)
|
)
|
||||||
|
@ -696,25 +697,12 @@ func TestTargetUpdatesOrder(t *testing.T) {
|
||||||
|
|
||||||
func assertEqualGroups(t *testing.T, got, expected []*targetgroup.Group, msg func(got, expected string) string) {
|
func assertEqualGroups(t *testing.T, got, expected []*targetgroup.Group, msg func(got, expected string) string) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
format := func(groups []*targetgroup.Group) string {
|
|
||||||
var s string
|
|
||||||
for i, group := range groups {
|
|
||||||
if i > 0 {
|
|
||||||
s += ","
|
|
||||||
}
|
|
||||||
s += group.Source + ":" + fmt.Sprint(group.Targets)
|
|
||||||
}
|
|
||||||
return s
|
|
||||||
}
|
|
||||||
|
|
||||||
// Need to sort by the groups's source as the received order is not guaranteed.
|
// Need to sort by the groups's source as the received order is not guaranteed.
|
||||||
sort.Sort(byGroupSource(got))
|
sort.Sort(byGroupSource(got))
|
||||||
sort.Sort(byGroupSource(expected))
|
sort.Sort(byGroupSource(expected))
|
||||||
|
|
||||||
if !reflect.DeepEqual(got, expected) {
|
assert.Equal(t, expected, got)
|
||||||
t.Errorf(msg(format(got), format(expected)))
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func staticConfig(addrs ...string) StaticConfig {
|
func staticConfig(addrs ...string) StaticConfig {
|
||||||
|
@ -894,10 +882,7 @@ func TestApplyConfigDoesNotModifyStaticTargets(t *testing.T) {
|
||||||
<-discoveryManager.SyncCh()
|
<-discoveryManager.SyncCh()
|
||||||
|
|
||||||
for _, cfg := range cfgs {
|
for _, cfg := range cfgs {
|
||||||
if !reflect.DeepEqual(originalConfig, cfg) {
|
assert.Equal(t, originalConfig, cfg)
|
||||||
t.Fatalf("discovery manager modified static config \n expected: %v\n got: %v\n",
|
|
||||||
originalConfig, cfg)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type OpenstackSDHypervisorTestSuite struct {
|
type OpenstackSDHypervisorTestSuite struct {
|
||||||
|
@ -55,12 +55,12 @@ func TestOpenstackSDHypervisorRefresh(t *testing.T) {
|
||||||
hypervisor, _ := mock.openstackAuthSuccess()
|
hypervisor, _ := mock.openstackAuthSuccess()
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tgs, err := hypervisor.refresh(ctx)
|
tgs, err := hypervisor.refresh(ctx)
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, tg != nil, "")
|
assert.NotNil(t, tg)
|
||||||
testutil.Assert(t, tg.Targets != nil, "")
|
assert.NotNil(t, tg.Targets)
|
||||||
testutil.Equals(t, 2, len(tg.Targets))
|
assert.Equal(t, 2, len(tg.Targets))
|
||||||
|
|
||||||
for l, v := range map[string]string{
|
for l, v := range map[string]string{
|
||||||
"__address__": "172.16.70.14:0",
|
"__address__": "172.16.70.14:0",
|
||||||
|
@ -71,7 +71,7 @@ func TestOpenstackSDHypervisorRefresh(t *testing.T) {
|
||||||
"__meta_openstack_hypervisor_status": "enabled",
|
"__meta_openstack_hypervisor_status": "enabled",
|
||||||
"__meta_openstack_hypervisor_id": "1",
|
"__meta_openstack_hypervisor_id": "1",
|
||||||
} {
|
} {
|
||||||
testutil.Equals(t, model.LabelValue(v), tg.Targets[0][model.LabelName(l)])
|
assert.Equal(t, model.LabelValue(v), tg.Targets[0][model.LabelName(l)])
|
||||||
}
|
}
|
||||||
|
|
||||||
for l, v := range map[string]string{
|
for l, v := range map[string]string{
|
||||||
|
@ -83,7 +83,7 @@ func TestOpenstackSDHypervisorRefresh(t *testing.T) {
|
||||||
"__meta_openstack_hypervisor_status": "enabled",
|
"__meta_openstack_hypervisor_status": "enabled",
|
||||||
"__meta_openstack_hypervisor_id": "721",
|
"__meta_openstack_hypervisor_id": "721",
|
||||||
} {
|
} {
|
||||||
testutil.Equals(t, model.LabelValue(v), tg.Targets[1][model.LabelName(l)])
|
assert.Equal(t, model.LabelValue(v), tg.Targets[1][model.LabelName(l)])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,6 +95,6 @@ func TestOpenstackSDHypervisorRefreshWithDoneContext(t *testing.T) {
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
ctx, cancel := context.WithCancel(context.Background())
|
||||||
cancel()
|
cancel()
|
||||||
_, err := hypervisor.refresh(ctx)
|
_, err := hypervisor.refresh(ctx)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, strings.Contains(err.Error(), context.Canceled.Error()), "%q doesn't contain %q", err, context.Canceled)
|
assert.True(t, strings.Contains(err.Error(), context.Canceled.Error()), "%q doesn't contain %q", err, context.Canceled)
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ import (
|
||||||
"github.com/gophercloud/gophercloud/pagination"
|
"github.com/gophercloud/gophercloud/pagination"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
)
|
)
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type OpenstackSDInstanceTestSuite struct {
|
type OpenstackSDInstanceTestSuite struct {
|
||||||
|
@ -57,18 +57,18 @@ func TestOpenstackSDInstanceRefresh(t *testing.T) {
|
||||||
mock.SetupTest(t)
|
mock.SetupTest(t)
|
||||||
|
|
||||||
instance, err := mock.openstackAuthSuccess()
|
instance, err := mock.openstackAuthSuccess()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tgs, err := instance.refresh(ctx)
|
tgs, err := instance.refresh(ctx)
|
||||||
|
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
|
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Assert(t, tg != nil, "")
|
assert.NotNil(t, tg)
|
||||||
testutil.Assert(t, tg.Targets != nil, "")
|
assert.NotNil(t, tg.Targets)
|
||||||
testutil.Equals(t, 4, len(tg.Targets))
|
assert.Equal(t, 4, len(tg.Targets))
|
||||||
|
|
||||||
for i, lbls := range []model.LabelSet{
|
for i, lbls := range []model.LabelSet{
|
||||||
{
|
{
|
||||||
|
@ -121,7 +121,7 @@ func TestOpenstackSDInstanceRefresh(t *testing.T) {
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
t.Run(fmt.Sprintf("item %d", i), func(t *testing.T) {
|
||||||
testutil.Equals(t, lbls, tg.Targets[i])
|
assert.Equal(t, lbls, tg.Targets[i])
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -134,6 +134,6 @@ func TestOpenstackSDInstanceRefreshWithDoneContext(t *testing.T) {
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
ctx, cancel := context.WithCancel(context.Background())
|
||||||
cancel()
|
cancel()
|
||||||
_, err := hypervisor.refresh(ctx)
|
_, err := hypervisor.refresh(ctx)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, strings.Contains(err.Error(), context.Canceled.Error()), "%q doesn't contain %q", err, context.Canceled)
|
assert.True(t, strings.Contains(err.Error(), context.Canceled.Error()), "%q doesn't contain %q", err, context.Canceled)
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,10 +20,10 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"go.uber.org/goleak"
|
"go.uber.org/goleak"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
@ -73,10 +73,10 @@ func TestRefresh(t *testing.T) {
|
||||||
go d.Run(ctx, ch)
|
go d.Run(ctx, ch)
|
||||||
|
|
||||||
tg := <-ch
|
tg := <-ch
|
||||||
testutil.Equals(t, tg1, tg)
|
assert.Equal(t, tg1, tg)
|
||||||
|
|
||||||
tg = <-ch
|
tg = <-ch
|
||||||
testutil.Equals(t, tg2, tg)
|
assert.Equal(t, tg2, tg)
|
||||||
|
|
||||||
tick := time.NewTicker(2 * interval)
|
tick := time.NewTicker(2 * interval)
|
||||||
defer tick.Stop()
|
defer tick.Stop()
|
||||||
|
|
|
@ -21,8 +21,9 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
|
|
@ -18,9 +18,8 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"gopkg.in/yaml.v2"
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestTargetGroupStrictJsonUnmarshal(t *testing.T) {
|
func TestTargetGroupStrictJsonUnmarshal(t *testing.T) {
|
||||||
|
@ -54,8 +53,8 @@ func TestTargetGroupStrictJsonUnmarshal(t *testing.T) {
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
tg := Group{}
|
tg := Group{}
|
||||||
actual := tg.UnmarshalJSON([]byte(test.json))
|
actual := tg.UnmarshalJSON([]byte(test.json))
|
||||||
testutil.Equals(t, test.expectedReply, actual)
|
assert.Equal(t, test.expectedReply, actual)
|
||||||
testutil.Equals(t, test.expectedGroup, tg)
|
assert.Equal(t, test.expectedGroup, tg)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -93,8 +92,8 @@ func TestTargetGroupYamlMarshal(t *testing.T) {
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
actual, err := test.group.MarshalYAML()
|
actual, err := test.group.MarshalYAML()
|
||||||
testutil.Equals(t, test.expectedErr, err)
|
assert.Equal(t, test.expectedErr, err)
|
||||||
testutil.Equals(t, test.expectedYaml, string(marshal(actual)))
|
assert.Equal(t, test.expectedYaml, string(marshal(actual)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,8 +132,8 @@ func TestTargetGroupYamlUnmarshal(t *testing.T) {
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
tg := Group{}
|
tg := Group{}
|
||||||
actual := tg.UnmarshalYAML(unmarshal([]byte(test.yaml)))
|
actual := tg.UnmarshalYAML(unmarshal([]byte(test.yaml)))
|
||||||
testutil.Equals(t, test.expectedReply, actual)
|
assert.Equal(t, test.expectedReply, actual)
|
||||||
testutil.Equals(t, test.expectedGroup, tg)
|
assert.Equal(t, test.expectedGroup, tg)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -151,7 +150,7 @@ func TestString(t *testing.T) {
|
||||||
Group{Targets: []model.LabelSet{},
|
Group{Targets: []model.LabelSet{},
|
||||||
Source: "<source>",
|
Source: "<source>",
|
||||||
Labels: model.LabelSet{}}
|
Labels: model.LabelSet{}}
|
||||||
testutil.Equals(t, "<source>", group1.String())
|
assert.Equal(t, "<source>", group1.String())
|
||||||
testutil.Equals(t, "<source>", group2.String())
|
assert.Equal(t, "<source>", group2.String())
|
||||||
testutil.Equals(t, group1.String(), group2.String())
|
assert.Equal(t, group1.String(), group2.String())
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,8 +26,7 @@ import (
|
||||||
|
|
||||||
"github.com/prometheus/common/config"
|
"github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
@ -85,54 +84,54 @@ func newTritonDiscovery(c SDConfig) (*Discovery, error) {
|
||||||
|
|
||||||
func TestTritonSDNew(t *testing.T) {
|
func TestTritonSDNew(t *testing.T) {
|
||||||
td, err := newTritonDiscovery(conf)
|
td, err := newTritonDiscovery(conf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, td != nil, "")
|
assert.NotNil(t, td)
|
||||||
testutil.Assert(t, td.client != nil, "")
|
assert.NotNil(t, td.client)
|
||||||
testutil.Assert(t, td.interval != 0, "")
|
assert.True(t, td.interval != 0, "")
|
||||||
testutil.Assert(t, td.sdConfig != nil, "")
|
assert.NotNil(t, td.sdConfig)
|
||||||
testutil.Equals(t, conf.Account, td.sdConfig.Account)
|
assert.Equal(t, conf.Account, td.sdConfig.Account)
|
||||||
testutil.Equals(t, conf.DNSSuffix, td.sdConfig.DNSSuffix)
|
assert.Equal(t, conf.DNSSuffix, td.sdConfig.DNSSuffix)
|
||||||
testutil.Equals(t, conf.Endpoint, td.sdConfig.Endpoint)
|
assert.Equal(t, conf.Endpoint, td.sdConfig.Endpoint)
|
||||||
testutil.Equals(t, conf.Port, td.sdConfig.Port)
|
assert.Equal(t, conf.Port, td.sdConfig.Port)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDNewBadConfig(t *testing.T) {
|
func TestTritonSDNewBadConfig(t *testing.T) {
|
||||||
td, err := newTritonDiscovery(badconf)
|
td, err := newTritonDiscovery(badconf)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, td == nil, "")
|
assert.True(t, td == nil, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDNewGroupsConfig(t *testing.T) {
|
func TestTritonSDNewGroupsConfig(t *testing.T) {
|
||||||
td, err := newTritonDiscovery(groupsconf)
|
td, err := newTritonDiscovery(groupsconf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, td != nil, "")
|
assert.NotNil(t, td)
|
||||||
testutil.Assert(t, td.client != nil, "")
|
assert.NotNil(t, td.client)
|
||||||
testutil.Assert(t, td.interval != 0, "")
|
assert.True(t, td.interval != 0, "")
|
||||||
testutil.Assert(t, td.sdConfig != nil, "")
|
assert.NotNil(t, td.sdConfig)
|
||||||
testutil.Equals(t, groupsconf.Account, td.sdConfig.Account)
|
assert.Equal(t, groupsconf.Account, td.sdConfig.Account)
|
||||||
testutil.Equals(t, groupsconf.DNSSuffix, td.sdConfig.DNSSuffix)
|
assert.Equal(t, groupsconf.DNSSuffix, td.sdConfig.DNSSuffix)
|
||||||
testutil.Equals(t, groupsconf.Endpoint, td.sdConfig.Endpoint)
|
assert.Equal(t, groupsconf.Endpoint, td.sdConfig.Endpoint)
|
||||||
testutil.Equals(t, groupsconf.Groups, td.sdConfig.Groups)
|
assert.Equal(t, groupsconf.Groups, td.sdConfig.Groups)
|
||||||
testutil.Equals(t, groupsconf.Port, td.sdConfig.Port)
|
assert.Equal(t, groupsconf.Port, td.sdConfig.Port)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDNewCNConfig(t *testing.T) {
|
func TestTritonSDNewCNConfig(t *testing.T) {
|
||||||
td, err := newTritonDiscovery(cnconf)
|
td, err := newTritonDiscovery(cnconf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, td != nil, "")
|
assert.NotNil(t, td)
|
||||||
testutil.Assert(t, td.client != nil, "")
|
assert.NotNil(t, td.client)
|
||||||
testutil.Assert(t, td.interval != 0, "")
|
assert.True(t, td.interval != 0, "")
|
||||||
testutil.Assert(t, td.sdConfig != nil, "")
|
assert.NotNil(t, td.sdConfig)
|
||||||
testutil.Equals(t, cnconf.Role, td.sdConfig.Role)
|
assert.Equal(t, cnconf.Role, td.sdConfig.Role)
|
||||||
testutil.Equals(t, cnconf.Account, td.sdConfig.Account)
|
assert.Equal(t, cnconf.Account, td.sdConfig.Account)
|
||||||
testutil.Equals(t, cnconf.DNSSuffix, td.sdConfig.DNSSuffix)
|
assert.Equal(t, cnconf.DNSSuffix, td.sdConfig.DNSSuffix)
|
||||||
testutil.Equals(t, cnconf.Endpoint, td.sdConfig.Endpoint)
|
assert.Equal(t, cnconf.Endpoint, td.sdConfig.Endpoint)
|
||||||
testutil.Equals(t, cnconf.Port, td.sdConfig.Port)
|
assert.Equal(t, cnconf.Port, td.sdConfig.Port)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDRefreshNoTargets(t *testing.T) {
|
func TestTritonSDRefreshNoTargets(t *testing.T) {
|
||||||
tgts := testTritonSDRefresh(t, conf, "{\"containers\":[]}")
|
tgts := testTritonSDRefresh(t, conf, "{\"containers\":[]}")
|
||||||
testutil.Assert(t, tgts == nil, "")
|
assert.True(t, tgts == nil, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDRefreshMultipleTargets(t *testing.T) {
|
func TestTritonSDRefreshMultipleTargets(t *testing.T) {
|
||||||
|
@ -157,8 +156,8 @@ func TestTritonSDRefreshMultipleTargets(t *testing.T) {
|
||||||
)
|
)
|
||||||
|
|
||||||
tgts := testTritonSDRefresh(t, conf, dstr)
|
tgts := testTritonSDRefresh(t, conf, dstr)
|
||||||
testutil.Assert(t, tgts != nil, "")
|
assert.NotNil(t, tgts)
|
||||||
testutil.Equals(t, 2, len(tgts))
|
assert.Equal(t, 2, len(tgts))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDRefreshNoServer(t *testing.T) {
|
func TestTritonSDRefreshNoServer(t *testing.T) {
|
||||||
|
@ -167,8 +166,8 @@ func TestTritonSDRefreshNoServer(t *testing.T) {
|
||||||
)
|
)
|
||||||
|
|
||||||
_, err := td.refresh(context.Background())
|
_, err := td.refresh(context.Background())
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Equals(t, strings.Contains(err.Error(), "an error occurred when requesting targets from the discovery endpoint"), true)
|
assert.Equal(t, strings.Contains(err.Error(), "an error occurred when requesting targets from the discovery endpoint"), true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDRefreshCancelled(t *testing.T) {
|
func TestTritonSDRefreshCancelled(t *testing.T) {
|
||||||
|
@ -179,8 +178,8 @@ func TestTritonSDRefreshCancelled(t *testing.T) {
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
ctx, cancel := context.WithCancel(context.Background())
|
||||||
cancel()
|
cancel()
|
||||||
_, err := td.refresh(ctx)
|
_, err := td.refresh(ctx)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Equals(t, strings.Contains(err.Error(), context.Canceled.Error()), true)
|
assert.Equal(t, strings.Contains(err.Error(), context.Canceled.Error()), true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDRefreshCNsUUIDOnly(t *testing.T) {
|
func TestTritonSDRefreshCNsUUIDOnly(t *testing.T) {
|
||||||
|
@ -196,8 +195,8 @@ func TestTritonSDRefreshCNsUUIDOnly(t *testing.T) {
|
||||||
)
|
)
|
||||||
|
|
||||||
tgts := testTritonSDRefresh(t, cnconf, dstr)
|
tgts := testTritonSDRefresh(t, cnconf, dstr)
|
||||||
testutil.Assert(t, tgts != nil, "")
|
assert.NotNil(t, tgts)
|
||||||
testutil.Equals(t, 2, len(tgts))
|
assert.Equal(t, 2, len(tgts))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTritonSDRefreshCNsWithHostname(t *testing.T) {
|
func TestTritonSDRefreshCNsWithHostname(t *testing.T) {
|
||||||
|
@ -215,8 +214,8 @@ func TestTritonSDRefreshCNsWithHostname(t *testing.T) {
|
||||||
)
|
)
|
||||||
|
|
||||||
tgts := testTritonSDRefresh(t, cnconf, dstr)
|
tgts := testTritonSDRefresh(t, cnconf, dstr)
|
||||||
testutil.Assert(t, tgts != nil, "")
|
assert.NotNil(t, tgts)
|
||||||
testutil.Equals(t, 2, len(tgts))
|
assert.Equal(t, 2, len(tgts))
|
||||||
}
|
}
|
||||||
|
|
||||||
func testTritonSDRefresh(t *testing.T, c SDConfig, dstr string) []model.LabelSet {
|
func testTritonSDRefresh(t *testing.T, c SDConfig, dstr string) []model.LabelSet {
|
||||||
|
@ -230,25 +229,25 @@ func testTritonSDRefresh(t *testing.T, c SDConfig, dstr string) []model.LabelSet
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
|
||||||
u, err := url.Parse(s.URL)
|
u, err := url.Parse(s.URL)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, u != nil, "")
|
assert.NotNil(t, u)
|
||||||
|
|
||||||
host, strport, err := net.SplitHostPort(u.Host)
|
host, strport, err := net.SplitHostPort(u.Host)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, host != "", "")
|
assert.True(t, host != "", "")
|
||||||
testutil.Assert(t, strport != "", "")
|
assert.True(t, strport != "", "")
|
||||||
|
|
||||||
port, err := strconv.Atoi(strport)
|
port, err := strconv.Atoi(strport)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, port != 0, "")
|
assert.True(t, port != 0, "")
|
||||||
|
|
||||||
td.sdConfig.Port = port
|
td.sdConfig.Port = port
|
||||||
|
|
||||||
tgs, err := td.refresh(context.Background())
|
tgs, err := td.refresh(context.Background())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 1, len(tgs))
|
assert.Equal(t, 1, len(tgs))
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
testutil.Assert(t, tg != nil, "")
|
assert.NotNil(t, tg)
|
||||||
|
|
||||||
return tg.Targets
|
return tg.Targets
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,10 +29,11 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"gopkg.in/alecthomas/kingpin.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/documentation/examples/custom-sd/adapter"
|
"github.com/prometheus/prometheus/documentation/examples/custom-sd/adapter"
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
"gopkg.in/alecthomas/kingpin.v2"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
|
|
@ -27,6 +27,7 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery"
|
"github.com/prometheus/prometheus/discovery"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
|
@ -15,13 +15,14 @@ package adapter
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
"reflect"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -231,9 +232,9 @@ func TestGenerateTargetGroups(t *testing.T) {
|
||||||
func TestWriteOutput(t *testing.T) {
|
func TestWriteOutput(t *testing.T) {
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
tmpfile, err := ioutil.TempFile("", "sd_adapter_test")
|
tmpfile, err := ioutil.TempFile("", "sd_adapter_test")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.Remove(tmpfile.Name())
|
defer os.Remove(tmpfile.Name())
|
||||||
tmpfile.Close()
|
tmpfile.Close()
|
||||||
adapter := NewAdapter(ctx, tmpfile.Name(), "test_sd", nil, nil)
|
adapter := NewAdapter(ctx, tmpfile.Name(), "test_sd", nil, nil)
|
||||||
testutil.Ok(t, adapter.writeOutput())
|
assert.NoError(t, adapter.writeOutput())
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,7 +23,6 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
influx "github.com/influxdata/influxdb/client/v2"
|
influx "github.com/influxdata/influxdb/client/v2"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -29,16 +29,14 @@ import (
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/gogo/protobuf/proto"
|
"github.com/gogo/protobuf/proto"
|
||||||
"github.com/golang/snappy"
|
"github.com/golang/snappy"
|
||||||
|
influx "github.com/influxdata/influxdb/client/v2"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/client_golang/prometheus/promhttp"
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"gopkg.in/alecthomas/kingpin.v2"
|
|
||||||
|
|
||||||
influx "github.com/influxdata/influxdb/client/v2"
|
|
||||||
|
|
||||||
"github.com/prometheus/common/promlog"
|
"github.com/prometheus/common/promlog"
|
||||||
"github.com/prometheus/common/promlog/flag"
|
"github.com/prometheus/common/promlog/flag"
|
||||||
|
"gopkg.in/alecthomas/kingpin.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/documentation/examples/remote_storage/remote_storage_adapter/graphite"
|
"github.com/prometheus/prometheus/documentation/examples/remote_storage/remote_storage_adapter/graphite"
|
||||||
"github.com/prometheus/prometheus/documentation/examples/remote_storage/remote_storage_adapter/influxdb"
|
"github.com/prometheus/prometheus/documentation/examples/remote_storage/remote_storage_adapter/influxdb"
|
||||||
|
|
5
go.mod
5
go.mod
|
@ -16,7 +16,6 @@ require (
|
||||||
github.com/aws/aws-sdk-go v1.35.5
|
github.com/aws/aws-sdk-go v1.35.5
|
||||||
github.com/cespare/xxhash/v2 v2.1.1
|
github.com/cespare/xxhash/v2 v2.1.1
|
||||||
github.com/containerd/containerd v1.3.4 // indirect
|
github.com/containerd/containerd v1.3.4 // indirect
|
||||||
github.com/davecgh/go-spew v1.1.1
|
|
||||||
github.com/dgryski/go-sip13 v0.0.0-20200911182023-62edffca9245
|
github.com/dgryski/go-sip13 v0.0.0-20200911182023-62edffca9245
|
||||||
github.com/digitalocean/godo v1.46.0
|
github.com/digitalocean/godo v1.46.0
|
||||||
github.com/docker/distribution v2.7.1+incompatible // indirect
|
github.com/docker/distribution v2.7.1+incompatible // indirect
|
||||||
|
@ -49,7 +48,6 @@ require (
|
||||||
github.com/opentracing-contrib/go-stdlib v1.0.0
|
github.com/opentracing-contrib/go-stdlib v1.0.0
|
||||||
github.com/opentracing/opentracing-go v1.2.0
|
github.com/opentracing/opentracing-go v1.2.0
|
||||||
github.com/pkg/errors v0.9.1
|
github.com/pkg/errors v0.9.1
|
||||||
github.com/pmezard/go-difflib v1.0.0
|
|
||||||
github.com/prometheus/alertmanager v0.21.0
|
github.com/prometheus/alertmanager v0.21.0
|
||||||
github.com/prometheus/client_golang v1.7.1
|
github.com/prometheus/client_golang v1.7.1
|
||||||
github.com/prometheus/client_model v0.2.0
|
github.com/prometheus/client_model v0.2.0
|
||||||
|
@ -57,6 +55,7 @@ require (
|
||||||
github.com/samuel/go-zookeeper v0.0.0-20200724154423-2164a8ac840e
|
github.com/samuel/go-zookeeper v0.0.0-20200724154423-2164a8ac840e
|
||||||
github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749
|
github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749
|
||||||
github.com/shurcooL/vfsgen v0.0.0-20200824052919-0d455de96546
|
github.com/shurcooL/vfsgen v0.0.0-20200824052919-0d455de96546
|
||||||
|
github.com/stretchr/testify v1.6.1
|
||||||
github.com/uber/jaeger-client-go v2.25.0+incompatible
|
github.com/uber/jaeger-client-go v2.25.0+incompatible
|
||||||
github.com/uber/jaeger-lib v2.4.0+incompatible
|
github.com/uber/jaeger-lib v2.4.0+incompatible
|
||||||
go.mongodb.org/mongo-driver v1.3.2 // indirect
|
go.mongodb.org/mongo-driver v1.3.2 // indirect
|
||||||
|
@ -67,7 +66,7 @@ require (
|
||||||
golang.org/x/sync v0.0.0-20200930132711-30421366ff76
|
golang.org/x/sync v0.0.0-20200930132711-30421366ff76
|
||||||
golang.org/x/sys v0.0.0-20201008064518-c1f3e3309c71
|
golang.org/x/sys v0.0.0-20201008064518-c1f3e3309c71
|
||||||
golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e
|
golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e
|
||||||
golang.org/x/tools v0.0.0-20201008025239-9df69603baec
|
golang.org/x/tools v0.0.0-20201020161133-226fd2f889ca
|
||||||
google.golang.org/api v0.32.0
|
google.golang.org/api v0.32.0
|
||||||
gopkg.in/alecthomas/kingpin.v2 v2.2.6
|
gopkg.in/alecthomas/kingpin.v2 v2.2.6
|
||||||
gopkg.in/fsnotify/fsnotify.v1 v1.4.7
|
gopkg.in/fsnotify/fsnotify.v1 v1.4.7
|
||||||
|
|
46
go.sum
46
go.sum
|
@ -11,7 +11,6 @@ cloud.google.com/go v0.51.0/go.mod h1:hWtGJ6gnXH+KgDv+V0zFGDvpi07n3z8ZNj3T1RW0Gc
|
||||||
cloud.google.com/go v0.52.0/go.mod h1:pXajvRH/6o3+F9jDHZWQ5PbGhn+o8w9qiu/CffaVdO4=
|
cloud.google.com/go v0.52.0/go.mod h1:pXajvRH/6o3+F9jDHZWQ5PbGhn+o8w9qiu/CffaVdO4=
|
||||||
cloud.google.com/go v0.53.0/go.mod h1:fp/UouUEsRkN6ryDKNW/Upv/JBKnv6WDthjR6+vze6M=
|
cloud.google.com/go v0.53.0/go.mod h1:fp/UouUEsRkN6ryDKNW/Upv/JBKnv6WDthjR6+vze6M=
|
||||||
cloud.google.com/go v0.54.0/go.mod h1:1rq2OEkV3YMf6n/9ZvGWI3GWw0VoqH/1x2nd8Is/bPc=
|
cloud.google.com/go v0.54.0/go.mod h1:1rq2OEkV3YMf6n/9ZvGWI3GWw0VoqH/1x2nd8Is/bPc=
|
||||||
cloud.google.com/go v0.56.0 h1:WRz29PgAsVEyPSDHyk+0fpEkwEFyfhHn+JbksT6gIL4=
|
|
||||||
cloud.google.com/go v0.56.0/go.mod h1:jr7tqZxxKOVYizybht9+26Z/gUq7tiRzu+ACVAMbKVk=
|
cloud.google.com/go v0.56.0/go.mod h1:jr7tqZxxKOVYizybht9+26Z/gUq7tiRzu+ACVAMbKVk=
|
||||||
cloud.google.com/go v0.57.0/go.mod h1:oXiQ6Rzq3RAkkY7N6t3TcE6jE+CIBBbA36lwQ1JyzZs=
|
cloud.google.com/go v0.57.0/go.mod h1:oXiQ6Rzq3RAkkY7N6t3TcE6jE+CIBBbA36lwQ1JyzZs=
|
||||||
cloud.google.com/go v0.65.0 h1:Dg9iHVQfrhq82rUNu9ZxUDrJLaxFUe/HlCVaLyRruq8=
|
cloud.google.com/go v0.65.0 h1:Dg9iHVQfrhq82rUNu9ZxUDrJLaxFUe/HlCVaLyRruq8=
|
||||||
|
@ -63,11 +62,9 @@ github.com/Azure/go-autorest/autorest/to v0.3.0 h1:zebkZaadz7+wIQYgC7GXaz3Wb28yK
|
||||||
github.com/Azure/go-autorest/autorest/to v0.3.0/go.mod h1:MgwOyqaIuKdG4TL/2ywSsIWKAfJfgHDo8ObuUk3t5sA=
|
github.com/Azure/go-autorest/autorest/to v0.3.0/go.mod h1:MgwOyqaIuKdG4TL/2ywSsIWKAfJfgHDo8ObuUk3t5sA=
|
||||||
github.com/Azure/go-autorest/autorest/validation v0.2.0 h1:15vMO4y76dehZSq7pAaOLQxC6dZYsSrj2GQpflyM/L4=
|
github.com/Azure/go-autorest/autorest/validation v0.2.0 h1:15vMO4y76dehZSq7pAaOLQxC6dZYsSrj2GQpflyM/L4=
|
||||||
github.com/Azure/go-autorest/autorest/validation v0.2.0/go.mod h1:3EEqHnBxQGHXRYq3HT1WyXAvT7LLY3tl70hw6tQIbjI=
|
github.com/Azure/go-autorest/autorest/validation v0.2.0/go.mod h1:3EEqHnBxQGHXRYq3HT1WyXAvT7LLY3tl70hw6tQIbjI=
|
||||||
github.com/Azure/go-autorest/logger v0.1.0 h1:ruG4BSDXONFRrZZJ2GUXDiUyVpayPmb1GnWeHDdaNKY=
|
|
||||||
github.com/Azure/go-autorest/logger v0.1.0/go.mod h1:oExouG+K6PryycPJfVSxi/koC6LSNgds39diKLz7Vrc=
|
github.com/Azure/go-autorest/logger v0.1.0/go.mod h1:oExouG+K6PryycPJfVSxi/koC6LSNgds39diKLz7Vrc=
|
||||||
github.com/Azure/go-autorest/logger v0.2.0 h1:e4RVHVZKC5p6UANLJHkM4OfR1UKZPj8Wt8Pcx+3oqrE=
|
github.com/Azure/go-autorest/logger v0.2.0 h1:e4RVHVZKC5p6UANLJHkM4OfR1UKZPj8Wt8Pcx+3oqrE=
|
||||||
github.com/Azure/go-autorest/logger v0.2.0/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZmbF5NWuPV8+WeEW8=
|
github.com/Azure/go-autorest/logger v0.2.0/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZmbF5NWuPV8+WeEW8=
|
||||||
github.com/Azure/go-autorest/tracing v0.5.0 h1:TRn4WjSnkcSy5AEG3pnbtFSwNtwzjr4VYyQflFE619k=
|
|
||||||
github.com/Azure/go-autorest/tracing v0.5.0/go.mod h1:r/s2XiOKccPW3HrqB+W0TQzfbtp2fGCgRFtBroKn4Dk=
|
github.com/Azure/go-autorest/tracing v0.5.0/go.mod h1:r/s2XiOKccPW3HrqB+W0TQzfbtp2fGCgRFtBroKn4Dk=
|
||||||
github.com/Azure/go-autorest/tracing v0.6.0 h1:TYi4+3m5t6K48TGI9AUdb+IzbnSxvnvUMfuitfgcfuo=
|
github.com/Azure/go-autorest/tracing v0.6.0 h1:TYi4+3m5t6K48TGI9AUdb+IzbnSxvnvUMfuitfgcfuo=
|
||||||
github.com/Azure/go-autorest/tracing v0.6.0/go.mod h1:+vhtPC754Xsa23ID7GlGsrdKBpUA79WCAKPPZVC2DeU=
|
github.com/Azure/go-autorest/tracing v0.6.0/go.mod h1:+vhtPC754Xsa23ID7GlGsrdKBpUA79WCAKPPZVC2DeU=
|
||||||
|
@ -81,7 +78,6 @@ github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go
|
||||||
github.com/Microsoft/go-winio v0.4.14 h1:+hMXMk01us9KgxGb7ftKQt2Xpf5hH/yky+TDA+qxleU=
|
github.com/Microsoft/go-winio v0.4.14 h1:+hMXMk01us9KgxGb7ftKQt2Xpf5hH/yky+TDA+qxleU=
|
||||||
github.com/Microsoft/go-winio v0.4.14/go.mod h1:qXqCSQ3Xa7+6tgxaGTIe4Kpcdsi+P8jBhyzoq1bpyYA=
|
github.com/Microsoft/go-winio v0.4.14/go.mod h1:qXqCSQ3Xa7+6tgxaGTIe4Kpcdsi+P8jBhyzoq1bpyYA=
|
||||||
github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ=
|
github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ=
|
||||||
github.com/OneOfOne/xxhash v1.2.2 h1:KMrpdQIwFcEqXDklaen+P1axHaj9BSKzvpUUfnHldSE=
|
|
||||||
github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
|
github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
|
||||||
github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
|
github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
|
||||||
github.com/PuerkitoBio/purell v1.1.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
|
github.com/PuerkitoBio/purell v1.1.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
|
||||||
|
@ -141,7 +137,6 @@ github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghf
|
||||||
github.com/cespare/xxhash/v2 v2.1.1 h1:6MnRN8NT7+YBpUIWxHtefFZOKTAPgGjpQSxqLNn0+qY=
|
github.com/cespare/xxhash/v2 v2.1.1 h1:6MnRN8NT7+YBpUIWxHtefFZOKTAPgGjpQSxqLNn0+qY=
|
||||||
github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
|
github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
|
||||||
github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI=
|
github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI=
|
||||||
github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e h1:fY5BOSpyZCqRo5OhCuC+XN+r/bBCmeuuJtjz+bCNIf8=
|
|
||||||
github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI=
|
github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI=
|
||||||
github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU=
|
github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU=
|
||||||
github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6Dob7S7YxXgwXpfOuvO54S+tGdZdw9fuRZt25Ag=
|
github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6Dob7S7YxXgwXpfOuvO54S+tGdZdw9fuRZt25Ag=
|
||||||
|
@ -163,7 +158,6 @@ github.com/dave/jennifer v1.2.0/go.mod h1:fIb+770HOpJ2fmN9EPPKOqm1vMGhB+TwXKMZhr
|
||||||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/dgrijalva/jwt-go v3.2.0+incompatible h1:7qlOGliEKZXTDg6OTjfoBKDXWrumCAMpl/TFQ4/5kLM=
|
|
||||||
github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ=
|
github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ=
|
||||||
github.com/dgryski/go-bitstream v0.0.0-20180413035011-3522498ce2c8/go.mod h1:VMaSuZ+SZcx/wljOQKvp5srsbCiKDEb6K2wC4+PiBmQ=
|
github.com/dgryski/go-bitstream v0.0.0-20180413035011-3522498ce2c8/go.mod h1:VMaSuZ+SZcx/wljOQKvp5srsbCiKDEb6K2wC4+PiBmQ=
|
||||||
github.com/dgryski/go-sip13 v0.0.0-20200911182023-62edffca9245 h1:9cOfvEwjQxdwKuNDTQSaMKNRvwKwgZG+U4HrjeRKHso=
|
github.com/dgryski/go-sip13 v0.0.0-20200911182023-62edffca9245 h1:9cOfvEwjQxdwKuNDTQSaMKNRvwKwgZG+U4HrjeRKHso=
|
||||||
|
@ -205,7 +199,6 @@ github.com/form3tech-oss/jwt-go v3.2.2+incompatible h1:TcekIExNqud5crz4xD2pavyTg
|
||||||
github.com/form3tech-oss/jwt-go v3.2.2+incompatible/go.mod h1:pbq4aXjuKjdthFRnoDwaVPLA+WlJuPGy+QneDUgJi2k=
|
github.com/form3tech-oss/jwt-go v3.2.2+incompatible/go.mod h1:pbq4aXjuKjdthFRnoDwaVPLA+WlJuPGy+QneDUgJi2k=
|
||||||
github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4=
|
github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4=
|
||||||
github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20=
|
github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20=
|
||||||
github.com/fsnotify/fsnotify v1.4.7 h1:IXs+QLmnXW2CcXuY+8Mzv/fWEsPGWxqefPtCP5CnV9I=
|
|
||||||
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
|
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
|
||||||
github.com/fsnotify/fsnotify v1.4.9 h1:hsms1Qyu0jgnwNXIxa+/V/PDsU6CfLf6CNO8H7IWoS4=
|
github.com/fsnotify/fsnotify v1.4.9 h1:hsms1Qyu0jgnwNXIxa+/V/PDsU6CfLf6CNO8H7IWoS4=
|
||||||
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
|
||||||
|
@ -361,7 +354,6 @@ github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QD
|
||||||
github.com/golang/protobuf v1.4.2 h1:+Z5KGCizgyZCbGh1KZqA0fcLLkwbsjIzS4aV2v7wJX0=
|
github.com/golang/protobuf v1.4.2 h1:+Z5KGCizgyZCbGh1KZqA0fcLLkwbsjIzS4aV2v7wJX0=
|
||||||
github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
|
github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
|
||||||
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||||
github.com/golang/snappy v0.0.1 h1:Qgr9rKW7uDUkrbSmQeiDsGa8SjGyCOGtuasMWwvp2P4=
|
|
||||||
github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||||
github.com/golang/snappy v0.0.2 h1:aeE13tS0IiQgFjYdoL8qN3K1N2bXXtI6Vi51/y7BpMw=
|
github.com/golang/snappy v0.0.2 h1:aeE13tS0IiQgFjYdoL8qN3K1N2bXXtI6Vi51/y7BpMw=
|
||||||
github.com/golang/snappy v0.0.2/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
github.com/golang/snappy v0.0.2/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
|
||||||
|
@ -372,10 +364,8 @@ github.com/google/flatbuffers v1.11.0/go.mod h1:1AeVuKshWv4vARoZatz6mlQ0JxURH0Kv
|
||||||
github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
|
github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
|
||||||
github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
||||||
github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
||||||
github.com/google/go-cmp v0.4.0 h1:xsAVV57WRhGj6kEIi8ReJzQlHHqcBYCElAvkovg3B/4=
|
|
||||||
github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
github.com/google/go-cmp v0.4.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
github.com/google/go-cmp v0.4.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
github.com/google/go-cmp v0.5.0 h1:/QaMHBdZ26BB3SSst0Iwl10Epc+xhTquomWX0oZEB6w=
|
|
||||||
github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
github.com/google/go-cmp v0.5.2 h1:X2ev0eStA3AbceY54o37/0PQ/UWqKEiiO2dKL5OPaFM=
|
github.com/google/go-cmp v0.5.2 h1:X2ev0eStA3AbceY54o37/0PQ/UWqKEiiO2dKL5OPaFM=
|
||||||
|
@ -393,7 +383,6 @@ github.com/google/pprof v0.0.0-20191218002539-d4f498aebedc/go.mod h1:ZgVRPoUq/hf
|
||||||
github.com/google/pprof v0.0.0-20200212024743-f11f1df84d12/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
github.com/google/pprof v0.0.0-20200212024743-f11f1df84d12/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
||||||
github.com/google/pprof v0.0.0-20200229191704-1ebb73c60ed3/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
github.com/google/pprof v0.0.0-20200229191704-1ebb73c60ed3/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
||||||
github.com/google/pprof v0.0.0-20200430221834-fc25d7d30c6d/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
github.com/google/pprof v0.0.0-20200430221834-fc25d7d30c6d/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
||||||
github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99 h1:Ak8CrdlwwXwAZxzS66vgPt4U8yUZX7JwLvVR58FN5jM=
|
|
||||||
github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
||||||
github.com/google/pprof v0.0.0-20201007051231-1066cbb265c7 h1:qYWTuM6SUNWgtvkhV8oH6GFHCpU+rKQOxPcepM3xKi0=
|
github.com/google/pprof v0.0.0-20201007051231-1066cbb265c7 h1:qYWTuM6SUNWgtvkhV8oH6GFHCpU+rKQOxPcepM3xKi0=
|
||||||
github.com/google/pprof v0.0.0-20201007051231-1066cbb265c7/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
github.com/google/pprof v0.0.0-20201007051231-1066cbb265c7/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM=
|
||||||
|
@ -414,7 +403,6 @@ github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2z
|
||||||
github.com/gorilla/mux v1.7.3 h1:gnP5JzjVOuiZD07fKKToCAOjS0yOpj/qPETTXCCS6hw=
|
github.com/gorilla/mux v1.7.3 h1:gnP5JzjVOuiZD07fKKToCAOjS0yOpj/qPETTXCCS6hw=
|
||||||
github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs=
|
github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs=
|
||||||
github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
|
github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
|
||||||
github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7 h1:pdN6V1QBWetyv/0+wjACpqVH+eVULgEjkurDLq3goeM=
|
|
||||||
github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA=
|
github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA=
|
||||||
github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs=
|
github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs=
|
||||||
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk=
|
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk=
|
||||||
|
@ -440,7 +428,6 @@ github.com/hashicorp/go-immutable-radix v1.2.0 h1:l6UW37iCXwZkZoAbEYnptSHVE/cQ5b
|
||||||
github.com/hashicorp/go-immutable-radix v1.2.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
github.com/hashicorp/go-immutable-radix v1.2.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
||||||
github.com/hashicorp/go-msgpack v0.5.3 h1:zKjpN5BK/P5lMYrLmBHdBULWbJ0XpYR+7NGzqkZzoD4=
|
github.com/hashicorp/go-msgpack v0.5.3 h1:zKjpN5BK/P5lMYrLmBHdBULWbJ0XpYR+7NGzqkZzoD4=
|
||||||
github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM=
|
github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM=
|
||||||
github.com/hashicorp/go-multierror v1.0.0 h1:iVjPR7a6H0tWELX5NxNe7bYopibicUzc7uPribsnS6o=
|
|
||||||
github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk=
|
github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk=
|
||||||
github.com/hashicorp/go-multierror v1.1.0 h1:B9UzwGQJehnUY1yNrnwREHc3fGbC2xefo8g4TbElacI=
|
github.com/hashicorp/go-multierror v1.1.0 h1:B9UzwGQJehnUY1yNrnwREHc3fGbC2xefo8g4TbElacI=
|
||||||
github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA=
|
github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA=
|
||||||
|
@ -475,7 +462,6 @@ github.com/hetznercloud/hcloud-go v1.22.0/go.mod h1:xng8lbDUg+xM1dgc0yGHX5EeqbwI
|
||||||
github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI=
|
github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI=
|
||||||
github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU=
|
github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU=
|
||||||
github.com/hudl/fargo v1.3.0/go.mod h1:y3CKSmjA+wD2gak7sUSXTAoopbhU08POFhmITJgmKTg=
|
github.com/hudl/fargo v1.3.0/go.mod h1:y3CKSmjA+wD2gak7sUSXTAoopbhU08POFhmITJgmKTg=
|
||||||
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6 h1:UDMh68UUwekSh5iP2OMhRRZJiiBccgV7axzUG8vi56c=
|
|
||||||
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
|
||||||
github.com/imdario/mergo v0.3.5/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA=
|
github.com/imdario/mergo v0.3.5/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA=
|
||||||
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
|
||||||
|
@ -525,13 +511,11 @@ github.com/klauspost/cpuid v0.0.0-20170728055534-ae7887de9fa5/go.mod h1:Pj4uuM52
|
||||||
github.com/klauspost/crc32 v0.0.0-20161016154125-cb6bfca970f6/go.mod h1:+ZoRqAPRLkC4NPOvfYeR5KNOrY6TD+/sAC3HXPZgDYg=
|
github.com/klauspost/crc32 v0.0.0-20161016154125-cb6bfca970f6/go.mod h1:+ZoRqAPRLkC4NPOvfYeR5KNOrY6TD+/sAC3HXPZgDYg=
|
||||||
github.com/klauspost/pgzip v1.0.2-0.20170402124221-0bf5dcad4ada/go.mod h1:Ch1tH69qFZu15pkjo5kYi6mth2Zzwzt50oCQKQE9RUs=
|
github.com/klauspost/pgzip v1.0.2-0.20170402124221-0bf5dcad4ada/go.mod h1:Ch1tH69qFZu15pkjo5kYi6mth2Zzwzt50oCQKQE9RUs=
|
||||||
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
||||||
github.com/konsorten/go-windows-terminal-sequences v1.0.2 h1:DB17ag19krx9CFsz4o3enTrPXyIXCl+2iCXH/aMAp9s=
|
|
||||||
github.com/konsorten/go-windows-terminal-sequences v1.0.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
github.com/konsorten/go-windows-terminal-sequences v1.0.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
||||||
github.com/konsorten/go-windows-terminal-sequences v1.0.3 h1:CE8S1cTafDpPvMhIxNJKvHsGVBgn1xWYf1NbHQhywc8=
|
github.com/konsorten/go-windows-terminal-sequences v1.0.3 h1:CE8S1cTafDpPvMhIxNJKvHsGVBgn1xWYf1NbHQhywc8=
|
||||||
github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
|
||||||
github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
|
github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
|
||||||
github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
|
github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
|
||||||
github.com/kr/pretty v0.2.0 h1:s5hAObm+yFO5uHYt5dYjxi2rXrsnmRpJx4OYvIWUaQs=
|
|
||||||
github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
|
github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
|
||||||
github.com/kr/pretty v0.2.1 h1:Fmg33tUaq4/8ym9TJN1x7sLJnHVwhP33CNkpYV/7rwI=
|
github.com/kr/pretty v0.2.1 h1:Fmg33tUaq4/8ym9TJN1x7sLJnHVwhP33CNkpYV/7rwI=
|
||||||
github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
|
github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
|
||||||
|
@ -638,7 +622,6 @@ github.com/opentracing-contrib/go-stdlib v1.0.0/go.mod h1:qtI1ogk+2JhVPIXVc6q+NH
|
||||||
github.com/opentracing/basictracer-go v1.0.0/go.mod h1:QfBfYuafItcjQuMwinw9GhYKwFXS9KnPs5lxoYwgW74=
|
github.com/opentracing/basictracer-go v1.0.0/go.mod h1:QfBfYuafItcjQuMwinw9GhYKwFXS9KnPs5lxoYwgW74=
|
||||||
github.com/opentracing/opentracing-go v1.0.2/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o=
|
github.com/opentracing/opentracing-go v1.0.2/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o=
|
||||||
github.com/opentracing/opentracing-go v1.0.3-0.20180606204148-bd9c31933947/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o=
|
github.com/opentracing/opentracing-go v1.0.3-0.20180606204148-bd9c31933947/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o=
|
||||||
github.com/opentracing/opentracing-go v1.1.0 h1:pWlfV3Bxv7k65HYwkikxat0+s3pV4bsqf19k25Ur8rU=
|
|
||||||
github.com/opentracing/opentracing-go v1.1.0/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o=
|
github.com/opentracing/opentracing-go v1.1.0/go.mod h1:UkNAQd3GIcIGf0SeVgPpRdFStlNbqXla1AfSYxPUl2o=
|
||||||
github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs=
|
github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+1B0VhjKrZUs=
|
||||||
github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc=
|
github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc=
|
||||||
|
@ -654,7 +637,6 @@ github.com/paulbellamy/ratecounter v0.2.0/go.mod h1:Hfx1hDpSGoqxkVVpBi/IlYD7kChl
|
||||||
github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k=
|
github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k=
|
||||||
github.com/pelletier/go-toml v1.4.0/go.mod h1:PN7xzY2wHTK0K9p34ErDQMlFxa51Fk0OUruD3k1mMwo=
|
github.com/pelletier/go-toml v1.4.0/go.mod h1:PN7xzY2wHTK0K9p34ErDQMlFxa51Fk0OUruD3k1mMwo=
|
||||||
github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac=
|
github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac=
|
||||||
github.com/peterbourgon/diskv v2.0.1+incompatible h1:UBdAOUP5p4RWqPBg048CAvpKN+vxiaj6gdUUzhl4XmI=
|
|
||||||
github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU=
|
github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU=
|
||||||
github.com/peterh/liner v1.0.1-0.20180619022028-8c1271fcf47f/go.mod h1:xIteQHvHuaLYG9IFj6mSxM0fCKrs34IrEQUhOYuGPHc=
|
github.com/peterh/liner v1.0.1-0.20180619022028-8c1271fcf47f/go.mod h1:xIteQHvHuaLYG9IFj6mSxM0fCKrs34IrEQUhOYuGPHc=
|
||||||
github.com/philhofer/fwd v1.0.0/go.mod h1:gk3iGcWd9+svBvR0sR+KPcfE+RNWozjowpeBVG3ZVNU=
|
github.com/philhofer/fwd v1.0.0/go.mod h1:gk3iGcWd9+svBvR0sR+KPcfE+RNWozjowpeBVG3ZVNU=
|
||||||
|
@ -692,7 +674,6 @@ github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y8
|
||||||
github.com/prometheus/common v0.6.0/go.mod h1:eBmuwkDJBwy6iBfxCBob6t6dR6ENT/y+J+Zk0j9GMYc=
|
github.com/prometheus/common v0.6.0/go.mod h1:eBmuwkDJBwy6iBfxCBob6t6dR6ENT/y+J+Zk0j9GMYc=
|
||||||
github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA=
|
github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA=
|
||||||
github.com/prometheus/common v0.9.1/go.mod h1:yhUN8i9wzaXS3w1O07YhxHEBxD+W35wd8bs7vj7HSQ4=
|
github.com/prometheus/common v0.9.1/go.mod h1:yhUN8i9wzaXS3w1O07YhxHEBxD+W35wd8bs7vj7HSQ4=
|
||||||
github.com/prometheus/common v0.10.0 h1:RyRA7RzGXQZiW+tGMr7sxa85G1z0yOpM1qq5c8lNawc=
|
|
||||||
github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo=
|
github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo=
|
||||||
github.com/prometheus/common v0.14.0 h1:RHRyE8UocrbjU+6UvRzwi6HjiDfxrrBU91TtbKzkGp4=
|
github.com/prometheus/common v0.14.0 h1:RHRyE8UocrbjU+6UvRzwi6HjiDfxrrBU91TtbKzkGp4=
|
||||||
github.com/prometheus/common v0.14.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s=
|
github.com/prometheus/common v0.14.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s=
|
||||||
|
@ -714,7 +695,6 @@ github.com/rs/cors v1.7.0/go.mod h1:gFx+x8UowdsKA9AchylcLynDq+nNFfI8FkUZdN/jGCU=
|
||||||
github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
|
github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
|
||||||
github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
|
github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
|
||||||
github.com/ryanuber/columnize v2.1.0+incompatible/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
|
github.com/ryanuber/columnize v2.1.0+incompatible/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
|
||||||
github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da h1:p3Vo3i64TCLY7gIfzeQaUJ+kppEO5WQG3cL8iE8tGHU=
|
|
||||||
github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
|
github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
|
||||||
github.com/samuel/go-zookeeper v0.0.0-20200724154423-2164a8ac840e h1:CGjiMQ0wMH4wtNWrlj6kiTbkPt2F3rbYnhGX6TWLfco=
|
github.com/samuel/go-zookeeper v0.0.0-20200724154423-2164a8ac840e h1:CGjiMQ0wMH4wtNWrlj6kiTbkPt2F3rbYnhGX6TWLfco=
|
||||||
github.com/samuel/go-zookeeper v0.0.0-20200724154423-2164a8ac840e/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
|
github.com/samuel/go-zookeeper v0.0.0-20200724154423-2164a8ac840e/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
|
||||||
|
@ -727,7 +707,6 @@ github.com/sergi/go-diff v1.0.0/go.mod h1:0CfEIISq7TuYL3j771MWULgwwjU+GofnZX9QAm
|
||||||
github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749 h1:bUGsEnyNbVPw06Bs80sCeARAlK8lhwqGyi6UT8ymuGk=
|
github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749 h1:bUGsEnyNbVPw06Bs80sCeARAlK8lhwqGyi6UT8ymuGk=
|
||||||
github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749/go.mod h1:ZY1cvUeJuFPAdZ/B6v7RHavJWZn2YPVFQ1OSXhCGOkg=
|
github.com/shurcooL/httpfs v0.0.0-20190707220628-8d4bc4ba7749/go.mod h1:ZY1cvUeJuFPAdZ/B6v7RHavJWZn2YPVFQ1OSXhCGOkg=
|
||||||
github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc=
|
github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc=
|
||||||
github.com/shurcooL/vfsgen v0.0.0-20181202132449-6a9ea43bcacd h1:ug7PpSOB5RBPK1Kg6qskGBoP3Vnj/aNYFTznWvlkGo0=
|
|
||||||
github.com/shurcooL/vfsgen v0.0.0-20181202132449-6a9ea43bcacd/go.mod h1:TrYk7fJVaAttu97ZZKrO9UbRa8izdowaMIZcxYMbVaw=
|
github.com/shurcooL/vfsgen v0.0.0-20181202132449-6a9ea43bcacd/go.mod h1:TrYk7fJVaAttu97ZZKrO9UbRa8izdowaMIZcxYMbVaw=
|
||||||
github.com/shurcooL/vfsgen v0.0.0-20200824052919-0d455de96546 h1:pXY9qYc/MP5zdvqWEUH6SjNiu7VhSjuVFTFiTcphaLU=
|
github.com/shurcooL/vfsgen v0.0.0-20200824052919-0d455de96546 h1:pXY9qYc/MP5zdvqWEUH6SjNiu7VhSjuVFTFiTcphaLU=
|
||||||
github.com/shurcooL/vfsgen v0.0.0-20200824052919-0d455de96546/go.mod h1:TrYk7fJVaAttu97ZZKrO9UbRa8izdowaMIZcxYMbVaw=
|
github.com/shurcooL/vfsgen v0.0.0-20200824052919-0d455de96546/go.mod h1:TrYk7fJVaAttu97ZZKrO9UbRa8izdowaMIZcxYMbVaw=
|
||||||
|
@ -738,16 +717,13 @@ github.com/simonpasquier/klog-gokit/v2 v2.0.1/go.mod h1:VgeTFrwzYYcMH8edEfh3/ai2
|
||||||
github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
|
github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
|
||||||
github.com/sirupsen/logrus v1.4.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
|
github.com/sirupsen/logrus v1.4.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
|
||||||
github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q=
|
github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q=
|
||||||
github.com/sirupsen/logrus v1.4.2 h1:SPIRibHv4MatM3XXNO2BJeFLZwZ2LvZgfQ5+UNI2im4=
|
|
||||||
github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE=
|
github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE=
|
||||||
github.com/sirupsen/logrus v1.6.0 h1:UBcNElsrwanuuMsnGSlYmtmgbb23qDR5dG+6X6Oo89I=
|
github.com/sirupsen/logrus v1.6.0 h1:UBcNElsrwanuuMsnGSlYmtmgbb23qDR5dG+6X6Oo89I=
|
||||||
github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88=
|
github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88=
|
||||||
github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc=
|
github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc=
|
||||||
github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA=
|
github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA=
|
||||||
github.com/soheilhy/cmux v0.1.4 h1:0HKaf1o97UwFjHH9o5XsHUOF+tqmdA7KEzXLpiyaw0E=
|
|
||||||
github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM=
|
github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM=
|
||||||
github.com/sony/gobreaker v0.4.1/go.mod h1:ZKptC7FHNvhBz7dN2LGjPVBz2sZJmc0/PkyDJOjmxWY=
|
github.com/sony/gobreaker v0.4.1/go.mod h1:ZKptC7FHNvhBz7dN2LGjPVBz2sZJmc0/PkyDJOjmxWY=
|
||||||
github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72 h1:qLC7fQah7D6K1B0ujays3HV9gkFtllcxhzImRR7ArPQ=
|
|
||||||
github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
|
github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
|
||||||
github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk=
|
github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk=
|
||||||
github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
|
github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
|
||||||
|
@ -768,8 +744,9 @@ github.com/stretchr/testify v1.2.0/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXf
|
||||||
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
||||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||||
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
||||||
github.com/stretchr/testify v1.5.1 h1:nOGnQDM7FYENwehXlg/kFVnos3rEvtKTjRvOWSzb6H4=
|
|
||||||
github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
|
github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
|
||||||
|
github.com/stretchr/testify v1.6.1 h1:hDPOHmpOpP40lSULcqw7IrRb/u7w6RpDC9399XyoNd0=
|
||||||
|
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/tidwall/pretty v1.0.0 h1:HsD+QiTn7sK6flMKIvNmpqz1qrpP3Ps6jOKIKMooyg4=
|
github.com/tidwall/pretty v1.0.0 h1:HsD+QiTn7sK6flMKIvNmpqz1qrpP3Ps6jOKIKMooyg4=
|
||||||
github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk=
|
github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk=
|
||||||
github.com/tinylib/msgp v1.0.2/go.mod h1:+d+yLhGm8mzTaHzB+wgMYrodPfmZrzkirds8fDWklFE=
|
github.com/tinylib/msgp v1.0.2/go.mod h1:+d+yLhGm8mzTaHzB+wgMYrodPfmZrzkirds8fDWklFE=
|
||||||
|
@ -805,7 +782,6 @@ go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
|
||||||
go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU=
|
go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU=
|
||||||
go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8=
|
go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8=
|
||||||
go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
||||||
go.opencensus.io v0.22.3 h1:8sGtKOrtQqkN1bp2AtX+misvLIlOmsEsNd+9NIcPEm8=
|
|
||||||
go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
||||||
go.opencensus.io v0.22.4 h1:LYy1Hy3MJdrCdMwwzxA/dRok4ejH+RwNGbuoD9fCjto=
|
go.opencensus.io v0.22.4 h1:LYy1Hy3MJdrCdMwwzxA/dRok4ejH+RwNGbuoD9fCjto=
|
||||||
go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw=
|
||||||
|
@ -836,7 +812,6 @@ golang.org/x/crypto v0.0.0-20190923035154-9ee001bba392/go.mod h1:/lpIB1dKB+9EgE3
|
||||||
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
||||||
golang.org/x/crypto v0.0.0-20191202143827-86a70503ff7e/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
golang.org/x/crypto v0.0.0-20191202143827-86a70503ff7e/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9 h1:psW17arqaxU48Z5kZ0CQnkZWQJsqcURM6tKiBApRjXI=
|
|
||||||
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0 h1:hb9wdF1z5waM+dSIICn1l0DkLVDT3hqhhQsDNUmHPRE=
|
golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0 h1:hb9wdF1z5waM+dSIICn1l0DkLVDT3hqhhQsDNUmHPRE=
|
||||||
golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
|
@ -873,7 +848,6 @@ golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKG
|
||||||
golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY=
|
golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY=
|
||||||
golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg=
|
golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg=
|
||||||
golang.org/x/mod v0.1.1-0.20191107180719-034126e5016b/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg=
|
golang.org/x/mod v0.1.1-0.20191107180719-034126e5016b/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg=
|
||||||
golang.org/x/mod v0.2.0 h1:KU7oHjnv3XNWfa5COkzUifxZmxp1TyI7ImMXqFxLwvQ=
|
|
||||||
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||||
golang.org/x/mod v0.3.0 h1:RM4zey1++hCTbCVQfnWeKs9/IEsaBLA8vTkd0WVtmH4=
|
golang.org/x/mod v0.3.0 h1:RM4zey1++hCTbCVQfnWeKs9/IEsaBLA8vTkd0WVtmH4=
|
||||||
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
|
||||||
|
@ -915,7 +889,6 @@ golang.org/x/net v0.0.0-20200513185701-a91f0712d120/go.mod h1:qpuaurCH72eLCgpAm/
|
||||||
golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A=
|
golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A=
|
||||||
golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
|
golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
|
||||||
golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
|
golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
|
||||||
golang.org/x/net v0.0.0-20200822124328-c89045814202 h1:VvcQYSHwXgi7W+TpUR6A9g6Up98WAHf3f/ulnJ62IyA=
|
|
||||||
golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
|
golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
|
||||||
golang.org/x/net v0.0.0-20201006153459-a7d1128ccaa0 h1:wBouT66WTYFXdxfVdz9sVWARVd/2vfGcmI45D2gj45M=
|
golang.org/x/net v0.0.0-20201006153459-a7d1128ccaa0 h1:wBouT66WTYFXdxfVdz9sVWARVd/2vfGcmI45D2gj45M=
|
||||||
golang.org/x/net v0.0.0-20201006153459-a7d1128ccaa0/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
|
golang.org/x/net v0.0.0-20201006153459-a7d1128ccaa0/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
|
||||||
|
@ -923,7 +896,6 @@ golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAG
|
||||||
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
||||||
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
||||||
golang.org/x/oauth2 v0.0.0-20191202225959-858c2ad4c8b6/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
golang.org/x/oauth2 v0.0.0-20191202225959-858c2ad4c8b6/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
||||||
golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d h1:TzXSXBo42m9gQenoE3b9BGiEpg5IG2JkU5FkPIawgtw=
|
|
||||||
golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
|
||||||
golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43 h1:ld7aEMNHoBnnDAX15v1T6z31v8HwR2A9FYOuAhWqkwc=
|
golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43 h1:ld7aEMNHoBnnDAX15v1T6z31v8HwR2A9FYOuAhWqkwc=
|
||||||
golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A=
|
golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A=
|
||||||
|
@ -934,9 +906,7 @@ golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJ
|
||||||
golang.org/x/sync v0.0.0-20190412183630-56d357773e84/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20190412183630-56d357773e84/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a h1:WXEvlFVvvGxCJLG6REjsT03iWnKLEWinaScsxF2Vm2o=
|
|
||||||
golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208 h1:qwRHBd0NqMbJxfbotnDhm2ByMI1Shq4Y6oRJo21SGJA=
|
|
||||||
golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sync v0.0.0-20200930132711-30421366ff76 h1:JnxiSYT3Nm0BT2a8CyvYyM6cnrWpidecD1UuSYbhKm0=
|
golang.org/x/sync v0.0.0-20200930132711-30421366ff76 h1:JnxiSYT3Nm0BT2a8CyvYyM6cnrWpidecD1UuSYbhKm0=
|
||||||
golang.org/x/sync v0.0.0-20200930132711-30421366ff76/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20200930132711-30421366ff76/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
@ -991,7 +961,6 @@ golang.org/x/sys v0.0.0-20200501052902-10377860bb8e/go.mod h1:h1NjWce9XRLGQEsW7w
|
||||||
golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1 h1:ogLJMz+qpzav7lGMh10LMvAkM/fAoGlaiiHYiFYdm80=
|
|
||||||
golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200622214017-ed371f2e16b4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200622214017-ed371f2e16b4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
@ -1003,7 +972,6 @@ golang.org/x/sys v0.0.0-20201008064518-c1f3e3309c71/go.mod h1:h1NjWce9XRLGQEsW7w
|
||||||
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/text v0.3.2 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs=
|
|
||||||
golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
|
golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
|
||||||
golang.org/x/text v0.3.3 h1:cokOdA+Jmi5PJGXLlLllQSgYigAEfHXJAERHVMaCc2k=
|
golang.org/x/text v0.3.3 h1:cokOdA+Jmi5PJGXLlLllQSgYigAEfHXJAERHVMaCc2k=
|
||||||
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
|
||||||
|
@ -1069,18 +1037,16 @@ golang.org/x/tools v0.0.0-20200312045724-11d5b4c81c7d/go.mod h1:o4KQGtdN14AW+yjs
|
||||||
golang.org/x/tools v0.0.0-20200331025713-a30bf2db82d4/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8=
|
golang.org/x/tools v0.0.0-20200331025713-a30bf2db82d4/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8=
|
||||||
golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200513201620-d5fe73897c97 h1:DAuln/hGp+aJiHpID1Y1hYzMEPP5WLwtZHPb50mN0OE=
|
|
||||||
golang.org/x/tools v0.0.0-20200513201620-d5fe73897c97/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200513201620-d5fe73897c97/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
|
||||||
golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
||||||
golang.org/x/tools v0.0.0-20200828161849-5deb26317202/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
golang.org/x/tools v0.0.0-20200828161849-5deb26317202/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
|
||||||
golang.org/x/tools v0.0.0-20200904185747-39188db58858/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE=
|
golang.org/x/tools v0.0.0-20200904185747-39188db58858/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE=
|
||||||
golang.org/x/tools v0.0.0-20201008025239-9df69603baec h1:RY2OghEV/7X1MLaecgm1mwFd3sGvUddm5pGVSxQvX0c=
|
golang.org/x/tools v0.0.0-20201020161133-226fd2f889ca h1:pvScuB+UnCGDas2naNKUOXruM08MjwVcEdaweeynIqQ=
|
||||||
golang.org/x/tools v0.0.0-20201008025239-9df69603baec/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU=
|
golang.org/x/tools v0.0.0-20201020161133-226fd2f889ca/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU=
|
||||||
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4=
|
|
||||||
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE=
|
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE=
|
||||||
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
@ -1142,7 +1108,6 @@ google.golang.org/genproto v0.0.0-20200312145019-da6875a35672/go.mod h1:55QSHmfG
|
||||||
google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
||||||
google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
||||||
google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
||||||
google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884 h1:fiNLklpBwWK1mth30Hlwk+fcdBmIALlgF5iy77O37Ig=
|
|
||||||
google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
|
||||||
google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U=
|
google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U=
|
||||||
google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo=
|
google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo=
|
||||||
|
@ -1165,7 +1130,6 @@ google.golang.org/grpc v1.26.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8
|
||||||
google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
|
google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
|
||||||
google.golang.org/grpc v1.27.1/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
|
google.golang.org/grpc v1.27.1/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
|
||||||
google.golang.org/grpc v1.28.0/go.mod h1:rpkK4SK4GF4Ach/+MFLZUBavHOvF2JJB5uozKKal+60=
|
google.golang.org/grpc v1.28.0/go.mod h1:rpkK4SK4GF4Ach/+MFLZUBavHOvF2JJB5uozKKal+60=
|
||||||
google.golang.org/grpc v1.29.1 h1:EC2SB8S04d2r73uptxphDSUG+kTKVgjRPF+N3xpxRB4=
|
|
||||||
google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3IjizoKk=
|
google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3IjizoKk=
|
||||||
google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak=
|
google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak=
|
||||||
google.golang.org/grpc v1.31.1/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak=
|
google.golang.org/grpc v1.31.1/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak=
|
||||||
|
@ -1177,7 +1141,6 @@ google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQ
|
||||||
google.golang.org/protobuf v1.20.1-0.20200309200217-e05f789c0967/go.mod h1:A+miEFZTKqfCUM6K7xSMQL9OKL/b6hQv+e19PK+JZNE=
|
google.golang.org/protobuf v1.20.1-0.20200309200217-e05f789c0967/go.mod h1:A+miEFZTKqfCUM6K7xSMQL9OKL/b6hQv+e19PK+JZNE=
|
||||||
google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzikPIcrTAo=
|
google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzikPIcrTAo=
|
||||||
google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
||||||
google.golang.org/protobuf v1.23.0 h1:4MY060fB1DLGMB/7MBTLnwQUY6+F09GEiz6SsrNqyzM=
|
|
||||||
google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
||||||
google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
||||||
google.golang.org/protobuf v1.24.0 h1:UhZDfRO8JRQru4/+LlLE0BRKGF8L+PICnvYZmx/fEGA=
|
google.golang.org/protobuf v1.24.0 h1:UhZDfRO8JRQru4/+LlLE0BRKGF8L+PICnvYZmx/fEGA=
|
||||||
|
@ -1210,6 +1173,7 @@ gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
||||||
gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
||||||
gopkg.in/yaml.v2 v2.3.0 h1:clyUAQHOM3G0M3f5vQj7LuJrETvjVot3Z5el9nffUtU=
|
gopkg.in/yaml.v2 v2.3.0 h1:clyUAQHOM3G0M3f5vQj7LuJrETvjVot3Z5el9nffUtU=
|
||||||
gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
|
||||||
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 h1:tQIYjPdBoyREyB9XMu+nnTclpTYkz2zFM+lzLJFO4gQ=
|
gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 h1:tQIYjPdBoyREyB9XMu+nnTclpTYkz2zFM+lzLJFO4gQ=
|
||||||
gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gotest.tools v2.2.0+incompatible h1:VsBPFP1AI068pPrMxtb/S8Zkgf9xEmTLJjfM+P5UIEo=
|
gotest.tools v2.2.0+incompatible h1:VsBPFP1AI068pPrMxtb/S8Zkgf9xEmTLJjfM+P5UIEo=
|
||||||
|
|
|
@ -32,13 +32,13 @@ import (
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/go-openapi/strfmt"
|
"github.com/go-openapi/strfmt"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"go.uber.org/atomic"
|
|
||||||
|
|
||||||
"github.com/prometheus/alertmanager/api/v2/models"
|
"github.com/prometheus/alertmanager/api/v2/models"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
config_util "github.com/prometheus/common/config"
|
config_util "github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/common/version"
|
"github.com/prometheus/common/version"
|
||||||
|
"go.uber.org/atomic"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
|
|
|
@ -29,6 +29,7 @@ import (
|
||||||
"github.com/prometheus/alertmanager/api/v2/models"
|
"github.com/prometheus/alertmanager/api/v2/models"
|
||||||
config_util "github.com/prometheus/common/config"
|
config_util "github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"go.uber.org/atomic"
|
"go.uber.org/atomic"
|
||||||
yaml "gopkg.in/yaml.v2"
|
yaml "gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
@ -36,7 +37,6 @@ import (
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/relabel"
|
"github.com/prometheus/prometheus/pkg/relabel"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestPostPath(t *testing.T) {
|
func TestPostPath(t *testing.T) {
|
||||||
|
@ -65,7 +65,7 @@ func TestPostPath(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
testutil.Equals(t, c.out, postPath(c.in, config.AlertmanagerAPIVersionV1))
|
assert.Equal(t, c.out, postPath(c.in, config.AlertmanagerAPIVersionV1))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,10 +80,10 @@ func TestHandlerNextBatch(t *testing.T) {
|
||||||
|
|
||||||
expected := append([]*Alert{}, h.queue...)
|
expected := append([]*Alert{}, h.queue...)
|
||||||
|
|
||||||
testutil.Ok(t, alertsEqual(expected[0:maxBatchSize], h.nextBatch()))
|
assert.NoError(t, alertsEqual(expected[0:maxBatchSize], h.nextBatch()))
|
||||||
testutil.Ok(t, alertsEqual(expected[maxBatchSize:2*maxBatchSize], h.nextBatch()))
|
assert.NoError(t, alertsEqual(expected[maxBatchSize:2*maxBatchSize], h.nextBatch()))
|
||||||
testutil.Ok(t, alertsEqual(expected[2*maxBatchSize:], h.nextBatch()))
|
assert.NoError(t, alertsEqual(expected[2*maxBatchSize:], h.nextBatch()))
|
||||||
testutil.Assert(t, len(h.queue) == 0, "Expected queue to be empty but got %d alerts", len(h.queue))
|
assert.True(t, len(h.queue) == 0, "Expected queue to be empty but got %d alerts", len(h.queue))
|
||||||
}
|
}
|
||||||
|
|
||||||
func alertsEqual(a, b []*Alert) error {
|
func alertsEqual(a, b []*Alert) error {
|
||||||
|
@ -188,20 +188,20 @@ func TestHandlerSendAll(t *testing.T) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
select {
|
select {
|
||||||
case err := <-errc:
|
case err := <-errc:
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Assert(t, h.sendAll(h.queue...), "all sends failed unexpectedly")
|
assert.True(t, h.sendAll(h.queue...), "all sends failed unexpectedly")
|
||||||
checkNoErr()
|
checkNoErr()
|
||||||
|
|
||||||
status1.Store(int32(http.StatusNotFound))
|
status1.Store(int32(http.StatusNotFound))
|
||||||
testutil.Assert(t, h.sendAll(h.queue...), "all sends failed unexpectedly")
|
assert.True(t, h.sendAll(h.queue...), "all sends failed unexpectedly")
|
||||||
checkNoErr()
|
checkNoErr()
|
||||||
|
|
||||||
status2.Store(int32(http.StatusInternalServerError))
|
status2.Store(int32(http.StatusInternalServerError))
|
||||||
testutil.Assert(t, !h.sendAll(h.queue...), "all sends succeeded unexpectedly")
|
assert.True(t, !h.sendAll(h.queue...), "all sends succeeded unexpectedly")
|
||||||
checkNoErr()
|
checkNoErr()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -215,11 +215,11 @@ func TestCustomDo(t *testing.T) {
|
||||||
received = true
|
received = true
|
||||||
body, err := ioutil.ReadAll(req.Body)
|
body, err := ioutil.ReadAll(req.Body)
|
||||||
|
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
testutil.Equals(t, testBody, string(body))
|
assert.Equal(t, testBody, string(body))
|
||||||
|
|
||||||
testutil.Equals(t, testURL, req.URL.String())
|
assert.Equal(t, testURL, req.URL.String())
|
||||||
|
|
||||||
return &http.Response{
|
return &http.Response{
|
||||||
Body: ioutil.NopCloser(bytes.NewBuffer(nil)),
|
Body: ioutil.NopCloser(bytes.NewBuffer(nil)),
|
||||||
|
@ -229,7 +229,7 @@ func TestCustomDo(t *testing.T) {
|
||||||
|
|
||||||
h.sendOne(context.Background(), nil, testURL, []byte(testBody))
|
h.sendOne(context.Background(), nil, testURL, []byte(testBody))
|
||||||
|
|
||||||
testutil.Assert(t, received, "Expected to receive an alert, but didn't")
|
assert.True(t, received, "Expected to receive an alert, but didn't")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestExternalLabels(t *testing.T) {
|
func TestExternalLabels(t *testing.T) {
|
||||||
|
@ -263,7 +263,7 @@ func TestExternalLabels(t *testing.T) {
|
||||||
{Labels: labels.FromStrings("alertname", "externalrelabelthis", "a", "c")},
|
{Labels: labels.FromStrings("alertname", "externalrelabelthis", "a", "c")},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, alertsEqual(expected, h.queue))
|
assert.NoError(t, alertsEqual(expected, h.queue))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestHandlerRelabel(t *testing.T) {
|
func TestHandlerRelabel(t *testing.T) {
|
||||||
|
@ -299,7 +299,7 @@ func TestHandlerRelabel(t *testing.T) {
|
||||||
{Labels: labels.FromStrings("alertname", "renamed")},
|
{Labels: labels.FromStrings("alertname", "renamed")},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, alertsEqual(expected, h.queue))
|
assert.NoError(t, alertsEqual(expected, h.queue))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestHandlerQueuing(t *testing.T) {
|
func TestHandlerQueuing(t *testing.T) {
|
||||||
|
@ -375,7 +375,7 @@ func TestHandlerQueuing(t *testing.T) {
|
||||||
case <-called:
|
case <-called:
|
||||||
expectedc <- expected
|
expectedc <- expected
|
||||||
case err := <-errc:
|
case err := <-errc:
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
return
|
return
|
||||||
case <-time.After(5 * time.Second):
|
case <-time.After(5 * time.Second):
|
||||||
t.Fatalf("Alerts were not pushed")
|
t.Fatalf("Alerts were not pushed")
|
||||||
|
@ -408,7 +408,7 @@ func TestHandlerQueuing(t *testing.T) {
|
||||||
expectedc <- alerts[:maxBatchSize]
|
expectedc <- alerts[:maxBatchSize]
|
||||||
select {
|
select {
|
||||||
case err := <-errc:
|
case err := <-errc:
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
case <-time.After(5 * time.Second):
|
case <-time.After(5 * time.Second):
|
||||||
t.Fatalf("Alerts were not pushed")
|
t.Fatalf("Alerts were not pushed")
|
||||||
}
|
}
|
||||||
|
@ -435,10 +435,10 @@ func TestLabelSetNotReused(t *testing.T) {
|
||||||
tg := makeInputTargetGroup()
|
tg := makeInputTargetGroup()
|
||||||
_, _, err := alertmanagerFromGroup(tg, &config.AlertmanagerConfig{})
|
_, _, err := alertmanagerFromGroup(tg, &config.AlertmanagerConfig{})
|
||||||
|
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
// Target modified during alertmanager extraction
|
// Target modified during alertmanager extraction
|
||||||
testutil.Equals(t, tg, makeInputTargetGroup())
|
assert.Equal(t, tg, makeInputTargetGroup())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestReload(t *testing.T) {
|
func TestReload(t *testing.T) {
|
||||||
|
@ -469,7 +469,7 @@ alerting:
|
||||||
if err := yaml.UnmarshalStrict([]byte(s), cfg); err != nil {
|
if err := yaml.UnmarshalStrict([]byte(s), cfg); err != nil {
|
||||||
t.Fatalf("Unable to load YAML config: %s", err)
|
t.Fatalf("Unable to load YAML config: %s", err)
|
||||||
}
|
}
|
||||||
testutil.Equals(t, 1, len(cfg.AlertingConfig.AlertmanagerConfigs))
|
assert.Equal(t, 1, len(cfg.AlertingConfig.AlertmanagerConfigs))
|
||||||
|
|
||||||
if err := n.ApplyConfig(cfg); err != nil {
|
if err := n.ApplyConfig(cfg); err != nil {
|
||||||
t.Fatalf("Error Applying the config:%v", err)
|
t.Fatalf("Error Applying the config:%v", err)
|
||||||
|
@ -486,7 +486,7 @@ alerting:
|
||||||
n.reload(tgs)
|
n.reload(tgs)
|
||||||
res := n.Alertmanagers()[0].String()
|
res := n.Alertmanagers()[0].String()
|
||||||
|
|
||||||
testutil.Equals(t, tt.out, res)
|
assert.Equal(t, tt.out, res)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -523,7 +523,7 @@ alerting:
|
||||||
if err := yaml.UnmarshalStrict([]byte(s), cfg); err != nil {
|
if err := yaml.UnmarshalStrict([]byte(s), cfg); err != nil {
|
||||||
t.Fatalf("Unable to load YAML config: %s", err)
|
t.Fatalf("Unable to load YAML config: %s", err)
|
||||||
}
|
}
|
||||||
testutil.Equals(t, 1, len(cfg.AlertingConfig.AlertmanagerConfigs))
|
assert.Equal(t, 1, len(cfg.AlertingConfig.AlertmanagerConfigs))
|
||||||
|
|
||||||
if err := n.ApplyConfig(cfg); err != nil {
|
if err := n.ApplyConfig(cfg); err != nil {
|
||||||
t.Fatalf("Error Applying the config:%v", err)
|
t.Fatalf("Error Applying the config:%v", err)
|
||||||
|
@ -541,7 +541,7 @@ alerting:
|
||||||
n.reload(tgs)
|
n.reload(tgs)
|
||||||
res := n.DroppedAlertmanagers()[0].String()
|
res := n.DroppedAlertmanagers()[0].String()
|
||||||
|
|
||||||
testutil.Equals(t, res, tt.out)
|
assert.Equal(t, res, tt.out)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -561,5 +561,5 @@ func makeInputTargetGroup() *targetgroup.Group {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabelsToOpenAPILabelSet(t *testing.T) {
|
func TestLabelsToOpenAPILabelSet(t *testing.T) {
|
||||||
testutil.Equals(t, models.LabelSet{"aaa": "111", "bbb": "222"}, labelsToOpenAPILabelSet(labels.Labels{{Name: "aaa", Value: "111"}, {Name: "bbb", Value: "222"}}))
|
assert.Equal(t, models.LabelSet{"aaa": "111", "bbb": "222"}, labelsToOpenAPILabelSet(labels.Labels{{Name: "aaa", Value: "111"}, {Name: "bbb", Value: "222"}}))
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestLabels_String(t *testing.T) {
|
func TestLabels_String(t *testing.T) {
|
||||||
|
@ -50,7 +50,7 @@ func TestLabels_String(t *testing.T) {
|
||||||
}
|
}
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
str := c.lables.String()
|
str := c.lables.String()
|
||||||
testutil.Equals(t, c.expected, str)
|
assert.Equal(t, c.expected, str)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -181,7 +181,7 @@ func TestLabels_MatchLabels(t *testing.T) {
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
got := labels.MatchLabels(test.on, test.providedNames...)
|
got := labels.MatchLabels(test.on, test.providedNames...)
|
||||||
testutil.Equals(t, test.expected, got, "unexpected labelset for test case %d", i)
|
assert.Equal(t, test.expected, got, "unexpected labelset for test case %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -206,8 +206,8 @@ func TestLabels_HasDuplicateLabelNames(t *testing.T) {
|
||||||
|
|
||||||
for i, c := range cases {
|
for i, c := range cases {
|
||||||
l, d := c.Input.HasDuplicateLabelNames()
|
l, d := c.Input.HasDuplicateLabelNames()
|
||||||
testutil.Equals(t, c.Duplicate, d, "test %d: incorrect duplicate bool", i)
|
assert.Equal(t, c.Duplicate, d, "test %d: incorrect duplicate bool", i)
|
||||||
testutil.Equals(t, c.LabelName, l, "test %d: incorrect label name", i)
|
assert.Equal(t, c.LabelName, l, "test %d: incorrect label name", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -287,7 +287,7 @@ func TestLabels_WithoutEmpty(t *testing.T) {
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
t.Run("", func(t *testing.T) {
|
t.Run("", func(t *testing.T) {
|
||||||
testutil.Equals(t, test.expected, test.input.WithoutEmpty())
|
assert.Equal(t, test.expected, test.input.WithoutEmpty())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -368,7 +368,7 @@ func TestLabels_Equal(t *testing.T) {
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
got := Equal(labels, test.compared)
|
got := Equal(labels, test.compared)
|
||||||
testutil.Equals(t, test.expected, got, "unexpected comparison result for test case %d", i)
|
assert.Equal(t, test.expected, got, "unexpected comparison result for test case %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -385,12 +385,12 @@ func TestLabels_FromStrings(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, expected, labels, "unexpected labelset")
|
assert.Equal(t, expected, labels, "unexpected labelset")
|
||||||
|
|
||||||
defer func() { recover() }()
|
defer func() { recover() }()
|
||||||
FromStrings("aaa", "111", "bbb")
|
FromStrings("aaa", "111", "bbb")
|
||||||
|
|
||||||
testutil.Assert(t, false, "did not panic as expected")
|
assert.True(t, false, "did not panic as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabels_Compare(t *testing.T) {
|
func TestLabels_Compare(t *testing.T) {
|
||||||
|
@ -508,7 +508,7 @@ func TestLabels_Compare(t *testing.T) {
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
got := Compare(labels, test.compared)
|
got := Compare(labels, test.compared)
|
||||||
testutil.Equals(t, test.expected, got, "unexpected comparison result for test case %d", i)
|
assert.Equal(t, test.expected, got, "unexpected comparison result for test case %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -540,34 +540,34 @@ func TestLabels_Has(t *testing.T) {
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
got := labelsSet.Has(test.input)
|
got := labelsSet.Has(test.input)
|
||||||
testutil.Equals(t, test.expected, got, "unexpected comparison result for test case %d", i)
|
assert.Equal(t, test.expected, got, "unexpected comparison result for test case %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabels_Get(t *testing.T) {
|
func TestLabels_Get(t *testing.T) {
|
||||||
testutil.Equals(t, "", Labels{{"aaa", "111"}, {"bbb", "222"}}.Get("foo"))
|
assert.Equal(t, "", Labels{{"aaa", "111"}, {"bbb", "222"}}.Get("foo"))
|
||||||
testutil.Equals(t, "111", Labels{{"aaa", "111"}, {"bbb", "222"}}.Get("aaa"))
|
assert.Equal(t, "111", Labels{{"aaa", "111"}, {"bbb", "222"}}.Get("aaa"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabels_Copy(t *testing.T) {
|
func TestLabels_Copy(t *testing.T) {
|
||||||
testutil.Equals(t, Labels{{"aaa", "111"}, {"bbb", "222"}}, Labels{{"aaa", "111"}, {"bbb", "222"}}.Copy())
|
assert.Equal(t, Labels{{"aaa", "111"}, {"bbb", "222"}}, Labels{{"aaa", "111"}, {"bbb", "222"}}.Copy())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabels_Map(t *testing.T) {
|
func TestLabels_Map(t *testing.T) {
|
||||||
testutil.Equals(t, map[string]string{"aaa": "111", "bbb": "222"}, Labels{{"aaa", "111"}, {"bbb", "222"}}.Map())
|
assert.Equal(t, map[string]string{"aaa": "111", "bbb": "222"}, Labels{{"aaa", "111"}, {"bbb", "222"}}.Map())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabels_WithLabels(t *testing.T) {
|
func TestLabels_WithLabels(t *testing.T) {
|
||||||
testutil.Equals(t, Labels{{"aaa", "111"}, {"bbb", "222"}}, Labels{{"aaa", "111"}, {"bbb", "222"}, {"ccc", "333"}}.WithLabels("aaa", "bbb"))
|
assert.Equal(t, Labels{{"aaa", "111"}, {"bbb", "222"}}, Labels{{"aaa", "111"}, {"bbb", "222"}, {"ccc", "333"}}.WithLabels("aaa", "bbb"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLabels_WithoutLabels(t *testing.T) {
|
func TestLabels_WithoutLabels(t *testing.T) {
|
||||||
testutil.Equals(t, Labels{{"aaa", "111"}}, Labels{{"aaa", "111"}, {"bbb", "222"}, {"ccc", "333"}}.WithoutLabels("bbb", "ccc"))
|
assert.Equal(t, Labels{{"aaa", "111"}}, Labels{{"aaa", "111"}, {"bbb", "222"}, {"ccc", "333"}}.WithoutLabels("bbb", "ccc"))
|
||||||
testutil.Equals(t, Labels{{"aaa", "111"}}, Labels{{"aaa", "111"}, {"bbb", "222"}, {MetricName, "333"}}.WithoutLabels("bbb"))
|
assert.Equal(t, Labels{{"aaa", "111"}}, Labels{{"aaa", "111"}, {"bbb", "222"}, {MetricName, "333"}}.WithoutLabels("bbb"))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBulider_NewBulider(t *testing.T) {
|
func TestBulider_NewBulider(t *testing.T) {
|
||||||
testutil.Equals(
|
assert.Equal(
|
||||||
t,
|
t,
|
||||||
&Builder{
|
&Builder{
|
||||||
base: Labels{{"aaa", "111"}},
|
base: Labels{{"aaa", "111"}},
|
||||||
|
@ -579,7 +579,7 @@ func TestBulider_NewBulider(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBuilder_Del(t *testing.T) {
|
func TestBuilder_Del(t *testing.T) {
|
||||||
testutil.Equals(
|
assert.Equal(
|
||||||
t,
|
t,
|
||||||
&Builder{
|
&Builder{
|
||||||
del: []string{"bbb"},
|
del: []string{"bbb"},
|
||||||
|
@ -593,7 +593,7 @@ func TestBuilder_Del(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBuilder_Set(t *testing.T) {
|
func TestBuilder_Set(t *testing.T) {
|
||||||
testutil.Equals(
|
assert.Equal(
|
||||||
t,
|
t,
|
||||||
&Builder{
|
&Builder{
|
||||||
base: Labels{{"aaa", "111"}},
|
base: Labels{{"aaa", "111"}},
|
||||||
|
@ -607,7 +607,7 @@ func TestBuilder_Set(t *testing.T) {
|
||||||
}).Set("bbb", "222"),
|
}).Set("bbb", "222"),
|
||||||
)
|
)
|
||||||
|
|
||||||
testutil.Equals(
|
assert.Equal(
|
||||||
t,
|
t,
|
||||||
&Builder{
|
&Builder{
|
||||||
base: Labels{{"aaa", "111"}},
|
base: Labels{{"aaa", "111"}},
|
||||||
|
@ -623,7 +623,7 @@ func TestBuilder_Set(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBuilder_Labels(t *testing.T) {
|
func TestBuilder_Labels(t *testing.T) {
|
||||||
testutil.Equals(
|
assert.Equal(
|
||||||
t,
|
t,
|
||||||
Labels{{"aaa", "111"}, {"ccc", "333"}, {"ddd", "444"}},
|
Labels{{"aaa", "111"}, {"ccc", "333"}, {"ddd", "444"}},
|
||||||
(&Builder{
|
(&Builder{
|
||||||
|
@ -639,9 +639,9 @@ func TestLabels_Hash(t *testing.T) {
|
||||||
{Name: "foo", Value: "bar"},
|
{Name: "foo", Value: "bar"},
|
||||||
{Name: "baz", Value: "qux"},
|
{Name: "baz", Value: "qux"},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, lbls.Hash(), lbls.Hash())
|
assert.Equal(t, lbls.Hash(), lbls.Hash())
|
||||||
testutil.Assert(t, lbls.Hash() != Labels{lbls[1], lbls[0]}.Hash(), "unordered labels match.")
|
assert.True(t, lbls.Hash() != Labels{lbls[1], lbls[0]}.Hash(), "unordered labels match.")
|
||||||
testutil.Assert(t, lbls.Hash() != Labels{lbls[0]}.Hash(), "different labels match.")
|
assert.True(t, lbls.Hash() != Labels{lbls[0]}.Hash(), "different labels match.")
|
||||||
}
|
}
|
||||||
|
|
||||||
var benchmarkLabelsResult uint64
|
var benchmarkLabelsResult uint64
|
||||||
|
|
|
@ -16,12 +16,12 @@ package labels
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func mustNewMatcher(t *testing.T, mType MatchType, value string) *Matcher {
|
func mustNewMatcher(t *testing.T, mType MatchType, value string) *Matcher {
|
||||||
m, err := NewMatcher(mType, "", value)
|
m, err := NewMatcher(mType, "", value)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ func TestMatcher(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
testutil.Equals(t, test.matcher.Matches(test.value), test.match)
|
assert.Equal(t, test.matcher.Matches(test.value), test.match)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,7 +113,7 @@ func TestInverse(t *testing.T) {
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
result, err := test.matcher.Inverse()
|
result, err := test.matcher.Inverse()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, test.expected.Type, result.Type)
|
assert.Equal(t, test.expected.Type, result.Type)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ import (
|
||||||
"regexp/syntax"
|
"regexp/syntax"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestNewFastRegexMatcher(t *testing.T) {
|
func TestNewFastRegexMatcher(t *testing.T) {
|
||||||
|
@ -54,8 +54,8 @@ func TestNewFastRegexMatcher(t *testing.T) {
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
m, err := NewFastRegexMatcher(c.regex)
|
m, err := NewFastRegexMatcher(c.regex)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, c.expected, m.MatchString(c.value))
|
assert.Equal(t, c.expected, m.MatchString(c.value))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,11 +88,11 @@ func TestOptimizeConcatRegex(t *testing.T) {
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
parsed, err := syntax.Parse(c.regex, syntax.Perl)
|
parsed, err := syntax.Parse(c.regex, syntax.Perl)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
prefix, suffix, contains := optimizeConcatRegex(parsed)
|
prefix, suffix, contains := optimizeConcatRegex(parsed)
|
||||||
testutil.Equals(t, c.prefix, prefix)
|
assert.Equal(t, c.prefix, prefix)
|
||||||
testutil.Equals(t, c.suffix, suffix)
|
assert.Equal(t, c.suffix, suffix)
|
||||||
testutil.Equals(t, c.contains, contains)
|
assert.Equal(t, c.contains, contains)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type counter int
|
type counter int
|
||||||
|
@ -35,13 +35,13 @@ func TestDedupe(t *testing.T) {
|
||||||
// Log 10 times quickly, ensure they are deduped.
|
// Log 10 times quickly, ensure they are deduped.
|
||||||
for i := 0; i < 10; i++ {
|
for i := 0; i < 10; i++ {
|
||||||
err := d.Log("msg", "hello")
|
err := d.Log("msg", "hello")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
testutil.Equals(t, 1, int(c))
|
assert.Equal(t, 1, int(c))
|
||||||
|
|
||||||
// Wait, then log again, make sure it is logged.
|
// Wait, then log again, make sure it is logged.
|
||||||
time.Sleep(200 * time.Millisecond)
|
time.Sleep(200 * time.Millisecond)
|
||||||
err := d.Log("msg", "hello")
|
err := d.Log("msg", "hello")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 2, int(c))
|
assert.Equal(t, 2, int(c))
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,71 +20,71 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestJSONFileLogger_basic(t *testing.T) {
|
func TestJSONFileLogger_basic(t *testing.T) {
|
||||||
f, err := ioutil.TempFile("", "logging")
|
f, err := ioutil.TempFile("", "logging")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, f.Close())
|
assert.NoError(t, f.Close())
|
||||||
testutil.Ok(t, os.Remove(f.Name()))
|
assert.NoError(t, os.Remove(f.Name()))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
l, err := NewJSONFileLogger(f.Name())
|
l, err := NewJSONFileLogger(f.Name())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, l != nil, "logger can't be nil")
|
assert.NotNil(t, l, "logger can't be nil")
|
||||||
|
|
||||||
err = l.Log("test", "yes")
|
err = l.Log("test", "yes")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
r := make([]byte, 1024)
|
r := make([]byte, 1024)
|
||||||
_, err = f.Read(r)
|
_, err = f.Read(r)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
result, err := regexp.Match(`^{"test":"yes","ts":"[^"]+"}\n`, r)
|
result, err := regexp.Match(`^{"test":"yes","ts":"[^"]+"}\n`, r)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, result, "unexpected content: %s", r)
|
assert.True(t, result, "unexpected content: %s", r)
|
||||||
|
|
||||||
err = l.Close()
|
err = l.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
err = l.file.Close()
|
err = l.file.Close()
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, strings.HasSuffix(err.Error(), os.ErrClosed.Error()), "file not closed")
|
assert.True(t, strings.HasSuffix(err.Error(), os.ErrClosed.Error()), "file not closed")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestJSONFileLogger_parallel(t *testing.T) {
|
func TestJSONFileLogger_parallel(t *testing.T) {
|
||||||
f, err := ioutil.TempFile("", "logging")
|
f, err := ioutil.TempFile("", "logging")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, f.Close())
|
assert.NoError(t, f.Close())
|
||||||
testutil.Ok(t, os.Remove(f.Name()))
|
assert.NoError(t, os.Remove(f.Name()))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
l, err := NewJSONFileLogger(f.Name())
|
l, err := NewJSONFileLogger(f.Name())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, l != nil, "logger can't be nil")
|
assert.NotNil(t, l, "logger can't be nil")
|
||||||
|
|
||||||
err = l.Log("test", "yes")
|
err = l.Log("test", "yes")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
l2, err := NewJSONFileLogger(f.Name())
|
l2, err := NewJSONFileLogger(f.Name())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, l != nil, "logger can't be nil")
|
assert.NotNil(t, l, "logger can't be nil")
|
||||||
|
|
||||||
err = l2.Log("test", "yes")
|
err = l2.Log("test", "yes")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
err = l.Close()
|
err = l.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
err = l.file.Close()
|
err = l.file.Close()
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, strings.HasSuffix(err.Error(), os.ErrClosed.Error()), "file not closed")
|
assert.True(t, strings.HasSuffix(err.Error(), os.ErrClosed.Error()), "file not closed")
|
||||||
|
|
||||||
err = l2.Close()
|
err = l2.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
err = l2.file.Close()
|
err = l2.file.Close()
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, strings.HasSuffix(err.Error(), os.ErrClosed.Error()), "file not closed")
|
assert.True(t, strings.HasSuffix(err.Error(), os.ErrClosed.Error()), "file not closed")
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ package pool
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func makeFunc(size int) interface{} {
|
func makeFunc(size int) interface{} {
|
||||||
|
@ -44,7 +44,7 @@ func TestPool(t *testing.T) {
|
||||||
}
|
}
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
ret := testPool.Get(c.size)
|
ret := testPool.Get(c.size)
|
||||||
testutil.Equals(t, c.expectedCap, cap(ret.([]int)))
|
assert.Equal(t, c.expectedCap, cap(ret.([]int)))
|
||||||
testPool.Put(ret)
|
testPool.Put(ret)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,9 +17,9 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestRelabel(t *testing.T) {
|
func TestRelabel(t *testing.T) {
|
||||||
|
@ -414,7 +414,7 @@ func TestRelabel(t *testing.T) {
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
res := Process(test.input, test.relabel...)
|
res := Process(test.input, test.relabel...)
|
||||||
testutil.Equals(t, test.output, res)
|
assert.Equal(t, test.output, res)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -440,7 +440,7 @@ func TestTargetLabelValidity(t *testing.T) {
|
||||||
{"foo${bar}foo", true},
|
{"foo${bar}foo", true},
|
||||||
}
|
}
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
testutil.Assert(t, relabelTarget.Match([]byte(test.str)) == test.valid,
|
assert.True(t, relabelTarget.Match([]byte(test.str)) == test.valid,
|
||||||
"Expected %q to be %v", test.str, test.valid)
|
"Expected %q to be %v", test.str, test.valid)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestParseFileSuccess(t *testing.T) {
|
func TestParseFileSuccess(t *testing.T) {
|
||||||
|
@ -163,9 +163,9 @@ groups:
|
||||||
|
|
||||||
for _, tst := range tests {
|
for _, tst := range tests {
|
||||||
rgs, errs := Parse([]byte(tst.ruleString))
|
rgs, errs := Parse([]byte(tst.ruleString))
|
||||||
testutil.Assert(t, rgs != nil, "Rule parsing, rule=\n"+tst.ruleString)
|
assert.NotNil(t, rgs, "Rule parsing, rule=\n"+tst.ruleString)
|
||||||
passed := (tst.shouldPass && len(errs) == 0) || (!tst.shouldPass && len(errs) > 0)
|
passed := (tst.shouldPass && len(errs) == 0) || (!tst.shouldPass && len(errs) > 0)
|
||||||
testutil.Assert(t, passed, "Rule validation failed, rule=\n"+tst.ruleString)
|
assert.True(t, passed, "Rule validation failed, rule=\n"+tst.ruleString)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,9 +17,10 @@ import (
|
||||||
"io"
|
"io"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/exemplar"
|
"github.com/prometheus/prometheus/pkg/exemplar"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestOpenMetricsParse(t *testing.T) {
|
func TestOpenMetricsParse(t *testing.T) {
|
||||||
|
@ -220,7 +221,7 @@ foo_total 17.0 1520879607.789 # {xx="yy"} 5`
|
||||||
if err == io.EOF {
|
if err == io.EOF {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
switch et {
|
switch et {
|
||||||
case EntrySeries:
|
case EntrySeries:
|
||||||
|
@ -230,40 +231,40 @@ foo_total 17.0 1520879607.789 # {xx="yy"} 5`
|
||||||
p.Metric(&res)
|
p.Metric(&res)
|
||||||
found := p.Exemplar(&e)
|
found := p.Exemplar(&e)
|
||||||
|
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].t, ts)
|
assert.Equal(t, exp[i].t, ts)
|
||||||
testutil.Equals(t, exp[i].v, v)
|
assert.Equal(t, exp[i].v, v)
|
||||||
testutil.Equals(t, exp[i].lset, res)
|
assert.Equal(t, exp[i].lset, res)
|
||||||
if exp[i].e == nil {
|
if exp[i].e == nil {
|
||||||
testutil.Equals(t, false, found)
|
assert.Equal(t, false, found)
|
||||||
} else {
|
} else {
|
||||||
testutil.Equals(t, true, found)
|
assert.Equal(t, true, found)
|
||||||
testutil.Equals(t, *exp[i].e, e)
|
assert.Equal(t, *exp[i].e, e)
|
||||||
}
|
}
|
||||||
res = res[:0]
|
res = res[:0]
|
||||||
|
|
||||||
case EntryType:
|
case EntryType:
|
||||||
m, typ := p.Type()
|
m, typ := p.Type()
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].typ, typ)
|
assert.Equal(t, exp[i].typ, typ)
|
||||||
|
|
||||||
case EntryHelp:
|
case EntryHelp:
|
||||||
m, h := p.Help()
|
m, h := p.Help()
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].help, string(h))
|
assert.Equal(t, exp[i].help, string(h))
|
||||||
|
|
||||||
case EntryUnit:
|
case EntryUnit:
|
||||||
m, u := p.Unit()
|
m, u := p.Unit()
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].unit, string(u))
|
assert.Equal(t, exp[i].unit, string(u))
|
||||||
|
|
||||||
case EntryComment:
|
case EntryComment:
|
||||||
testutil.Equals(t, exp[i].comment, string(p.Comment()))
|
assert.Equal(t, exp[i].comment, string(p.Comment()))
|
||||||
}
|
}
|
||||||
|
|
||||||
i++
|
i++
|
||||||
}
|
}
|
||||||
testutil.Equals(t, len(exp), i)
|
assert.Equal(t, len(exp), i)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestOpenMetricsParseErrors(t *testing.T) {
|
func TestOpenMetricsParseErrors(t *testing.T) {
|
||||||
|
@ -510,7 +511,7 @@ func TestOpenMetricsParseErrors(t *testing.T) {
|
||||||
for err == nil {
|
for err == nil {
|
||||||
_, err = p.Next()
|
_, err = p.Next()
|
||||||
}
|
}
|
||||||
testutil.Equals(t, c.err, err.Error(), "test %d: %s", i, c.input)
|
assert.Equal(t, c.err, err.Error(), "test %d: %s", i, c.input)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -577,10 +578,10 @@ func TestOMNullByteHandling(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if c.err == "" {
|
if c.err == "" {
|
||||||
testutil.Equals(t, io.EOF, err, "test %d", i)
|
assert.Equal(t, io.EOF, err, "test %d", i)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, c.err, err.Error(), "test %d", i)
|
assert.Equal(t, c.err, err.Error(), "test %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,8 +23,9 @@ import (
|
||||||
|
|
||||||
"github.com/prometheus/common/expfmt"
|
"github.com/prometheus/common/expfmt"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestPromParse(t *testing.T) {
|
func TestPromParse(t *testing.T) {
|
||||||
|
@ -179,7 +180,7 @@ testmetric{label="\"bar\""} 1`
|
||||||
if err == io.EOF {
|
if err == io.EOF {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
switch et {
|
switch et {
|
||||||
case EntrySeries:
|
case EntrySeries:
|
||||||
|
@ -187,29 +188,29 @@ testmetric{label="\"bar\""} 1`
|
||||||
|
|
||||||
p.Metric(&res)
|
p.Metric(&res)
|
||||||
|
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].t, ts)
|
assert.Equal(t, exp[i].t, ts)
|
||||||
testutil.Equals(t, exp[i].v, v)
|
assert.Equal(t, exp[i].v, v)
|
||||||
testutil.Equals(t, exp[i].lset, res)
|
assert.Equal(t, exp[i].lset, res)
|
||||||
res = res[:0]
|
res = res[:0]
|
||||||
|
|
||||||
case EntryType:
|
case EntryType:
|
||||||
m, typ := p.Type()
|
m, typ := p.Type()
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].typ, typ)
|
assert.Equal(t, exp[i].typ, typ)
|
||||||
|
|
||||||
case EntryHelp:
|
case EntryHelp:
|
||||||
m, h := p.Help()
|
m, h := p.Help()
|
||||||
testutil.Equals(t, exp[i].m, string(m))
|
assert.Equal(t, exp[i].m, string(m))
|
||||||
testutil.Equals(t, exp[i].help, string(h))
|
assert.Equal(t, exp[i].help, string(h))
|
||||||
|
|
||||||
case EntryComment:
|
case EntryComment:
|
||||||
testutil.Equals(t, exp[i].comment, string(p.Comment()))
|
assert.Equal(t, exp[i].comment, string(p.Comment()))
|
||||||
}
|
}
|
||||||
|
|
||||||
i++
|
i++
|
||||||
}
|
}
|
||||||
testutil.Equals(t, len(exp), i)
|
assert.Equal(t, len(exp), i)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPromParseErrors(t *testing.T) {
|
func TestPromParseErrors(t *testing.T) {
|
||||||
|
@ -277,8 +278,8 @@ func TestPromParseErrors(t *testing.T) {
|
||||||
for err == nil {
|
for err == nil {
|
||||||
_, err = p.Next()
|
_, err = p.Next()
|
||||||
}
|
}
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Equals(t, c.err, err.Error(), "test %d", i)
|
assert.Equal(t, c.err, err.Error(), "test %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -329,12 +330,12 @@ func TestPromNullByteHandling(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if c.err == "" {
|
if c.err == "" {
|
||||||
testutil.Equals(t, io.EOF, err, "test %d", i)
|
assert.Equal(t, io.EOF, err, "test %d", i)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Equals(t, c.err, err.Error(), "test %d", i)
|
assert.Equal(t, c.err, err.Error(), "test %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -349,11 +350,11 @@ func BenchmarkParse(b *testing.B) {
|
||||||
} {
|
} {
|
||||||
for _, fn := range []string{"promtestdata.txt", "promtestdata.nometa.txt"} {
|
for _, fn := range []string{"promtestdata.txt", "promtestdata.nometa.txt"} {
|
||||||
f, err := os.Open(fn)
|
f, err := os.Open(fn)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
buf, err := ioutil.ReadAll(f)
|
buf, err := ioutil.ReadAll(f)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
|
|
||||||
b.Run(parserName+"/no-decode-metric/"+fn, func(b *testing.B) {
|
b.Run(parserName+"/no-decode-metric/"+fn, func(b *testing.B) {
|
||||||
total := 0
|
total := 0
|
||||||
|
@ -483,18 +484,18 @@ func BenchmarkGzip(b *testing.B) {
|
||||||
for _, fn := range []string{"promtestdata.txt", "promtestdata.nometa.txt"} {
|
for _, fn := range []string{"promtestdata.txt", "promtestdata.nometa.txt"} {
|
||||||
b.Run(fn, func(b *testing.B) {
|
b.Run(fn, func(b *testing.B) {
|
||||||
f, err := os.Open(fn)
|
f, err := os.Open(fn)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
var buf bytes.Buffer
|
var buf bytes.Buffer
|
||||||
gw := gzip.NewWriter(&buf)
|
gw := gzip.NewWriter(&buf)
|
||||||
|
|
||||||
n, err := io.Copy(gw, f)
|
n, err := io.Copy(gw, f)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
testutil.Ok(b, gw.Close())
|
assert.NoError(b, gw.Close())
|
||||||
|
|
||||||
gbuf, err := ioutil.ReadAll(&buf)
|
gbuf, err := ioutil.ReadAll(&buf)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
|
|
||||||
k := b.N / promtestdataSampleCount
|
k := b.N / promtestdataSampleCount
|
||||||
|
|
||||||
|
@ -506,11 +507,11 @@ func BenchmarkGzip(b *testing.B) {
|
||||||
|
|
||||||
for i := 0; i < k; i++ {
|
for i := 0; i < k; i++ {
|
||||||
gr, err := gzip.NewReader(bytes.NewReader(gbuf))
|
gr, err := gzip.NewReader(bytes.NewReader(gbuf))
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
|
|
||||||
d, err := ioutil.ReadAll(gr)
|
d, err := ioutil.ReadAll(gr)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
testutil.Ok(b, gr.Close())
|
assert.NoError(b, gr.Close())
|
||||||
|
|
||||||
total += len(d)
|
total += len(d)
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,12 +23,13 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
"go.uber.org/goleak"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/timestamp"
|
"github.com/prometheus/prometheus/pkg/timestamp"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
"go.uber.org/goleak"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
@ -39,7 +40,7 @@ func TestQueryConcurrency(t *testing.T) {
|
||||||
maxConcurrency := 10
|
maxConcurrency := 10
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "test_concurrency")
|
dir, err := ioutil.TempDir("", "test_concurrency")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.RemoveAll(dir)
|
defer os.RemoveAll(dir)
|
||||||
queryTracker := NewActiveQueryTracker(dir, maxConcurrency, nil)
|
queryTracker := NewActiveQueryTracker(dir, maxConcurrency, nil)
|
||||||
|
|
||||||
|
@ -118,10 +119,10 @@ func TestQueryTimeout(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
res := query.Exec(ctx)
|
res := query.Exec(ctx)
|
||||||
testutil.NotOk(t, res.Err, "expected timeout error but got none")
|
assert.Error(t, res.Err, "expected timeout error but got none")
|
||||||
|
|
||||||
var e ErrQueryTimeout
|
var e ErrQueryTimeout
|
||||||
testutil.Assert(t, errors.As(res.Err, &e), "expected timeout error but got: %s", res.Err)
|
assert.True(t, errors.As(res.Err, &e), "expected timeout error but got: %s", res.Err)
|
||||||
}
|
}
|
||||||
|
|
||||||
const errQueryCanceled = ErrQueryCanceled("test statement execution")
|
const errQueryCanceled = ErrQueryCanceled("test statement execution")
|
||||||
|
@ -159,8 +160,8 @@ func TestQueryCancel(t *testing.T) {
|
||||||
block <- struct{}{}
|
block <- struct{}{}
|
||||||
<-processing
|
<-processing
|
||||||
|
|
||||||
testutil.NotOk(t, res.Err, "expected cancellation error for query1 but got none")
|
assert.Error(t, res.Err, "expected cancellation error for query1 but got none")
|
||||||
testutil.Equals(t, errQueryCanceled, res.Err)
|
assert.Equal(t, errQueryCanceled, res.Err)
|
||||||
|
|
||||||
// Canceling a query before starting it must have no effect.
|
// Canceling a query before starting it must have no effect.
|
||||||
query2 := engine.newTestQuery(func(ctx context.Context) error {
|
query2 := engine.newTestQuery(func(ctx context.Context) error {
|
||||||
|
@ -169,7 +170,7 @@ func TestQueryCancel(t *testing.T) {
|
||||||
|
|
||||||
query2.Cancel()
|
query2.Cancel()
|
||||||
res = query2.Exec(ctx)
|
res = query2.Exec(ctx)
|
||||||
testutil.Ok(t, res.Err)
|
assert.NoError(t, res.Err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// errQuerier implements storage.Querier which always returns error.
|
// errQuerier implements storage.Querier which always returns error.
|
||||||
|
@ -210,18 +211,18 @@ func TestQueryError(t *testing.T) {
|
||||||
defer cancelCtx()
|
defer cancelCtx()
|
||||||
|
|
||||||
vectorQuery, err := engine.NewInstantQuery(queryable, "foo", time.Unix(1, 0))
|
vectorQuery, err := engine.NewInstantQuery(queryable, "foo", time.Unix(1, 0))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res := vectorQuery.Exec(ctx)
|
res := vectorQuery.Exec(ctx)
|
||||||
testutil.NotOk(t, res.Err, "expected error on failed select but got none")
|
assert.Error(t, res.Err, "expected error on failed select but got none")
|
||||||
testutil.Assert(t, errors.Is(res.Err, errStorage), "expected error doesn't match")
|
assert.True(t, errors.Is(res.Err, errStorage), "expected error doesn't match")
|
||||||
|
|
||||||
matrixQuery, err := engine.NewInstantQuery(queryable, "foo[1m]", time.Unix(1, 0))
|
matrixQuery, err := engine.NewInstantQuery(queryable, "foo[1m]", time.Unix(1, 0))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res = matrixQuery.Exec(ctx)
|
res = matrixQuery.Exec(ctx)
|
||||||
testutil.NotOk(t, res.Err, "expected error on failed select but got none")
|
assert.Error(t, res.Err, "expected error on failed select but got none")
|
||||||
testutil.Assert(t, errors.Is(res.Err, errStorage), "expected error doesn't match")
|
assert.True(t, errors.Is(res.Err, errStorage), "expected error doesn't match")
|
||||||
}
|
}
|
||||||
|
|
||||||
type noopHintRecordingQueryable struct {
|
type noopHintRecordingQueryable struct {
|
||||||
|
@ -377,12 +378,12 @@ func TestSelectHintsSetCorrectly(t *testing.T) {
|
||||||
} else {
|
} else {
|
||||||
query, err = engine.NewRangeQuery(hintsRecorder, tc.query, timestamp.Time(tc.start), timestamp.Time(tc.end), time.Second)
|
query, err = engine.NewRangeQuery(hintsRecorder, tc.query, timestamp.Time(tc.start), timestamp.Time(tc.end), time.Second)
|
||||||
}
|
}
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res := query.Exec(context.Background())
|
res := query.Exec(context.Background())
|
||||||
testutil.Ok(t, res.Err)
|
assert.NoError(t, res.Err)
|
||||||
|
|
||||||
testutil.Equals(t, tc.expected, hintsRecorder.hints)
|
assert.Equal(t, tc.expected, hintsRecorder.hints)
|
||||||
})
|
})
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -425,8 +426,8 @@ func TestEngineShutdown(t *testing.T) {
|
||||||
block <- struct{}{}
|
block <- struct{}{}
|
||||||
<-processing
|
<-processing
|
||||||
|
|
||||||
testutil.NotOk(t, res.Err, "expected error on shutdown during query but got none")
|
assert.Error(t, res.Err, "expected error on shutdown during query but got none")
|
||||||
testutil.Equals(t, errQueryCanceled, res.Err)
|
assert.Equal(t, errQueryCanceled, res.Err)
|
||||||
|
|
||||||
query2 := engine.newTestQuery(func(context.Context) error {
|
query2 := engine.newTestQuery(func(context.Context) error {
|
||||||
t.Fatalf("reached query execution unexpectedly")
|
t.Fatalf("reached query execution unexpectedly")
|
||||||
|
@ -436,10 +437,10 @@ func TestEngineShutdown(t *testing.T) {
|
||||||
// The second query is started after the engine shut down. It must
|
// The second query is started after the engine shut down. It must
|
||||||
// be canceled immediately.
|
// be canceled immediately.
|
||||||
res2 := query2.Exec(ctx)
|
res2 := query2.Exec(ctx)
|
||||||
testutil.NotOk(t, res2.Err, "expected error on querying with canceled context but got none")
|
assert.Error(t, res2.Err, "expected error on querying with canceled context but got none")
|
||||||
|
|
||||||
var e ErrQueryCanceled
|
var e ErrQueryCanceled
|
||||||
testutil.Assert(t, errors.As(res2.Err, &e), "expected cancellation error but got: %s", res2.Err)
|
assert.True(t, errors.As(res2.Err, &e), "expected cancellation error but got: %s", res2.Err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEngineEvalStmtTimestamps(t *testing.T) {
|
func TestEngineEvalStmtTimestamps(t *testing.T) {
|
||||||
|
@ -447,11 +448,11 @@ func TestEngineEvalStmtTimestamps(t *testing.T) {
|
||||||
load 10s
|
load 10s
|
||||||
metric 1 2
|
metric 1 2
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer test.Close()
|
defer test.Close()
|
||||||
|
|
||||||
err = test.Run()
|
err = test.Run()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
cases := []struct {
|
cases := []struct {
|
||||||
Query string
|
Query string
|
||||||
|
@ -528,16 +529,16 @@ load 10s
|
||||||
} else {
|
} else {
|
||||||
qry, err = test.QueryEngine().NewRangeQuery(test.Queryable(), c.Query, c.Start, c.End, c.Interval)
|
qry, err = test.QueryEngine().NewRangeQuery(test.Queryable(), c.Query, c.Start, c.End, c.Interval)
|
||||||
}
|
}
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res := qry.Exec(test.Context())
|
res := qry.Exec(test.Context())
|
||||||
if c.ShouldError {
|
if c.ShouldError {
|
||||||
testutil.NotOk(t, res.Err, "expected error for the query %q", c.Query)
|
assert.Error(t, res.Err, "expected error for the query %q", c.Query)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, res.Err)
|
assert.NoError(t, res.Err)
|
||||||
testutil.Equals(t, c.Result, res.Value, "query %q failed", c.Query)
|
assert.Equal(t, c.Result, res.Value, "query %q failed", c.Query)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -548,11 +549,11 @@ load 10s
|
||||||
bigmetric{a="1"} 1 2
|
bigmetric{a="1"} 1 2
|
||||||
bigmetric{a="2"} 1 2
|
bigmetric{a="2"} 1 2
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer test.Close()
|
defer test.Close()
|
||||||
|
|
||||||
err = test.Run()
|
err = test.Run()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
cases := []struct {
|
cases := []struct {
|
||||||
Query string
|
Query string
|
||||||
|
@ -764,11 +765,11 @@ load 10s
|
||||||
} else {
|
} else {
|
||||||
qry, err = engine.NewRangeQuery(test.Queryable(), c.Query, c.Start, c.End, c.Interval)
|
qry, err = engine.NewRangeQuery(test.Queryable(), c.Query, c.Start, c.End, c.Interval)
|
||||||
}
|
}
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res := qry.Exec(test.Context())
|
res := qry.Exec(test.Context())
|
||||||
testutil.Equals(t, c.Result.Err, res.Err)
|
assert.Equal(t, c.Result.Err, res.Err)
|
||||||
testutil.Equals(t, c.Result.Value, res.Value, "query %q failed", c.Query)
|
assert.Equal(t, c.Result.Value, res.Value, "query %q failed", c.Query)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1051,21 +1052,21 @@ func TestSubquerySelector(t *testing.T) {
|
||||||
} {
|
} {
|
||||||
t.Run("", func(t *testing.T) {
|
t.Run("", func(t *testing.T) {
|
||||||
test, err := NewTest(t, tst.loadString)
|
test, err := NewTest(t, tst.loadString)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer test.Close()
|
defer test.Close()
|
||||||
|
|
||||||
testutil.Ok(t, test.Run())
|
assert.NoError(t, test.Run())
|
||||||
engine := test.QueryEngine()
|
engine := test.QueryEngine()
|
||||||
for _, c := range tst.cases {
|
for _, c := range tst.cases {
|
||||||
t.Run(c.Query, func(t *testing.T) {
|
t.Run(c.Query, func(t *testing.T) {
|
||||||
qry, err := engine.NewInstantQuery(test.Queryable(), c.Query, c.Start)
|
qry, err := engine.NewInstantQuery(test.Queryable(), c.Query, c.Start)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
res := qry.Exec(test.Context())
|
res := qry.Exec(test.Context())
|
||||||
testutil.Equals(t, c.Result.Err, res.Err)
|
assert.Equal(t, c.Result.Err, res.Err)
|
||||||
mat := res.Value.(Matrix)
|
mat := res.Value.(Matrix)
|
||||||
sort.Sort(mat)
|
sort.Sort(mat)
|
||||||
testutil.Equals(t, c.Result.Value, mat)
|
assert.Equal(t, c.Result.Value, mat)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -1110,7 +1111,7 @@ func TestQueryLogger_basic(t *testing.T) {
|
||||||
return contextDone(ctx, "test statement execution")
|
return contextDone(ctx, "test statement execution")
|
||||||
})
|
})
|
||||||
res := query.Exec(ctx)
|
res := query.Exec(ctx)
|
||||||
testutil.Ok(t, res.Err)
|
assert.NoError(t, res.Err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Query works without query log initialized.
|
// Query works without query log initialized.
|
||||||
|
@ -1120,28 +1121,28 @@ func TestQueryLogger_basic(t *testing.T) {
|
||||||
engine.SetQueryLogger(f1)
|
engine.SetQueryLogger(f1)
|
||||||
queryExec()
|
queryExec()
|
||||||
for i, field := range []interface{}{"params", map[string]interface{}{"query": "test statement"}} {
|
for i, field := range []interface{}{"params", map[string]interface{}{"query": "test statement"}} {
|
||||||
testutil.Equals(t, field, f1.logs[i])
|
assert.Equal(t, field, f1.logs[i])
|
||||||
}
|
}
|
||||||
|
|
||||||
l := len(f1.logs)
|
l := len(f1.logs)
|
||||||
queryExec()
|
queryExec()
|
||||||
testutil.Equals(t, 2*l, len(f1.logs))
|
assert.Equal(t, 2*l, len(f1.logs))
|
||||||
|
|
||||||
// Test that we close the query logger when unsetting it.
|
// Test that we close the query logger when unsetting it.
|
||||||
testutil.Assert(t, !f1.closed, "expected f1 to be open, got closed")
|
assert.True(t, !f1.closed, "expected f1 to be open, got closed")
|
||||||
engine.SetQueryLogger(nil)
|
engine.SetQueryLogger(nil)
|
||||||
testutil.Assert(t, f1.closed, "expected f1 to be closed, got open")
|
assert.True(t, f1.closed, "expected f1 to be closed, got open")
|
||||||
queryExec()
|
queryExec()
|
||||||
|
|
||||||
// Test that we close the query logger when swapping.
|
// Test that we close the query logger when swapping.
|
||||||
f2 := NewFakeQueryLogger()
|
f2 := NewFakeQueryLogger()
|
||||||
f3 := NewFakeQueryLogger()
|
f3 := NewFakeQueryLogger()
|
||||||
engine.SetQueryLogger(f2)
|
engine.SetQueryLogger(f2)
|
||||||
testutil.Assert(t, !f2.closed, "expected f2 to be open, got closed")
|
assert.True(t, !f2.closed, "expected f2 to be open, got closed")
|
||||||
queryExec()
|
queryExec()
|
||||||
engine.SetQueryLogger(f3)
|
engine.SetQueryLogger(f3)
|
||||||
testutil.Assert(t, f2.closed, "expected f2 to be closed, got open")
|
assert.True(t, f2.closed, "expected f2 to be closed, got open")
|
||||||
testutil.Assert(t, !f3.closed, "expected f3 to be open, got closed")
|
assert.True(t, !f3.closed, "expected f3 to be open, got closed")
|
||||||
queryExec()
|
queryExec()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1165,12 +1166,12 @@ func TestQueryLogger_fields(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
res := query.Exec(ctx)
|
res := query.Exec(ctx)
|
||||||
testutil.Ok(t, res.Err)
|
assert.NoError(t, res.Err)
|
||||||
|
|
||||||
expected := []string{"foo", "bar"}
|
expected := []string{"foo", "bar"}
|
||||||
for i, field := range expected {
|
for i, field := range expected {
|
||||||
v := f1.logs[len(f1.logs)-len(expected)+i].(string)
|
v := f1.logs[len(f1.logs)-len(expected)+i].(string)
|
||||||
testutil.Equals(t, field, v)
|
assert.Equal(t, field, v)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1195,9 +1196,9 @@ func TestQueryLogger_error(t *testing.T) {
|
||||||
})
|
})
|
||||||
|
|
||||||
res := query.Exec(ctx)
|
res := query.Exec(ctx)
|
||||||
testutil.NotOk(t, res.Err, "query should have failed")
|
assert.Error(t, res.Err, "query should have failed")
|
||||||
|
|
||||||
for i, field := range []interface{}{"params", map[string]interface{}{"query": "test statement"}, "error", testErr} {
|
for i, field := range []interface{}{"params", map[string]interface{}{"query": "test statement"}, "error", testErr} {
|
||||||
testutil.Equals(t, f1.logs[i], field)
|
assert.Equal(t, f1.logs[i], field)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,11 +19,12 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/timestamp"
|
"github.com/prometheus/prometheus/pkg/timestamp"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/util/teststorage"
|
"github.com/prometheus/prometheus/util/teststorage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDeriv(t *testing.T) {
|
func TestDeriv(t *testing.T) {
|
||||||
|
@ -46,28 +47,28 @@ func TestDeriv(t *testing.T) {
|
||||||
a.Add(metric, 1493712816939, 1.0)
|
a.Add(metric, 1493712816939, 1.0)
|
||||||
a.Add(metric, 1493712846939, 1.0)
|
a.Add(metric, 1493712846939, 1.0)
|
||||||
|
|
||||||
testutil.Ok(t, a.Commit())
|
assert.NoError(t, a.Commit())
|
||||||
|
|
||||||
query, err := engine.NewInstantQuery(storage, "deriv(foo[30m])", timestamp.Time(1493712846939))
|
query, err := engine.NewInstantQuery(storage, "deriv(foo[30m])", timestamp.Time(1493712846939))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
result := query.Exec(context.Background())
|
result := query.Exec(context.Background())
|
||||||
testutil.Ok(t, result.Err)
|
assert.NoError(t, result.Err)
|
||||||
|
|
||||||
vec, _ := result.Vector()
|
vec, _ := result.Vector()
|
||||||
testutil.Assert(t, len(vec) == 1, "Expected 1 result, got %d", len(vec))
|
assert.True(t, len(vec) == 1, "Expected 1 result, got %d", len(vec))
|
||||||
testutil.Assert(t, vec[0].V == 0.0, "Expected 0.0 as value, got %f", vec[0].V)
|
assert.True(t, vec[0].V == 0.0, "Expected 0.0 as value, got %f", vec[0].V)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFunctionList(t *testing.T) {
|
func TestFunctionList(t *testing.T) {
|
||||||
// Test that Functions and parser.Functions list the same functions.
|
// Test that Functions and parser.Functions list the same functions.
|
||||||
for i := range FunctionCalls {
|
for i := range FunctionCalls {
|
||||||
_, ok := parser.Functions[i]
|
_, ok := parser.Functions[i]
|
||||||
testutil.Assert(t, ok, fmt.Sprintf("function %s exists in promql package, but not in parser package", i))
|
assert.True(t, ok, fmt.Sprintf("function %s exists in promql package, but not in parser package", i))
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := range parser.Functions {
|
for i := range parser.Functions {
|
||||||
_, ok := FunctionCalls[i]
|
_, ok := FunctionCalls[i]
|
||||||
testutil.Assert(t, ok, (fmt.Sprintf("function %s exists in parser package, but not in promql package", i)))
|
assert.True(t, ok, (fmt.Sprintf("function %s exists in parser package, but not in promql package", i)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,11 +3,8 @@
|
||||||
//line generated_parser.y:15
|
//line generated_parser.y:15
|
||||||
package parser
|
package parser
|
||||||
|
|
||||||
import __yyfmt__ "fmt"
|
|
||||||
|
|
||||||
//line generated_parser.y:15
|
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
__yyfmt__ "fmt"
|
||||||
"math"
|
"math"
|
||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
@ -15,7 +12,7 @@ import (
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/value"
|
"github.com/prometheus/prometheus/pkg/value"
|
||||||
)
|
) //line generated_parser.y:15
|
||||||
|
|
||||||
//line generated_parser.y:28
|
//line generated_parser.y:28
|
||||||
type yySymType struct {
|
type yySymType struct {
|
||||||
|
|
|
@ -16,7 +16,7 @@ package parser
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type testCase struct {
|
type testCase struct {
|
||||||
|
@ -731,10 +731,10 @@ func TestLexer(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
eofItem := Item{EOF, Pos(len(test.input)), ""}
|
eofItem := Item{EOF, Pos(len(test.input)), ""}
|
||||||
testutil.Equals(t, lastItem, eofItem, "%d: input %q", i, test.input)
|
assert.Equal(t, lastItem, eofItem, "%d: input %q", i, test.input)
|
||||||
|
|
||||||
out = out[:len(out)-1]
|
out = out[:len(out)-1]
|
||||||
testutil.Equals(t, test.expected, out, "%d: input %q", i, test.input)
|
assert.Equal(t, test.expected, out, "%d: input %q", i, test.input)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,9 +21,9 @@ import (
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var testExpr = []struct {
|
var testExpr = []struct {
|
||||||
|
@ -2659,23 +2659,23 @@ func TestParseExpressions(t *testing.T) {
|
||||||
expr, err := ParseExpr(test.input)
|
expr, err := ParseExpr(test.input)
|
||||||
|
|
||||||
// Unexpected errors are always caused by a bug.
|
// Unexpected errors are always caused by a bug.
|
||||||
testutil.Assert(t, err != errUnexpected, "unexpected error occurred")
|
assert.True(t, err != errUnexpected, "unexpected error occurred")
|
||||||
|
|
||||||
if !test.fail {
|
if !test.fail {
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, test.expected, expr, "error on input '%s'", test.input)
|
assert.Equal(t, test.expected, expr, "error on input '%s'", test.input)
|
||||||
} else {
|
} else {
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Assert(t, strings.Contains(err.Error(), test.errMsg), "unexpected error on input '%s', expected '%s', got '%s'", test.input, test.errMsg, err.Error())
|
assert.True(t, strings.Contains(err.Error(), test.errMsg), "unexpected error on input '%s', expected '%s', got '%s'", test.input, test.errMsg, err.Error())
|
||||||
|
|
||||||
errorList, ok := err.(ParseErrors)
|
errorList, ok := err.(ParseErrors)
|
||||||
|
|
||||||
testutil.Assert(t, ok, "unexpected error type")
|
assert.True(t, ok, "unexpected error type")
|
||||||
|
|
||||||
for _, e := range errorList {
|
for _, e := range errorList {
|
||||||
testutil.Assert(t, 0 <= e.PositionRange.Start, "parse error has negative position\nExpression '%s'\nError: %v", test.input, e)
|
assert.True(t, 0 <= e.PositionRange.Start, "parse error has negative position\nExpression '%s'\nError: %v", test.input, e)
|
||||||
testutil.Assert(t, e.PositionRange.Start <= e.PositionRange.End, "parse error has negative length\nExpression '%s'\nError: %v", test.input, e)
|
assert.True(t, e.PositionRange.Start <= e.PositionRange.End, "parse error has negative length\nExpression '%s'\nError: %v", test.input, e)
|
||||||
testutil.Assert(t, e.PositionRange.End <= Pos(len(test.input)), "parse error is not contained in input\nExpression '%s'\nError: %v", test.input, e)
|
assert.True(t, e.PositionRange.End <= Pos(len(test.input)), "parse error is not contained in input\nExpression '%s'\nError: %v", test.input, e)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -2685,11 +2685,11 @@ func TestParseExpressions(t *testing.T) {
|
||||||
// NaN has no equality. Thus, we need a separate test for it.
|
// NaN has no equality. Thus, we need a separate test for it.
|
||||||
func TestNaNExpression(t *testing.T) {
|
func TestNaNExpression(t *testing.T) {
|
||||||
expr, err := ParseExpr("NaN")
|
expr, err := ParseExpr("NaN")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
nl, ok := expr.(*NumberLiteral)
|
nl, ok := expr.(*NumberLiteral)
|
||||||
testutil.Assert(t, ok, "expected number literal but got %T", expr)
|
assert.True(t, ok, "expected number literal but got %T", expr)
|
||||||
testutil.Assert(t, math.IsNaN(float64(nl.Val)), "expected 'NaN' in number literal but got %v", nl.Val)
|
assert.True(t, math.IsNaN(float64(nl.Val)), "expected 'NaN' in number literal but got %v", nl.Val)
|
||||||
}
|
}
|
||||||
|
|
||||||
func mustLabelMatcher(mt labels.MatchType, name, val string) *labels.Matcher {
|
func mustLabelMatcher(mt labels.MatchType, name, val string) *labels.Matcher {
|
||||||
|
@ -2804,14 +2804,14 @@ func TestParseSeries(t *testing.T) {
|
||||||
metric, vals, err := ParseSeriesDesc(test.input)
|
metric, vals, err := ParseSeriesDesc(test.input)
|
||||||
|
|
||||||
// Unexpected errors are always caused by a bug.
|
// Unexpected errors are always caused by a bug.
|
||||||
testutil.Assert(t, err != errUnexpected, "unexpected error occurred")
|
assert.True(t, err != errUnexpected, "unexpected error occurred")
|
||||||
|
|
||||||
if !test.fail {
|
if !test.fail {
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, test.expectedMetric, metric, "error on input '%s'", test.input)
|
assert.Equal(t, test.expectedMetric, metric, "error on input '%s'", test.input)
|
||||||
testutil.Equals(t, test.expectedValues, vals, "error in input '%s'", test.input)
|
assert.Equal(t, test.expectedValues, vals, "error in input '%s'", test.input)
|
||||||
} else {
|
} else {
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2821,7 +2821,7 @@ func TestRecoverParserRuntime(t *testing.T) {
|
||||||
var err error
|
var err error
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Equals(t, errUnexpected, err)
|
assert.Equal(t, errUnexpected, err)
|
||||||
}()
|
}()
|
||||||
defer p.recover(&err)
|
defer p.recover(&err)
|
||||||
// Cause a runtime panic.
|
// Cause a runtime panic.
|
||||||
|
@ -2837,7 +2837,7 @@ func TestRecoverParserError(t *testing.T) {
|
||||||
e := errors.New("custom error")
|
e := errors.New("custom error")
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Equals(t, e.Error(), err.Error())
|
assert.Equal(t, e.Error(), err.Error())
|
||||||
}()
|
}()
|
||||||
defer p.recover(&err)
|
defer p.recover(&err)
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@ package parser
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestExprString(t *testing.T) {
|
func TestExprString(t *testing.T) {
|
||||||
|
@ -102,13 +102,13 @@ func TestExprString(t *testing.T) {
|
||||||
|
|
||||||
for _, test := range inputs {
|
for _, test := range inputs {
|
||||||
expr, err := ParseExpr(test.in)
|
expr, err := ParseExpr(test.in)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
exp := test.in
|
exp := test.in
|
||||||
if test.out != "" {
|
if test.out != "" {
|
||||||
exp = test.out
|
exp = test.out
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, exp, expr.String())
|
assert.Equal(t, exp, expr.String())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,18 +17,18 @@ import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestEvaluations(t *testing.T) {
|
func TestEvaluations(t *testing.T) {
|
||||||
files, err := filepath.Glob("testdata/*.test")
|
files, err := filepath.Glob("testdata/*.test")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
for _, fn := range files {
|
for _, fn := range files {
|
||||||
t.Run(fn, func(t *testing.T) {
|
t.Run(fn, func(t *testing.T) {
|
||||||
test, err := newTestFromFile(t, fn)
|
test, err := newTestFromFile(t, fn)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, test.Run())
|
assert.NoError(t, test.Run())
|
||||||
|
|
||||||
test.Close()
|
test.Close()
|
||||||
})
|
})
|
||||||
|
|
|
@ -20,7 +20,7 @@ import (
|
||||||
"regexp"
|
"regexp"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestQueryLogging(t *testing.T) {
|
func TestQueryLogging(t *testing.T) {
|
||||||
|
@ -109,18 +109,18 @@ func TestIndexReuse(t *testing.T) {
|
||||||
|
|
||||||
func TestMMapFile(t *testing.T) {
|
func TestMMapFile(t *testing.T) {
|
||||||
file, err := ioutil.TempFile("", "mmapedFile")
|
file, err := ioutil.TempFile("", "mmapedFile")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
filename := file.Name()
|
filename := file.Name()
|
||||||
defer os.Remove(filename)
|
defer os.Remove(filename)
|
||||||
|
|
||||||
fileAsBytes, err := getMMapedFile(filename, 2, nil)
|
fileAsBytes, err := getMMapedFile(filename, 2, nil)
|
||||||
|
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
copy(fileAsBytes, "ab")
|
copy(fileAsBytes, "ab")
|
||||||
|
|
||||||
f, err := os.Open(filename)
|
f, err := os.Open(filename)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
bytes := make([]byte, 4)
|
bytes := make([]byte, 4)
|
||||||
n, err := f.Read(bytes)
|
n, err := f.Read(bytes)
|
||||||
|
|
|
@ -25,6 +25,7 @@ import (
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
|
|
|
@ -18,9 +18,9 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestLazyLoader_WithSamplesTill(t *testing.T) {
|
func TestLazyLoader_WithSamplesTill(t *testing.T) {
|
||||||
|
@ -110,12 +110,12 @@ func TestLazyLoader_WithSamplesTill(t *testing.T) {
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
suite, err := NewLazyLoader(t, c.loadString)
|
suite, err := NewLazyLoader(t, c.loadString)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
for _, tc := range c.testCases {
|
for _, tc := range c.testCases {
|
||||||
suite.WithSamplesTill(tc.ts, func(err error) {
|
suite.WithSamplesTill(tc.ts, func(err error) {
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
if tc.checkOnlyError {
|
if tc.checkOnlyError {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -123,20 +123,20 @@ func TestLazyLoader_WithSamplesTill(t *testing.T) {
|
||||||
// Check the series.
|
// Check the series.
|
||||||
queryable := suite.Queryable()
|
queryable := suite.Queryable()
|
||||||
querier, err := queryable.Querier(suite.Context(), math.MinInt64, math.MaxInt64)
|
querier, err := queryable.Querier(suite.Context(), math.MinInt64, math.MaxInt64)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
for _, s := range tc.series {
|
for _, s := range tc.series {
|
||||||
var matchers []*labels.Matcher
|
var matchers []*labels.Matcher
|
||||||
for _, label := range s.Metric {
|
for _, label := range s.Metric {
|
||||||
m, err := labels.NewMatcher(labels.MatchEqual, label.Name, label.Value)
|
m, err := labels.NewMatcher(labels.MatchEqual, label.Name, label.Value)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
matchers = append(matchers, m)
|
matchers = append(matchers, m)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the series for the matcher.
|
// Get the series for the matcher.
|
||||||
ss := querier.Select(false, nil, matchers...)
|
ss := querier.Select(false, nil, matchers...)
|
||||||
testutil.Assert(t, ss.Next(), "")
|
assert.True(t, ss.Next(), "")
|
||||||
storageSeries := ss.At()
|
storageSeries := ss.At()
|
||||||
testutil.Assert(t, !ss.Next(), "Expecting only 1 series")
|
assert.True(t, !ss.Next(), "Expecting only 1 series")
|
||||||
|
|
||||||
// Convert `storage.Series` to `promql.Series`.
|
// Convert `storage.Series` to `promql.Series`.
|
||||||
got := Series{
|
got := Series{
|
||||||
|
@ -147,9 +147,9 @@ func TestLazyLoader_WithSamplesTill(t *testing.T) {
|
||||||
t, v := it.At()
|
t, v := it.At()
|
||||||
got.Points = append(got.Points, Point{T: t, V: v})
|
got.Points = append(got.Points, Point{T: t, V: v})
|
||||||
}
|
}
|
||||||
testutil.Ok(t, it.Err())
|
assert.NoError(t, it.Err())
|
||||||
|
|
||||||
testutil.Equals(t, s, got)
|
assert.Equal(t, s, got)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,11 +21,10 @@ import (
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
|
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (Matrix) Type() parser.ValueType { return parser.ValueTypeMatrix }
|
func (Matrix) Type() parser.ValueType { return parser.ValueTypeMatrix }
|
||||||
|
|
|
@ -16,19 +16,17 @@ package rules
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
html_template "html/template"
|
||||||
"net/url"
|
"net/url"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
html_template "html/template"
|
|
||||||
|
|
||||||
yaml "gopkg.in/yaml.v2"
|
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
yaml "gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/rulefmt"
|
"github.com/prometheus/prometheus/pkg/rulefmt"
|
||||||
|
|
|
@ -15,22 +15,22 @@ package rules
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/timestamp"
|
"github.com/prometheus/prometheus/pkg/timestamp"
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/util/teststorage"
|
"github.com/prometheus/prometheus/util/teststorage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestAlertingRuleHTMLSnippet(t *testing.T) {
|
func TestAlertingRuleHTMLSnippet(t *testing.T) {
|
||||||
expr, err := parser.ParseExpr(`foo{html="<b>BOLD<b>"}`)
|
expr, err := parser.ParseExpr(`foo{html="<b>BOLD<b>"}`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
rule := NewAlertingRule("testrule", expr, 0, labels.FromStrings("html", "<b>BOLD</b>"), labels.FromStrings("html", "<b>BOLD</b>"), nil, false, nil)
|
rule := NewAlertingRule("testrule", expr, 0, labels.FromStrings("html", "<b>BOLD</b>"), labels.FromStrings("html", "<b>BOLD</b>"), nil, false, nil)
|
||||||
|
|
||||||
const want = `alert: <a href="/test/prefix/graph?g0.expr=ALERTS%7Balertname%3D%22testrule%22%7D&g0.tab=1">testrule</a>
|
const want = `alert: <a href="/test/prefix/graph?g0.expr=ALERTS%7Balertname%3D%22testrule%22%7D&g0.tab=1">testrule</a>
|
||||||
|
@ -42,7 +42,7 @@ annotations:
|
||||||
`
|
`
|
||||||
|
|
||||||
got := rule.HTMLSnippet("/test/prefix")
|
got := rule.HTMLSnippet("/test/prefix")
|
||||||
testutil.Assert(t, want == got, "incorrect HTML snippet; want:\n\n|%v|\n\ngot:\n\n|%v|", want, got)
|
assert.True(t, want == got, "incorrect HTML snippet; want:\n\n|%v|\n\ngot:\n\n|%v|", want, got)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAlertingRuleState(t *testing.T) {
|
func TestAlertingRuleState(t *testing.T) {
|
||||||
|
@ -81,7 +81,7 @@ func TestAlertingRuleState(t *testing.T) {
|
||||||
rule := NewAlertingRule(test.name, nil, 0, nil, nil, nil, true, nil)
|
rule := NewAlertingRule(test.name, nil, 0, nil, nil, nil, true, nil)
|
||||||
rule.active = test.active
|
rule.active = test.active
|
||||||
got := rule.State()
|
got := rule.State()
|
||||||
testutil.Assert(t, test.want == got, "test case %d unexpected AlertState, want:%d got:%d", i, test.want, got)
|
assert.True(t, test.want == got, "test case %d unexpected AlertState, want:%d got:%d", i, test.want, got)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,13 +90,13 @@ func TestAlertingRuleLabelsUpdate(t *testing.T) {
|
||||||
load 1m
|
load 1m
|
||||||
http_requests{job="app-server", instance="0"} 75 85 70 70
|
http_requests{job="app-server", instance="0"} 75 85 70 70
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
testutil.Ok(t, suite.Run())
|
assert.NoError(t, suite.Run())
|
||||||
|
|
||||||
expr, err := parser.ParseExpr(`http_requests < 100`)
|
expr, err := parser.ParseExpr(`http_requests < 100`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
rule := NewAlertingRule(
|
rule := NewAlertingRule(
|
||||||
"HTTPRequestRateLow",
|
"HTTPRequestRateLow",
|
||||||
|
@ -170,7 +170,7 @@ func TestAlertingRuleLabelsUpdate(t *testing.T) {
|
||||||
evalTime := baseTime.Add(time.Duration(i) * time.Minute)
|
evalTime := baseTime.Add(time.Duration(i) * time.Minute)
|
||||||
result[0].Point.T = timestamp.FromTime(evalTime)
|
result[0].Point.T = timestamp.FromTime(evalTime)
|
||||||
res, err := rule.Eval(suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil)
|
res, err := rule.Eval(suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
var filteredRes promql.Vector // After removing 'ALERTS_FOR_STATE' samples.
|
var filteredRes promql.Vector // After removing 'ALERTS_FOR_STATE' samples.
|
||||||
for _, smpl := range res {
|
for _, smpl := range res {
|
||||||
|
@ -179,11 +179,11 @@ func TestAlertingRuleLabelsUpdate(t *testing.T) {
|
||||||
filteredRes = append(filteredRes, smpl)
|
filteredRes = append(filteredRes, smpl)
|
||||||
} else {
|
} else {
|
||||||
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
||||||
testutil.Equals(t, "ALERTS_FOR_STATE", smplName)
|
assert.Equal(t, "ALERTS_FOR_STATE", smplName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, result, filteredRes)
|
assert.Equal(t, result, filteredRes)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -192,13 +192,13 @@ func TestAlertingRuleExternalLabelsInTemplate(t *testing.T) {
|
||||||
load 1m
|
load 1m
|
||||||
http_requests{job="app-server", instance="0"} 75 85 70 70
|
http_requests{job="app-server", instance="0"} 75 85 70 70
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
testutil.Ok(t, suite.Run())
|
assert.NoError(t, suite.Run())
|
||||||
|
|
||||||
expr, err := parser.ParseExpr(`http_requests < 100`)
|
expr, err := parser.ParseExpr(`http_requests < 100`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ruleWithoutExternalLabels := NewAlertingRule(
|
ruleWithoutExternalLabels := NewAlertingRule(
|
||||||
"ExternalLabelDoesNotExist",
|
"ExternalLabelDoesNotExist",
|
||||||
|
@ -251,32 +251,32 @@ func TestAlertingRuleExternalLabelsInTemplate(t *testing.T) {
|
||||||
res, err := ruleWithoutExternalLabels.Eval(
|
res, err := ruleWithoutExternalLabels.Eval(
|
||||||
suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil,
|
suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil,
|
||||||
)
|
)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
for _, smpl := range res {
|
for _, smpl := range res {
|
||||||
smplName := smpl.Metric.Get("__name__")
|
smplName := smpl.Metric.Get("__name__")
|
||||||
if smplName == "ALERTS" {
|
if smplName == "ALERTS" {
|
||||||
filteredRes = append(filteredRes, smpl)
|
filteredRes = append(filteredRes, smpl)
|
||||||
} else {
|
} else {
|
||||||
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
||||||
testutil.Equals(t, "ALERTS_FOR_STATE", smplName)
|
assert.Equal(t, "ALERTS_FOR_STATE", smplName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
res, err = ruleWithExternalLabels.Eval(
|
res, err = ruleWithExternalLabels.Eval(
|
||||||
suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil,
|
suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil,
|
||||||
)
|
)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
for _, smpl := range res {
|
for _, smpl := range res {
|
||||||
smplName := smpl.Metric.Get("__name__")
|
smplName := smpl.Metric.Get("__name__")
|
||||||
if smplName == "ALERTS" {
|
if smplName == "ALERTS" {
|
||||||
filteredRes = append(filteredRes, smpl)
|
filteredRes = append(filteredRes, smpl)
|
||||||
} else {
|
} else {
|
||||||
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
||||||
testutil.Equals(t, "ALERTS_FOR_STATE", smplName)
|
assert.Equal(t, "ALERTS_FOR_STATE", smplName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, result, filteredRes)
|
assert.Equal(t, result, filteredRes)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAlertingRuleEmptyLabelFromTemplate(t *testing.T) {
|
func TestAlertingRuleEmptyLabelFromTemplate(t *testing.T) {
|
||||||
|
@ -284,13 +284,13 @@ func TestAlertingRuleEmptyLabelFromTemplate(t *testing.T) {
|
||||||
load 1m
|
load 1m
|
||||||
http_requests{job="app-server", instance="0"} 75 85 70 70
|
http_requests{job="app-server", instance="0"} 75 85 70 70
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
testutil.Ok(t, suite.Run())
|
assert.NoError(t, suite.Run())
|
||||||
|
|
||||||
expr, err := parser.ParseExpr(`http_requests < 100`)
|
expr, err := parser.ParseExpr(`http_requests < 100`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
rule := NewAlertingRule(
|
rule := NewAlertingRule(
|
||||||
"EmptyLabel",
|
"EmptyLabel",
|
||||||
|
@ -321,17 +321,17 @@ func TestAlertingRuleEmptyLabelFromTemplate(t *testing.T) {
|
||||||
res, err := rule.Eval(
|
res, err := rule.Eval(
|
||||||
suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil,
|
suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil,
|
||||||
)
|
)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
for _, smpl := range res {
|
for _, smpl := range res {
|
||||||
smplName := smpl.Metric.Get("__name__")
|
smplName := smpl.Metric.Get("__name__")
|
||||||
if smplName == "ALERTS" {
|
if smplName == "ALERTS" {
|
||||||
filteredRes = append(filteredRes, smpl)
|
filteredRes = append(filteredRes, smpl)
|
||||||
} else {
|
} else {
|
||||||
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
||||||
testutil.Equals(t, "ALERTS_FOR_STATE", smplName)
|
assert.Equal(t, "ALERTS_FOR_STATE", smplName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
testutil.Equals(t, result, filteredRes)
|
assert.Equal(t, result, filteredRes)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAlertingRuleDuplicate(t *testing.T) {
|
func TestAlertingRuleDuplicate(t *testing.T) {
|
||||||
|
@ -362,7 +362,6 @@ func TestAlertingRuleDuplicate(t *testing.T) {
|
||||||
true, log.NewNopLogger(),
|
true, log.NewNopLogger(),
|
||||||
)
|
)
|
||||||
_, err := rule.Eval(ctx, now, EngineQueryFunc(engine, storage), nil)
|
_, err := rule.Eval(ctx, now, EngineQueryFunc(engine, storage), nil)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
e := fmt.Errorf("vector contains metrics with the same labelset after applying alert labels")
|
assert.EqualError(t, err, "vector contains metrics with the same labelset after applying alert labels")
|
||||||
testutil.ErrorEqual(t, e, err)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
"go.uber.org/goleak"
|
"go.uber.org/goleak"
|
||||||
yaml "gopkg.in/yaml.v2"
|
yaml "gopkg.in/yaml.v2"
|
||||||
|
|
||||||
|
@ -37,7 +38,6 @@ import (
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/util/teststorage"
|
"github.com/prometheus/prometheus/util/teststorage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMain(m *testing.M) {
|
func TestMain(m *testing.M) {
|
||||||
|
@ -50,14 +50,14 @@ func TestAlertingRule(t *testing.T) {
|
||||||
http_requests{job="app-server", instance="0", group="canary", severity="overwrite-me"} 75 85 95 105 105 95 85
|
http_requests{job="app-server", instance="0", group="canary", severity="overwrite-me"} 75 85 95 105 105 95 85
|
||||||
http_requests{job="app-server", instance="1", group="canary", severity="overwrite-me"} 80 90 100 110 120 130 140
|
http_requests{job="app-server", instance="1", group="canary", severity="overwrite-me"} 80 90 100 110 120 130 140
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
err = suite.Run()
|
err = suite.Run()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
expr, err := parser.ParseExpr(`http_requests{group="canary", job="app-server"} < 100`)
|
expr, err := parser.ParseExpr(`http_requests{group="canary", job="app-server"} < 100`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
rule := NewAlertingRule(
|
rule := NewAlertingRule(
|
||||||
"HTTPRequestRateLow",
|
"HTTPRequestRateLow",
|
||||||
|
@ -157,7 +157,7 @@ func TestAlertingRule(t *testing.T) {
|
||||||
evalTime := baseTime.Add(test.time)
|
evalTime := baseTime.Add(test.time)
|
||||||
|
|
||||||
res, err := rule.Eval(suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil)
|
res, err := rule.Eval(suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
var filteredRes promql.Vector // After removing 'ALERTS_FOR_STATE' samples.
|
var filteredRes promql.Vector // After removing 'ALERTS_FOR_STATE' samples.
|
||||||
for _, smpl := range res {
|
for _, smpl := range res {
|
||||||
|
@ -166,21 +166,21 @@ func TestAlertingRule(t *testing.T) {
|
||||||
filteredRes = append(filteredRes, smpl)
|
filteredRes = append(filteredRes, smpl)
|
||||||
} else {
|
} else {
|
||||||
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
// If not 'ALERTS', it has to be 'ALERTS_FOR_STATE'.
|
||||||
testutil.Equals(t, smplName, "ALERTS_FOR_STATE")
|
assert.Equal(t, smplName, "ALERTS_FOR_STATE")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for i := range test.result {
|
for i := range test.result {
|
||||||
test.result[i].T = timestamp.FromTime(evalTime)
|
test.result[i].T = timestamp.FromTime(evalTime)
|
||||||
}
|
}
|
||||||
testutil.Assert(t, len(test.result) == len(filteredRes), "%d. Number of samples in expected and actual output don't match (%d vs. %d)", i, len(test.result), len(res))
|
assert.True(t, len(test.result) == len(filteredRes), "%d. Number of samples in expected and actual output don't match (%d vs. %d)", i, len(test.result), len(res))
|
||||||
|
|
||||||
sort.Slice(filteredRes, func(i, j int) bool {
|
sort.Slice(filteredRes, func(i, j int) bool {
|
||||||
return labels.Compare(filteredRes[i].Metric, filteredRes[j].Metric) < 0
|
return labels.Compare(filteredRes[i].Metric, filteredRes[j].Metric) < 0
|
||||||
})
|
})
|
||||||
testutil.Equals(t, test.result, filteredRes)
|
assert.Equal(t, test.result, filteredRes)
|
||||||
|
|
||||||
for _, aa := range rule.ActiveAlerts() {
|
for _, aa := range rule.ActiveAlerts() {
|
||||||
testutil.Assert(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
assert.True(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -191,14 +191,14 @@ func TestForStateAddSamples(t *testing.T) {
|
||||||
http_requests{job="app-server", instance="0", group="canary", severity="overwrite-me"} 75 85 95 105 105 95 85
|
http_requests{job="app-server", instance="0", group="canary", severity="overwrite-me"} 75 85 95 105 105 95 85
|
||||||
http_requests{job="app-server", instance="1", group="canary", severity="overwrite-me"} 80 90 100 110 120 130 140
|
http_requests{job="app-server", instance="1", group="canary", severity="overwrite-me"} 80 90 100 110 120 130 140
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
err = suite.Run()
|
err = suite.Run()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
expr, err := parser.ParseExpr(`http_requests{group="canary", job="app-server"} < 100`)
|
expr, err := parser.ParseExpr(`http_requests{group="canary", job="app-server"} < 100`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
rule := NewAlertingRule(
|
rule := NewAlertingRule(
|
||||||
"HTTPRequestRateLow",
|
"HTTPRequestRateLow",
|
||||||
|
@ -306,7 +306,7 @@ func TestForStateAddSamples(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
res, err := rule.Eval(suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil)
|
res, err := rule.Eval(suite.Context(), evalTime, EngineQueryFunc(suite.QueryEngine(), suite.Storage()), nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
var filteredRes promql.Vector // After removing 'ALERTS' samples.
|
var filteredRes promql.Vector // After removing 'ALERTS' samples.
|
||||||
for _, smpl := range res {
|
for _, smpl := range res {
|
||||||
|
@ -315,7 +315,7 @@ func TestForStateAddSamples(t *testing.T) {
|
||||||
filteredRes = append(filteredRes, smpl)
|
filteredRes = append(filteredRes, smpl)
|
||||||
} else {
|
} else {
|
||||||
// If not 'ALERTS_FOR_STATE', it has to be 'ALERTS'.
|
// If not 'ALERTS_FOR_STATE', it has to be 'ALERTS'.
|
||||||
testutil.Equals(t, smplName, "ALERTS")
|
assert.Equal(t, smplName, "ALERTS")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for i := range test.result {
|
for i := range test.result {
|
||||||
|
@ -325,15 +325,15 @@ func TestForStateAddSamples(t *testing.T) {
|
||||||
test.result[i].V = forState
|
test.result[i].V = forState
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
testutil.Assert(t, len(test.result) == len(filteredRes), "%d. Number of samples in expected and actual output don't match (%d vs. %d)", i, len(test.result), len(res))
|
assert.True(t, len(test.result) == len(filteredRes), "%d. Number of samples in expected and actual output don't match (%d vs. %d)", i, len(test.result), len(res))
|
||||||
|
|
||||||
sort.Slice(filteredRes, func(i, j int) bool {
|
sort.Slice(filteredRes, func(i, j int) bool {
|
||||||
return labels.Compare(filteredRes[i].Metric, filteredRes[j].Metric) < 0
|
return labels.Compare(filteredRes[i].Metric, filteredRes[j].Metric) < 0
|
||||||
})
|
})
|
||||||
testutil.Equals(t, test.result, filteredRes)
|
assert.Equal(t, test.result, filteredRes)
|
||||||
|
|
||||||
for _, aa := range rule.ActiveAlerts() {
|
for _, aa := range rule.ActiveAlerts() {
|
||||||
testutil.Assert(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
assert.True(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -352,14 +352,14 @@ func TestForStateRestore(t *testing.T) {
|
||||||
http_requests{job="app-server", instance="0", group="canary", severity="overwrite-me"} 75 85 50 0 0 25 0 0 40 0 120
|
http_requests{job="app-server", instance="0", group="canary", severity="overwrite-me"} 75 85 50 0 0 25 0 0 40 0 120
|
||||||
http_requests{job="app-server", instance="1", group="canary", severity="overwrite-me"} 125 90 60 0 0 25 0 0 40 0 130
|
http_requests{job="app-server", instance="1", group="canary", severity="overwrite-me"} 125 90 60 0 0 25 0 0 40 0 130
|
||||||
`)
|
`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer suite.Close()
|
defer suite.Close()
|
||||||
|
|
||||||
err = suite.Run()
|
err = suite.Run()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
expr, err := parser.ParseExpr(`http_requests{group="canary", job="app-server"} < 100`)
|
expr, err := parser.ParseExpr(`http_requests{group="canary", job="app-server"} < 100`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
opts := &ManagerOptions{
|
opts := &ManagerOptions{
|
||||||
QueryFunc: EngineQueryFunc(suite.QueryEngine(), suite.Storage()),
|
QueryFunc: EngineQueryFunc(suite.QueryEngine(), suite.Storage()),
|
||||||
|
@ -402,7 +402,7 @@ func TestForStateRestore(t *testing.T) {
|
||||||
|
|
||||||
exp := rule.ActiveAlerts()
|
exp := rule.ActiveAlerts()
|
||||||
for _, aa := range exp {
|
for _, aa := range exp {
|
||||||
testutil.Assert(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
assert.True(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
||||||
}
|
}
|
||||||
sort.Slice(exp, func(i, j int) bool {
|
sort.Slice(exp, func(i, j int) bool {
|
||||||
return labels.Compare(exp[i].Labels, exp[j].Labels) < 0
|
return labels.Compare(exp[i].Labels, exp[j].Labels) < 0
|
||||||
|
@ -466,7 +466,7 @@ func TestForStateRestore(t *testing.T) {
|
||||||
|
|
||||||
got := newRule.ActiveAlerts()
|
got := newRule.ActiveAlerts()
|
||||||
for _, aa := range got {
|
for _, aa := range got {
|
||||||
testutil.Assert(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
assert.True(t, aa.Labels.Get(model.MetricNameLabel) == "", "%s label set on active alert: %s", model.MetricNameLabel, aa.Labels)
|
||||||
}
|
}
|
||||||
sort.Slice(got, func(i, j int) bool {
|
sort.Slice(got, func(i, j int) bool {
|
||||||
return labels.Compare(got[i].Labels, got[j].Labels) < 0
|
return labels.Compare(got[i].Labels, got[j].Labels) < 0
|
||||||
|
@ -474,27 +474,27 @@ func TestForStateRestore(t *testing.T) {
|
||||||
|
|
||||||
// Checking if we have restored it correctly.
|
// Checking if we have restored it correctly.
|
||||||
if tst.noRestore {
|
if tst.noRestore {
|
||||||
testutil.Equals(t, tst.num, len(got))
|
assert.Equal(t, tst.num, len(got))
|
||||||
for _, e := range got {
|
for _, e := range got {
|
||||||
testutil.Equals(t, e.ActiveAt, restoreTime)
|
assert.Equal(t, e.ActiveAt, restoreTime)
|
||||||
}
|
}
|
||||||
} else if tst.gracePeriod {
|
} else if tst.gracePeriod {
|
||||||
testutil.Equals(t, tst.num, len(got))
|
assert.Equal(t, tst.num, len(got))
|
||||||
for _, e := range got {
|
for _, e := range got {
|
||||||
testutil.Equals(t, opts.ForGracePeriod, e.ActiveAt.Add(alertForDuration).Sub(restoreTime))
|
assert.Equal(t, opts.ForGracePeriod, e.ActiveAt.Add(alertForDuration).Sub(restoreTime))
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
exp := tst.alerts
|
exp := tst.alerts
|
||||||
testutil.Equals(t, len(exp), len(got))
|
assert.Equal(t, len(exp), len(got))
|
||||||
sortAlerts(exp)
|
sortAlerts(exp)
|
||||||
sortAlerts(got)
|
sortAlerts(got)
|
||||||
for i, e := range exp {
|
for i, e := range exp {
|
||||||
testutil.Equals(t, e.Labels, got[i].Labels)
|
assert.Equal(t, e.Labels, got[i].Labels)
|
||||||
|
|
||||||
// Difference in time should be within 1e6 ns, i.e. 1ms
|
// Difference in time should be within 1e6 ns, i.e. 1ms
|
||||||
// (due to conversion between ns & ms, float64 & int64).
|
// (due to conversion between ns & ms, float64 & int64).
|
||||||
activeAtDiff := float64(e.ActiveAt.Unix() + int64(tst.downDuration/time.Second) - got[i].ActiveAt.Unix())
|
activeAtDiff := float64(e.ActiveAt.Unix() + int64(tst.downDuration/time.Second) - got[i].ActiveAt.Unix())
|
||||||
testutil.Assert(t, math.Abs(activeAtDiff) == 0, "'for' state restored time is wrong")
|
assert.True(t, math.Abs(activeAtDiff) == 0, "'for' state restored time is wrong")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -535,7 +535,7 @@ func TestStaleness(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
expr, err := parser.ParseExpr("a + 1")
|
expr, err := parser.ParseExpr("a + 1")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
rule := NewRecordingRule("a_plus_one", expr, labels.Labels{})
|
rule := NewRecordingRule("a_plus_one", expr, labels.Labels{})
|
||||||
group := NewGroup(GroupOptions{
|
group := NewGroup(GroupOptions{
|
||||||
Name: "default",
|
Name: "default",
|
||||||
|
@ -552,7 +552,7 @@ func TestStaleness(t *testing.T) {
|
||||||
app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 2000, math.Float64frombits(value.StaleNaN))
|
app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 2000, math.Float64frombits(value.StaleNaN))
|
||||||
|
|
||||||
err = app.Commit()
|
err = app.Commit()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
|
|
||||||
|
@ -562,31 +562,31 @@ func TestStaleness(t *testing.T) {
|
||||||
group.Eval(ctx, time.Unix(2, 0))
|
group.Eval(ctx, time.Unix(2, 0))
|
||||||
|
|
||||||
querier, err := st.Querier(context.Background(), 0, 2000)
|
querier, err := st.Querier(context.Background(), 0, 2000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "a_plus_one")
|
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "a_plus_one")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
set := querier.Select(false, nil, matcher)
|
set := querier.Select(false, nil, matcher)
|
||||||
samples, err := readSeriesSet(set)
|
samples, err := readSeriesSet(set)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
metric := labels.FromStrings(model.MetricNameLabel, "a_plus_one").String()
|
metric := labels.FromStrings(model.MetricNameLabel, "a_plus_one").String()
|
||||||
metricSample, ok := samples[metric]
|
metricSample, ok := samples[metric]
|
||||||
|
|
||||||
testutil.Assert(t, ok, "Series %s not returned.", metric)
|
assert.True(t, ok, "Series %s not returned.", metric)
|
||||||
testutil.Assert(t, value.IsStaleNaN(metricSample[2].V), "Appended second sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(metricSample[2].V))
|
assert.True(t, value.IsStaleNaN(metricSample[2].V), "Appended second sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(metricSample[2].V))
|
||||||
metricSample[2].V = 42 // reflect.DeepEqual cannot handle NaN.
|
metricSample[2].V = 42 // assert.Equal cannot handle NaN.
|
||||||
|
|
||||||
want := map[string][]promql.Point{
|
want := map[string][]promql.Point{
|
||||||
metric: {{T: 0, V: 2}, {T: 1000, V: 3}, {T: 2000, V: 42}},
|
metric: {{T: 0, V: 2}, {T: 1000, V: 3}, {T: 2000, V: 42}},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, want, samples)
|
assert.Equal(t, want, samples)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Convert a SeriesSet into a form usable with reflect.DeepEqual.
|
// Convert a SeriesSet into a form usable with assert.Equal.
|
||||||
func readSeriesSet(ss storage.SeriesSet) (map[string][]promql.Point, error) {
|
func readSeriesSet(ss storage.SeriesSet) (map[string][]promql.Point, error) {
|
||||||
result := map[string][]promql.Point{}
|
result := map[string][]promql.Point{}
|
||||||
|
|
||||||
|
@ -654,11 +654,11 @@ func TestCopyState(t *testing.T) {
|
||||||
{"a2": labels.Labels{{Name: "l2", Value: "v1"}}},
|
{"a2": labels.Labels{{Name: "l2", Value: "v1"}}},
|
||||||
nil,
|
nil,
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, newGroup.seriesInPreviousEval)
|
assert.Equal(t, want, newGroup.seriesInPreviousEval)
|
||||||
testutil.Equals(t, oldGroup.rules[0], newGroup.rules[3])
|
assert.Equal(t, oldGroup.rules[0], newGroup.rules[3])
|
||||||
testutil.Equals(t, oldGroup.evaluationTime, newGroup.evaluationTime)
|
assert.Equal(t, oldGroup.evaluationTime, newGroup.evaluationTime)
|
||||||
testutil.Equals(t, oldGroup.lastEvaluation, newGroup.lastEvaluation)
|
assert.Equal(t, oldGroup.lastEvaluation, newGroup.lastEvaluation)
|
||||||
testutil.Equals(t, []labels.Labels{{{Name: "l1", Value: "v3"}}}, newGroup.staleSeries)
|
assert.Equal(t, []labels.Labels{{{Name: "l1", Value: "v3"}}}, newGroup.staleSeries)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDeletedRuleMarkedStale(t *testing.T) {
|
func TestDeletedRuleMarkedStale(t *testing.T) {
|
||||||
|
@ -684,21 +684,21 @@ func TestDeletedRuleMarkedStale(t *testing.T) {
|
||||||
newGroup.Eval(context.Background(), time.Unix(0, 0))
|
newGroup.Eval(context.Background(), time.Unix(0, 0))
|
||||||
|
|
||||||
querier, err := st.Querier(context.Background(), 0, 2000)
|
querier, err := st.Querier(context.Background(), 0, 2000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher, err := labels.NewMatcher(labels.MatchEqual, "l1", "v1")
|
matcher, err := labels.NewMatcher(labels.MatchEqual, "l1", "v1")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
set := querier.Select(false, nil, matcher)
|
set := querier.Select(false, nil, matcher)
|
||||||
samples, err := readSeriesSet(set)
|
samples, err := readSeriesSet(set)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
metric := labels.FromStrings("l1", "v1").String()
|
metric := labels.FromStrings("l1", "v1").String()
|
||||||
metricSample, ok := samples[metric]
|
metricSample, ok := samples[metric]
|
||||||
|
|
||||||
testutil.Assert(t, ok, "Series %s not returned.", metric)
|
assert.True(t, ok, "Series %s not returned.", metric)
|
||||||
testutil.Assert(t, value.IsStaleNaN(metricSample[0].V), "Appended sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(metricSample[0].V))
|
assert.True(t, value.IsStaleNaN(metricSample[0].V), "Appended sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(metricSample[0].V))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestUpdate(t *testing.T) {
|
func TestUpdate(t *testing.T) {
|
||||||
|
@ -726,8 +726,8 @@ func TestUpdate(t *testing.T) {
|
||||||
defer ruleManager.Stop()
|
defer ruleManager.Stop()
|
||||||
|
|
||||||
err := ruleManager.Update(10*time.Second, files, nil)
|
err := ruleManager.Update(10*time.Second, files, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, len(ruleManager.groups) > 0, "expected non-empty rule groups")
|
assert.True(t, len(ruleManager.groups) > 0, "expected non-empty rule groups")
|
||||||
ogs := map[string]*Group{}
|
ogs := map[string]*Group{}
|
||||||
for h, g := range ruleManager.groups {
|
for h, g := range ruleManager.groups {
|
||||||
g.seriesInPreviousEval = []map[string]labels.Labels{
|
g.seriesInPreviousEval = []map[string]labels.Labels{
|
||||||
|
@ -737,26 +737,26 @@ func TestUpdate(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
err = ruleManager.Update(10*time.Second, files, nil)
|
err = ruleManager.Update(10*time.Second, files, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
for h, g := range ruleManager.groups {
|
for h, g := range ruleManager.groups {
|
||||||
for _, actual := range g.seriesInPreviousEval {
|
for _, actual := range g.seriesInPreviousEval {
|
||||||
testutil.Equals(t, expected, actual)
|
assert.Equal(t, expected, actual)
|
||||||
}
|
}
|
||||||
// Groups are the same because of no updates.
|
// Groups are the same because of no updates.
|
||||||
testutil.Equals(t, ogs[h], g)
|
assert.Equal(t, ogs[h], g)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Groups will be recreated if updated.
|
// Groups will be recreated if updated.
|
||||||
rgs, errs := rulefmt.ParseFile("fixtures/rules.yaml")
|
rgs, errs := rulefmt.ParseFile("fixtures/rules.yaml")
|
||||||
testutil.Assert(t, len(errs) == 0, "file parsing failures")
|
assert.True(t, len(errs) == 0, "file parsing failures")
|
||||||
|
|
||||||
tmpFile, err := ioutil.TempFile("", "rules.test.*.yaml")
|
tmpFile, err := ioutil.TempFile("", "rules.test.*.yaml")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.Remove(tmpFile.Name())
|
defer os.Remove(tmpFile.Name())
|
||||||
defer tmpFile.Close()
|
defer tmpFile.Close()
|
||||||
|
|
||||||
err = ruleManager.Update(10*time.Second, []string{tmpFile.Name()}, nil)
|
err = ruleManager.Update(10*time.Second, []string{tmpFile.Name()}, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
for h, g := range ruleManager.groups {
|
for h, g := range ruleManager.groups {
|
||||||
ogs[h] = g
|
ogs[h] = g
|
||||||
|
@ -822,12 +822,12 @@ func formatRules(r *rulefmt.RuleGroups) ruleGroupsTest {
|
||||||
|
|
||||||
func reloadAndValidate(rgs *rulefmt.RuleGroups, t *testing.T, tmpFile *os.File, ruleManager *Manager, expected map[string]labels.Labels, ogs map[string]*Group) {
|
func reloadAndValidate(rgs *rulefmt.RuleGroups, t *testing.T, tmpFile *os.File, ruleManager *Manager, expected map[string]labels.Labels, ogs map[string]*Group) {
|
||||||
bs, err := yaml.Marshal(formatRules(rgs))
|
bs, err := yaml.Marshal(formatRules(rgs))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
tmpFile.Seek(0, 0)
|
tmpFile.Seek(0, 0)
|
||||||
_, err = tmpFile.Write(bs)
|
_, err = tmpFile.Write(bs)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
err = ruleManager.Update(10*time.Second, []string{tmpFile.Name()}, nil)
|
err = ruleManager.Update(10*time.Second, []string{tmpFile.Name()}, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
for h, g := range ruleManager.groups {
|
for h, g := range ruleManager.groups {
|
||||||
if ogs[h] == g {
|
if ogs[h] == g {
|
||||||
t.Fail()
|
t.Fail()
|
||||||
|
@ -861,7 +861,7 @@ func TestNotify(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
expr, err := parser.ParseExpr("a > 1")
|
expr, err := parser.ParseExpr("a > 1")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
rule := NewAlertingRule("aTooHigh", expr, 0, labels.Labels{}, labels.Labels{}, nil, true, log.NewNopLogger())
|
rule := NewAlertingRule("aTooHigh", expr, 0, labels.Labels{}, labels.Labels{}, nil, true, log.NewNopLogger())
|
||||||
group := NewGroup(GroupOptions{
|
group := NewGroup(GroupOptions{
|
||||||
Name: "alert",
|
Name: "alert",
|
||||||
|
@ -878,26 +878,26 @@ func TestNotify(t *testing.T) {
|
||||||
app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 6000, 0)
|
app.Add(labels.FromStrings(model.MetricNameLabel, "a"), 6000, 0)
|
||||||
|
|
||||||
err = app.Commit()
|
err = app.Commit()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
|
|
||||||
// Alert sent right away
|
// Alert sent right away
|
||||||
group.Eval(ctx, time.Unix(1, 0))
|
group.Eval(ctx, time.Unix(1, 0))
|
||||||
testutil.Equals(t, 1, len(lastNotified))
|
assert.Equal(t, 1, len(lastNotified))
|
||||||
testutil.Assert(t, !lastNotified[0].ValidUntil.IsZero(), "ValidUntil should not be zero")
|
assert.True(t, !lastNotified[0].ValidUntil.IsZero(), "ValidUntil should not be zero")
|
||||||
|
|
||||||
// Alert is not sent 1s later
|
// Alert is not sent 1s later
|
||||||
group.Eval(ctx, time.Unix(2, 0))
|
group.Eval(ctx, time.Unix(2, 0))
|
||||||
testutil.Equals(t, 0, len(lastNotified))
|
assert.Equal(t, 0, len(lastNotified))
|
||||||
|
|
||||||
// Alert is resent at t=5s
|
// Alert is resent at t=5s
|
||||||
group.Eval(ctx, time.Unix(5, 0))
|
group.Eval(ctx, time.Unix(5, 0))
|
||||||
testutil.Equals(t, 1, len(lastNotified))
|
assert.Equal(t, 1, len(lastNotified))
|
||||||
|
|
||||||
// Resolution alert sent right away
|
// Resolution alert sent right away
|
||||||
group.Eval(ctx, time.Unix(6, 0))
|
group.Eval(ctx, time.Unix(6, 0))
|
||||||
testutil.Equals(t, 1, len(lastNotified))
|
assert.Equal(t, 1, len(lastNotified))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetricsUpdate(t *testing.T) {
|
func TestMetricsUpdate(t *testing.T) {
|
||||||
|
@ -934,7 +934,7 @@ func TestMetricsUpdate(t *testing.T) {
|
||||||
|
|
||||||
countMetrics := func() int {
|
countMetrics := func() int {
|
||||||
ms, err := registry.Gather()
|
ms, err := registry.Gather()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
var metrics int
|
var metrics int
|
||||||
for _, m := range ms {
|
for _, m := range ms {
|
||||||
s := m.GetName()
|
s := m.GetName()
|
||||||
|
@ -972,9 +972,9 @@ func TestMetricsUpdate(t *testing.T) {
|
||||||
|
|
||||||
for i, c := range cases {
|
for i, c := range cases {
|
||||||
err := ruleManager.Update(time.Second, c.files, nil)
|
err := ruleManager.Update(time.Second, c.files, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
time.Sleep(2 * time.Second)
|
time.Sleep(2 * time.Second)
|
||||||
testutil.Equals(t, c.metrics, countMetrics(), "test %d: invalid count of metrics", i)
|
assert.Equal(t, c.metrics, countMetrics(), "test %d: invalid count of metrics", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1046,14 +1046,14 @@ func TestGroupStalenessOnRemoval(t *testing.T) {
|
||||||
var totalStaleNaN int
|
var totalStaleNaN int
|
||||||
for i, c := range cases {
|
for i, c := range cases {
|
||||||
err := ruleManager.Update(time.Second, c.files, nil)
|
err := ruleManager.Update(time.Second, c.files, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
time.Sleep(3 * time.Second)
|
time.Sleep(3 * time.Second)
|
||||||
totalStaleNaN += c.staleNaN
|
totalStaleNaN += c.staleNaN
|
||||||
testutil.Equals(t, totalStaleNaN, countStaleNaN(t, storage), "test %d/%q: invalid count of staleness markers", i, c.files)
|
assert.Equal(t, totalStaleNaN, countStaleNaN(t, storage), "test %d/%q: invalid count of staleness markers", i, c.files)
|
||||||
}
|
}
|
||||||
ruleManager.Stop()
|
ruleManager.Stop()
|
||||||
stopped = true
|
stopped = true
|
||||||
testutil.Equals(t, totalStaleNaN, countStaleNaN(t, storage), "invalid count of staleness markers after stopping the engine")
|
assert.Equal(t, totalStaleNaN, countStaleNaN(t, storage), "invalid count of staleness markers after stopping the engine")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMetricsStalenessOnManagerShutdown(t *testing.T) {
|
func TestMetricsStalenessOnManagerShutdown(t *testing.T) {
|
||||||
|
@ -1089,34 +1089,34 @@ func TestMetricsStalenessOnManagerShutdown(t *testing.T) {
|
||||||
|
|
||||||
err := ruleManager.Update(2*time.Second, files, nil)
|
err := ruleManager.Update(2*time.Second, files, nil)
|
||||||
time.Sleep(4 * time.Second)
|
time.Sleep(4 * time.Second)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
start := time.Now()
|
start := time.Now()
|
||||||
err = ruleManager.Update(3*time.Second, files[:0], nil)
|
err = ruleManager.Update(3*time.Second, files[:0], nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
ruleManager.Stop()
|
ruleManager.Stop()
|
||||||
stopped = true
|
stopped = true
|
||||||
testutil.Assert(t, time.Since(start) < 1*time.Second, "rule manager does not stop early")
|
assert.True(t, time.Since(start) < 1*time.Second, "rule manager does not stop early")
|
||||||
time.Sleep(5 * time.Second)
|
time.Sleep(5 * time.Second)
|
||||||
testutil.Equals(t, 0, countStaleNaN(t, storage), "invalid count of staleness markers after stopping the engine")
|
assert.Equal(t, 0, countStaleNaN(t, storage), "invalid count of staleness markers after stopping the engine")
|
||||||
}
|
}
|
||||||
|
|
||||||
func countStaleNaN(t *testing.T, st storage.Storage) int {
|
func countStaleNaN(t *testing.T, st storage.Storage) int {
|
||||||
var c int
|
var c int
|
||||||
querier, err := st.Querier(context.Background(), 0, time.Now().Unix()*1000)
|
querier, err := st.Querier(context.Background(), 0, time.Now().Unix()*1000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "test_2")
|
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "test_2")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
set := querier.Select(false, nil, matcher)
|
set := querier.Select(false, nil, matcher)
|
||||||
samples, err := readSeriesSet(set)
|
samples, err := readSeriesSet(set)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
metric := labels.FromStrings(model.MetricNameLabel, "test_2").String()
|
metric := labels.FromStrings(model.MetricNameLabel, "test_2").String()
|
||||||
metricSample, ok := samples[metric]
|
metricSample, ok := samples[metric]
|
||||||
|
|
||||||
testutil.Assert(t, ok, "Series %s not returned.", metric)
|
assert.True(t, ok, "Series %s not returned.", metric)
|
||||||
for _, s := range metricSample {
|
for _, s := range metricSample {
|
||||||
if value.IsStaleNaN(s.V) {
|
if value.IsStaleNaN(s.V) {
|
||||||
c++
|
c++
|
||||||
|
@ -1160,6 +1160,6 @@ func TestGroupHasAlertingRules(t *testing.T) {
|
||||||
|
|
||||||
for i, test := range tests {
|
for i, test := range tests {
|
||||||
got := test.group.HasAlertingRules()
|
got := test.group.HasAlertingRules()
|
||||||
testutil.Assert(t, test.want == got, "test case %d failed, expected:%t got:%t", i, test.want, got)
|
assert.True(t, test.want == got, "test case %d failed, expected:%t got:%t", i, test.want, got)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,16 +15,16 @@ package rules
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/timestamp"
|
"github.com/prometheus/prometheus/pkg/timestamp"
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
"github.com/prometheus/prometheus/promql/parser"
|
"github.com/prometheus/prometheus/promql/parser"
|
||||||
"github.com/prometheus/prometheus/util/teststorage"
|
"github.com/prometheus/prometheus/util/teststorage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestRuleEval(t *testing.T) {
|
func TestRuleEval(t *testing.T) {
|
||||||
|
@ -73,14 +73,14 @@ func TestRuleEval(t *testing.T) {
|
||||||
for _, test := range suite {
|
for _, test := range suite {
|
||||||
rule := NewRecordingRule(test.name, test.expr, test.labels)
|
rule := NewRecordingRule(test.name, test.expr, test.labels)
|
||||||
result, err := rule.Eval(ctx, now, EngineQueryFunc(engine, storage), nil)
|
result, err := rule.Eval(ctx, now, EngineQueryFunc(engine, storage), nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, test.result, result)
|
assert.Equal(t, test.result, result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRecordingRuleHTMLSnippet(t *testing.T) {
|
func TestRecordingRuleHTMLSnippet(t *testing.T) {
|
||||||
expr, err := parser.ParseExpr(`foo{html="<b>BOLD<b>"}`)
|
expr, err := parser.ParseExpr(`foo{html="<b>BOLD<b>"}`)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
rule := NewRecordingRule("testrule", expr, labels.FromStrings("html", "<b>BOLD</b>"))
|
rule := NewRecordingRule("testrule", expr, labels.FromStrings("html", "<b>BOLD</b>"))
|
||||||
|
|
||||||
const want = `record: <a href="/test/prefix/graph?g0.expr=testrule&g0.tab=1">testrule</a>
|
const want = `record: <a href="/test/prefix/graph?g0.expr=testrule&g0.tab=1">testrule</a>
|
||||||
|
@ -90,7 +90,7 @@ labels:
|
||||||
`
|
`
|
||||||
|
|
||||||
got := rule.HTMLSnippet("/test/prefix")
|
got := rule.HTMLSnippet("/test/prefix")
|
||||||
testutil.Assert(t, want == got, "incorrect HTML snippet; want:\n\n%s\n\ngot:\n\n%s", want, got)
|
assert.True(t, want == got, "incorrect HTML snippet; want:\n\n%s\n\ngot:\n\n%s", want, got)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestRuleEvalDuplicate tests for duplicate labels in recorded metrics, see #5529.
|
// TestRuleEvalDuplicate tests for duplicate labels in recorded metrics, see #5529.
|
||||||
|
@ -114,7 +114,6 @@ func TestRuleEvalDuplicate(t *testing.T) {
|
||||||
expr, _ := parser.ParseExpr(`vector(0) or label_replace(vector(0),"test","x","","")`)
|
expr, _ := parser.ParseExpr(`vector(0) or label_replace(vector(0),"test","x","","")`)
|
||||||
rule := NewRecordingRule("foo", expr, labels.FromStrings("test", "test"))
|
rule := NewRecordingRule("foo", expr, labels.FromStrings("test", "test"))
|
||||||
_, err := rule.Eval(ctx, now, EngineQueryFunc(engine, storage), nil)
|
_, err := rule.Eval(ctx, now, EngineQueryFunc(engine, storage), nil)
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
e := fmt.Errorf("vector contains metrics with the same labelset after applying rule labels")
|
assert.EqualError(t, err, "vector contains metrics with the same labelset after applying rule labels")
|
||||||
testutil.ErrorEqual(t, e, err)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@ package scrape
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
)
|
)
|
||||||
|
|
|
@ -26,8 +26,8 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
|
|
|
@ -19,15 +19,14 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
yaml "gopkg.in/yaml.v2"
|
yaml "gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/relabel"
|
"github.com/prometheus/prometheus/pkg/relabel"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestPopulateLabels(t *testing.T) {
|
func TestPopulateLabels(t *testing.T) {
|
||||||
|
@ -36,7 +35,7 @@ func TestPopulateLabels(t *testing.T) {
|
||||||
cfg *config.ScrapeConfig
|
cfg *config.ScrapeConfig
|
||||||
res labels.Labels
|
res labels.Labels
|
||||||
resOrig labels.Labels
|
resOrig labels.Labels
|
||||||
err error
|
err string
|
||||||
}{
|
}{
|
||||||
// Regular population of scrape config options.
|
// Regular population of scrape config options.
|
||||||
{
|
{
|
||||||
|
@ -129,7 +128,7 @@ func TestPopulateLabels(t *testing.T) {
|
||||||
},
|
},
|
||||||
res: nil,
|
res: nil,
|
||||||
resOrig: nil,
|
resOrig: nil,
|
||||||
err: errors.New("no address"),
|
err: "no address",
|
||||||
},
|
},
|
||||||
// Address label missing, but added in relabelling.
|
// Address label missing, but added in relabelling.
|
||||||
{
|
{
|
||||||
|
@ -208,17 +207,21 @@ func TestPopulateLabels(t *testing.T) {
|
||||||
},
|
},
|
||||||
res: nil,
|
res: nil,
|
||||||
resOrig: nil,
|
resOrig: nil,
|
||||||
err: errors.New("invalid label value for \"custom\": \"\\xbd\""),
|
err: "invalid label value for \"custom\": \"\\xbd\"",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
in := c.in.Copy()
|
in := c.in.Copy()
|
||||||
|
|
||||||
res, orig, err := populateLabels(c.in, c.cfg)
|
res, orig, err := populateLabels(c.in, c.cfg)
|
||||||
testutil.ErrorEqual(t, c.err, err)
|
if c.err != "" {
|
||||||
testutil.Equals(t, c.in, in)
|
assert.EqualError(t, err, c.err)
|
||||||
testutil.Equals(t, c.res, res)
|
} else {
|
||||||
testutil.Equals(t, c.resOrig, orig)
|
assert.NoError(t, err)
|
||||||
|
}
|
||||||
|
assert.Equal(t, c.in, in)
|
||||||
|
assert.Equal(t, c.res, res)
|
||||||
|
assert.Equal(t, c.resOrig, orig)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -362,7 +365,7 @@ func TestManagerTargetsUpdates(t *testing.T) {
|
||||||
m.mtxScrape.Unlock()
|
m.mtxScrape.Unlock()
|
||||||
|
|
||||||
// Make sure all updates have been received.
|
// Make sure all updates have been received.
|
||||||
testutil.Equals(t, tgSent, tsetActual)
|
assert.Equal(t, tgSent, tsetActual)
|
||||||
|
|
||||||
select {
|
select {
|
||||||
case <-m.triggerReload:
|
case <-m.triggerReload:
|
||||||
|
|
|
@ -33,6 +33,7 @@ import (
|
||||||
dto "github.com/prometheus/client_model/go"
|
dto "github.com/prometheus/client_model/go"
|
||||||
config_util "github.com/prometheus/common/config"
|
config_util "github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/discovery/targetgroup"
|
"github.com/prometheus/prometheus/discovery/targetgroup"
|
||||||
|
@ -134,7 +135,7 @@ func TestDiscoveredLabelsUpdate(t *testing.T) {
|
||||||
}
|
}
|
||||||
sp.sync([]*Target{t2})
|
sp.sync([]*Target{t2})
|
||||||
|
|
||||||
testutil.Equals(t, t2.DiscoveredLabels(), sp.activeTargets[t1.hash()].DiscoveredLabels())
|
assert.Equal(t, t2.DiscoveredLabels(), sp.activeTargets[t1.hash()].DiscoveredLabels())
|
||||||
}
|
}
|
||||||
|
|
||||||
type testLoop struct {
|
type testLoop struct {
|
||||||
|
@ -227,11 +228,11 @@ func TestScrapePoolStop(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
mtx.Lock()
|
mtx.Lock()
|
||||||
testutil.Equals(t, numTargets, len(stopped), "Unexpected number of stopped loops")
|
assert.Equal(t, numTargets, len(stopped), "Unexpected number of stopped loops")
|
||||||
mtx.Unlock()
|
mtx.Unlock()
|
||||||
|
|
||||||
testutil.Assert(t, len(sp.activeTargets) == 0, "Targets were not cleared on stopping: %d left", len(sp.activeTargets))
|
assert.True(t, len(sp.activeTargets) == 0, "Targets were not cleared on stopping: %d left", len(sp.activeTargets))
|
||||||
testutil.Assert(t, len(sp.loops) == 0, "Loops were not cleared on stopping: %d left", len(sp.loops))
|
assert.True(t, len(sp.loops) == 0, "Loops were not cleared on stopping: %d left", len(sp.loops))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapePoolReload(t *testing.T) {
|
func TestScrapePoolReload(t *testing.T) {
|
||||||
|
@ -249,12 +250,12 @@ func TestScrapePoolReload(t *testing.T) {
|
||||||
newLoop := func(opts scrapeLoopOptions) loop {
|
newLoop := func(opts scrapeLoopOptions) loop {
|
||||||
l := &testLoop{}
|
l := &testLoop{}
|
||||||
l.startFunc = func(interval, timeout time.Duration, errc chan<- error) {
|
l.startFunc = func(interval, timeout time.Duration, errc chan<- error) {
|
||||||
testutil.Equals(t, 3*time.Second, interval, "Unexpected scrape interval")
|
assert.Equal(t, 3*time.Second, interval, "Unexpected scrape interval")
|
||||||
testutil.Equals(t, 2*time.Second, timeout, "Unexpected scrape timeout")
|
assert.Equal(t, 2*time.Second, timeout, "Unexpected scrape timeout")
|
||||||
|
|
||||||
mtx.Lock()
|
mtx.Lock()
|
||||||
targetScraper := opts.scraper.(*targetScraper)
|
targetScraper := opts.scraper.(*targetScraper)
|
||||||
testutil.Assert(t, stopped[targetScraper.hash()], "Scrape loop for %v not stopped yet", targetScraper)
|
assert.True(t, stopped[targetScraper.hash()], "Scrape loop for %v not stopped yet", targetScraper)
|
||||||
mtx.Unlock()
|
mtx.Unlock()
|
||||||
}
|
}
|
||||||
return l
|
return l
|
||||||
|
@ -313,11 +314,11 @@ func TestScrapePoolReload(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
mtx.Lock()
|
mtx.Lock()
|
||||||
testutil.Equals(t, numTargets, len(stopped), "Unexpected number of stopped loops")
|
assert.Equal(t, numTargets, len(stopped), "Unexpected number of stopped loops")
|
||||||
mtx.Unlock()
|
mtx.Unlock()
|
||||||
|
|
||||||
testutil.Equals(t, sp.activeTargets, beforeTargets, "Reloading affected target states unexpectedly")
|
assert.Equal(t, sp.activeTargets, beforeTargets, "Reloading affected target states unexpectedly")
|
||||||
testutil.Equals(t, numTargets, len(sp.loops), "Unexpected number of stopped loops after reload")
|
assert.Equal(t, numTargets, len(sp.loops), "Unexpected number of stopped loops after reload")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapePoolTargetLimit(t *testing.T) {
|
func TestScrapePoolTargetLimit(t *testing.T) {
|
||||||
|
@ -357,7 +358,7 @@ func TestScrapePoolTargetLimit(t *testing.T) {
|
||||||
var limit uint
|
var limit uint
|
||||||
reloadWithLimit := func(l uint) {
|
reloadWithLimit := func(l uint) {
|
||||||
limit = l
|
limit = l
|
||||||
testutil.Ok(t, sp.reload(&config.ScrapeConfig{
|
assert.NoError(t, sp.reload(&config.ScrapeConfig{
|
||||||
ScrapeInterval: model.Duration(3 * time.Second),
|
ScrapeInterval: model.Duration(3 * time.Second),
|
||||||
ScrapeTimeout: model.Duration(2 * time.Second),
|
ScrapeTimeout: model.Duration(2 * time.Second),
|
||||||
TargetLimit: l,
|
TargetLimit: l,
|
||||||
|
@ -373,7 +374,7 @@ func TestScrapePoolTargetLimit(t *testing.T) {
|
||||||
validateIsRunning := func() {
|
validateIsRunning := func() {
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
for _, l := range sp.loops {
|
for _, l := range sp.loops {
|
||||||
testutil.Assert(t, l.(*testLoop).runOnce, "loop should be running")
|
assert.True(t, l.(*testLoop).runOnce, "loop should be running")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -381,10 +382,10 @@ func TestScrapePoolTargetLimit(t *testing.T) {
|
||||||
for _, l := range sp.loops {
|
for _, l := range sp.loops {
|
||||||
lerr := l.(*testLoop).getForcedError()
|
lerr := l.(*testLoop).getForcedError()
|
||||||
if shouldErr {
|
if shouldErr {
|
||||||
testutil.Assert(t, lerr != nil, "error was expected for %d targets with a limit of %d", targets, limit)
|
assert.NotNil(t, lerr, "error was expected for %d targets with a limit of %d", targets, limit)
|
||||||
testutil.Equals(t, fmt.Sprintf("target_limit exceeded (number of targets: %d, limit: %d)", targets, limit), lerr.Error())
|
assert.Equal(t, fmt.Sprintf("target_limit exceeded (number of targets: %d, limit: %d)", targets, limit), lerr.Error())
|
||||||
} else {
|
} else {
|
||||||
testutil.Equals(t, nil, lerr)
|
assert.Equal(t, nil, lerr)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -451,33 +452,33 @@ func TestScrapePoolAppender(t *testing.T) {
|
||||||
target: &Target{},
|
target: &Target{},
|
||||||
})
|
})
|
||||||
appl, ok := loop.(*scrapeLoop)
|
appl, ok := loop.(*scrapeLoop)
|
||||||
testutil.Assert(t, ok, "Expected scrapeLoop but got %T", loop)
|
assert.True(t, ok, "Expected scrapeLoop but got %T", loop)
|
||||||
|
|
||||||
wrapped := appl.appender(context.Background())
|
wrapped := appl.appender(context.Background())
|
||||||
|
|
||||||
tl, ok := wrapped.(*timeLimitAppender)
|
tl, ok := wrapped.(*timeLimitAppender)
|
||||||
testutil.Assert(t, ok, "Expected timeLimitAppender but got %T", wrapped)
|
assert.True(t, ok, "Expected timeLimitAppender but got %T", wrapped)
|
||||||
|
|
||||||
_, ok = tl.Appender.(nopAppender)
|
_, ok = tl.Appender.(nopAppender)
|
||||||
testutil.Assert(t, ok, "Expected base appender but got %T", tl.Appender)
|
assert.True(t, ok, "Expected base appender but got %T", tl.Appender)
|
||||||
|
|
||||||
loop = sp.newLoop(scrapeLoopOptions{
|
loop = sp.newLoop(scrapeLoopOptions{
|
||||||
target: &Target{},
|
target: &Target{},
|
||||||
limit: 100,
|
limit: 100,
|
||||||
})
|
})
|
||||||
appl, ok = loop.(*scrapeLoop)
|
appl, ok = loop.(*scrapeLoop)
|
||||||
testutil.Assert(t, ok, "Expected scrapeLoop but got %T", loop)
|
assert.True(t, ok, "Expected scrapeLoop but got %T", loop)
|
||||||
|
|
||||||
wrapped = appl.appender(context.Background())
|
wrapped = appl.appender(context.Background())
|
||||||
|
|
||||||
sl, ok := wrapped.(*limitAppender)
|
sl, ok := wrapped.(*limitAppender)
|
||||||
testutil.Assert(t, ok, "Expected limitAppender but got %T", wrapped)
|
assert.True(t, ok, "Expected limitAppender but got %T", wrapped)
|
||||||
|
|
||||||
tl, ok = sl.Appender.(*timeLimitAppender)
|
tl, ok = sl.Appender.(*timeLimitAppender)
|
||||||
testutil.Assert(t, ok, "Expected limitAppender but got %T", sl.Appender)
|
assert.True(t, ok, "Expected limitAppender but got %T", sl.Appender)
|
||||||
|
|
||||||
_, ok = tl.Appender.(nopAppender)
|
_, ok = tl.Appender.(nopAppender)
|
||||||
testutil.Assert(t, ok, "Expected base appender but got %T", tl.Appender)
|
assert.True(t, ok, "Expected base appender but got %T", tl.Appender)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapePoolRaces(t *testing.T) {
|
func TestScrapePoolRaces(t *testing.T) {
|
||||||
|
@ -507,8 +508,8 @@ func TestScrapePoolRaces(t *testing.T) {
|
||||||
dropped := sp.DroppedTargets()
|
dropped := sp.DroppedTargets()
|
||||||
expectedActive, expectedDropped := len(tgts[0].Targets), 0
|
expectedActive, expectedDropped := len(tgts[0].Targets), 0
|
||||||
|
|
||||||
testutil.Equals(t, expectedActive, len(active), "Invalid number of active targets")
|
assert.Equal(t, expectedActive, len(active), "Invalid number of active targets")
|
||||||
testutil.Equals(t, expectedDropped, len(dropped), "Invalid number of dropped targets")
|
assert.Equal(t, expectedDropped, len(dropped), "Invalid number of dropped targets")
|
||||||
|
|
||||||
for i := 0; i < 20; i++ {
|
for i := 0; i < 20; i++ {
|
||||||
time.Sleep(time.Duration(10 * time.Millisecond))
|
time.Sleep(time.Duration(10 * time.Millisecond))
|
||||||
|
@ -551,17 +552,17 @@ func TestScrapePoolScrapeLoopsStarted(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, sp.reload(&config.ScrapeConfig{
|
assert.NoError(t, sp.reload(&config.ScrapeConfig{
|
||||||
ScrapeInterval: model.Duration(3 * time.Second),
|
ScrapeInterval: model.Duration(3 * time.Second),
|
||||||
ScrapeTimeout: model.Duration(2 * time.Second),
|
ScrapeTimeout: model.Duration(2 * time.Second),
|
||||||
}))
|
}))
|
||||||
sp.Sync(tgs)
|
sp.Sync(tgs)
|
||||||
|
|
||||||
testutil.Equals(t, 1, len(sp.loops))
|
assert.Equal(t, 1, len(sp.loops))
|
||||||
|
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
for _, l := range sp.loops {
|
for _, l := range sp.loops {
|
||||||
testutil.Assert(t, l.(*testLoop).runOnce, "loop should be running")
|
assert.True(t, l.(*testLoop).runOnce, "loop should be running")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -865,27 +866,27 @@ test_metric 1
|
||||||
# TYPE test_metric_no_help gauge
|
# TYPE test_metric_no_help gauge
|
||||||
# HELP test_metric_no_type other help text
|
# HELP test_metric_no_type other help text
|
||||||
# EOF`), "application/openmetrics-text", time.Now())
|
# EOF`), "application/openmetrics-text", time.Now())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
testutil.Equals(t, 1, total)
|
assert.Equal(t, 1, total)
|
||||||
|
|
||||||
md, ok := cache.GetMetadata("test_metric")
|
md, ok := cache.GetMetadata("test_metric")
|
||||||
testutil.Assert(t, ok, "expected metadata to be present")
|
assert.True(t, ok, "expected metadata to be present")
|
||||||
testutil.Assert(t, textparse.MetricTypeCounter == md.Type, "unexpected metric type")
|
assert.True(t, textparse.MetricTypeCounter == md.Type, "unexpected metric type")
|
||||||
testutil.Equals(t, "some help text", md.Help)
|
assert.Equal(t, "some help text", md.Help)
|
||||||
testutil.Equals(t, "metric", md.Unit)
|
assert.Equal(t, "metric", md.Unit)
|
||||||
|
|
||||||
md, ok = cache.GetMetadata("test_metric_no_help")
|
md, ok = cache.GetMetadata("test_metric_no_help")
|
||||||
testutil.Assert(t, ok, "expected metadata to be present")
|
assert.True(t, ok, "expected metadata to be present")
|
||||||
testutil.Assert(t, textparse.MetricTypeGauge == md.Type, "unexpected metric type")
|
assert.True(t, textparse.MetricTypeGauge == md.Type, "unexpected metric type")
|
||||||
testutil.Equals(t, "", md.Help)
|
assert.Equal(t, "", md.Help)
|
||||||
testutil.Equals(t, "", md.Unit)
|
assert.Equal(t, "", md.Unit)
|
||||||
|
|
||||||
md, ok = cache.GetMetadata("test_metric_no_type")
|
md, ok = cache.GetMetadata("test_metric_no_type")
|
||||||
testutil.Assert(t, ok, "expected metadata to be present")
|
assert.True(t, ok, "expected metadata to be present")
|
||||||
testutil.Assert(t, textparse.MetricTypeUnknown == md.Type, "unexpected metric type")
|
assert.True(t, textparse.MetricTypeUnknown == md.Type, "unexpected metric type")
|
||||||
testutil.Equals(t, "other help text", md.Help)
|
assert.Equal(t, "other help text", md.Help)
|
||||||
testutil.Equals(t, "", md.Unit)
|
assert.Equal(t, "", md.Unit)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopSeriesAdded(t *testing.T) {
|
func TestScrapeLoopSeriesAdded(t *testing.T) {
|
||||||
|
@ -908,19 +909,19 @@ func TestScrapeLoopSeriesAdded(t *testing.T) {
|
||||||
|
|
||||||
slApp := sl.appender(ctx)
|
slApp := sl.appender(ctx)
|
||||||
total, added, seriesAdded, err := sl.append(slApp, []byte("test_metric 1\n"), "", time.Time{})
|
total, added, seriesAdded, err := sl.append(slApp, []byte("test_metric 1\n"), "", time.Time{})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
testutil.Equals(t, 1, total)
|
assert.Equal(t, 1, total)
|
||||||
testutil.Equals(t, 1, added)
|
assert.Equal(t, 1, added)
|
||||||
testutil.Equals(t, 1, seriesAdded)
|
assert.Equal(t, 1, seriesAdded)
|
||||||
|
|
||||||
slApp = sl.appender(ctx)
|
slApp = sl.appender(ctx)
|
||||||
total, added, seriesAdded, err = sl.append(slApp, []byte("test_metric 1\n"), "", time.Time{})
|
total, added, seriesAdded, err = sl.append(slApp, []byte("test_metric 1\n"), "", time.Time{})
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 1, total)
|
assert.Equal(t, 1, total)
|
||||||
testutil.Equals(t, 1, added)
|
assert.Equal(t, 1, added)
|
||||||
testutil.Equals(t, 0, seriesAdded)
|
assert.Equal(t, 0, seriesAdded)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopRunCreatesStaleMarkersOnFailedScrape(t *testing.T) {
|
func TestScrapeLoopRunCreatesStaleMarkersOnFailedScrape(t *testing.T) {
|
||||||
|
@ -970,9 +971,9 @@ func TestScrapeLoopRunCreatesStaleMarkersOnFailedScrape(t *testing.T) {
|
||||||
|
|
||||||
// 1 successfully scraped sample, 1 stale marker after first fail, 5 report samples for
|
// 1 successfully scraped sample, 1 stale marker after first fail, 5 report samples for
|
||||||
// each scrape successful or not.
|
// each scrape successful or not.
|
||||||
testutil.Equals(t, 27, len(appender.result), "Appended samples not as expected")
|
assert.Equal(t, 27, len(appender.result), "Appended samples not as expected")
|
||||||
testutil.Equals(t, 42.0, appender.result[0].v, "Appended first sample not as expected")
|
assert.Equal(t, 42.0, appender.result[0].v, "Appended first sample not as expected")
|
||||||
testutil.Assert(t, value.IsStaleNaN(appender.result[6].v),
|
assert.True(t, value.IsStaleNaN(appender.result[6].v),
|
||||||
"Appended second sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(appender.result[6].v))
|
"Appended second sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(appender.result[6].v))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1026,9 +1027,9 @@ func TestScrapeLoopRunCreatesStaleMarkersOnParseFailure(t *testing.T) {
|
||||||
|
|
||||||
// 1 successfully scraped sample, 1 stale marker after first fail, 5 report samples for
|
// 1 successfully scraped sample, 1 stale marker after first fail, 5 report samples for
|
||||||
// each scrape successful or not.
|
// each scrape successful or not.
|
||||||
testutil.Equals(t, 17, len(appender.result), "Appended samples not as expected")
|
assert.Equal(t, 17, len(appender.result), "Appended samples not as expected")
|
||||||
testutil.Equals(t, 42.0, appender.result[0].v, "Appended first sample not as expected")
|
assert.Equal(t, 42.0, appender.result[0].v, "Appended first sample not as expected")
|
||||||
testutil.Assert(t, value.IsStaleNaN(appender.result[6].v),
|
assert.True(t, value.IsStaleNaN(appender.result[6].v),
|
||||||
"Appended second sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(appender.result[6].v))
|
"Appended second sample not as expected. Wanted: stale NaN Got: %x", math.Float64bits(appender.result[6].v))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1101,7 +1102,7 @@ func TestScrapeLoopCache(t *testing.T) {
|
||||||
|
|
||||||
// 1 successfully scraped sample, 1 stale marker after first fail, 5 report samples for
|
// 1 successfully scraped sample, 1 stale marker after first fail, 5 report samples for
|
||||||
// each scrape successful or not.
|
// each scrape successful or not.
|
||||||
testutil.Equals(t, 26, len(appender.result), "Appended samples not as expected")
|
assert.Equal(t, 26, len(appender.result), "Appended samples not as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopCacheMemoryExhaustionProtection(t *testing.T) {
|
func TestScrapeLoopCacheMemoryExhaustionProtection(t *testing.T) {
|
||||||
|
@ -1239,8 +1240,8 @@ func TestScrapeLoopAppend(t *testing.T) {
|
||||||
|
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte(test.scrapeLabels), "", now)
|
_, _, _, err := sl.append(slApp, []byte(test.scrapeLabels), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
expected := []sample{
|
expected := []sample{
|
||||||
{
|
{
|
||||||
|
@ -1258,7 +1259,7 @@ func TestScrapeLoopAppend(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
t.Logf("Test:%s", test.title)
|
t.Logf("Test:%s", test.title)
|
||||||
testutil.Equals(t, expected, app.result)
|
assert.Equal(t, expected, app.result)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1292,8 +1293,8 @@ func TestScrapeLoopAppendCacheEntryButErrNotFound(t *testing.T) {
|
||||||
|
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte(metric), "", now)
|
_, _, _, err := sl.append(slApp, []byte(metric), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
expected := []sample{
|
expected := []sample{
|
||||||
{
|
{
|
||||||
|
@ -1303,7 +1304,7 @@ func TestScrapeLoopAppendCacheEntryButErrNotFound(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, expected, app.result)
|
assert.Equal(t, expected, app.result)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopAppendSampleLimit(t *testing.T) {
|
func TestScrapeLoopAppendSampleLimit(t *testing.T) {
|
||||||
|
@ -1328,7 +1329,7 @@ func TestScrapeLoopAppendSampleLimit(t *testing.T) {
|
||||||
// Get the value of the Counter before performing the append.
|
// Get the value of the Counter before performing the append.
|
||||||
beforeMetric := dto.Metric{}
|
beforeMetric := dto.Metric{}
|
||||||
err := targetScrapeSampleLimit.Write(&beforeMetric)
|
err := targetScrapeSampleLimit.Write(&beforeMetric)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
beforeMetricValue := beforeMetric.GetCounter().GetValue()
|
beforeMetricValue := beforeMetric.GetCounter().GetValue()
|
||||||
|
|
||||||
|
@ -1338,20 +1339,20 @@ func TestScrapeLoopAppendSampleLimit(t *testing.T) {
|
||||||
if err != errSampleLimit {
|
if err != errSampleLimit {
|
||||||
t.Fatalf("Did not see expected sample limit error: %s", err)
|
t.Fatalf("Did not see expected sample limit error: %s", err)
|
||||||
}
|
}
|
||||||
testutil.Ok(t, slApp.Rollback())
|
assert.NoError(t, slApp.Rollback())
|
||||||
testutil.Equals(t, 3, total)
|
assert.Equal(t, 3, total)
|
||||||
testutil.Equals(t, 3, added)
|
assert.Equal(t, 3, added)
|
||||||
testutil.Equals(t, 1, seriesAdded)
|
assert.Equal(t, 1, seriesAdded)
|
||||||
|
|
||||||
// Check that the Counter has been incremented a single time for the scrape,
|
// Check that the Counter has been incremented a single time for the scrape,
|
||||||
// not multiple times for each sample.
|
// not multiple times for each sample.
|
||||||
metric := dto.Metric{}
|
metric := dto.Metric{}
|
||||||
err = targetScrapeSampleLimit.Write(&metric)
|
err = targetScrapeSampleLimit.Write(&metric)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
value := metric.GetCounter().GetValue()
|
value := metric.GetCounter().GetValue()
|
||||||
change := value - beforeMetricValue
|
change := value - beforeMetricValue
|
||||||
testutil.Assert(t, change == 1, "Unexpected change of sample limit metric: %f", change)
|
assert.True(t, change == 1, "Unexpected change of sample limit metric: %f", change)
|
||||||
|
|
||||||
// And verify that we got the samples that fit under the limit.
|
// And verify that we got the samples that fit under the limit.
|
||||||
want := []sample{
|
want := []sample{
|
||||||
|
@ -1361,7 +1362,7 @@ func TestScrapeLoopAppendSampleLimit(t *testing.T) {
|
||||||
v: 1,
|
v: 1,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, resApp.rolledbackResult, "Appended samples not as expected")
|
assert.Equal(t, want, resApp.rolledbackResult, "Appended samples not as expected")
|
||||||
|
|
||||||
now = time.Now()
|
now = time.Now()
|
||||||
slApp = sl.appender(context.Background())
|
slApp = sl.appender(context.Background())
|
||||||
|
@ -1369,10 +1370,10 @@ func TestScrapeLoopAppendSampleLimit(t *testing.T) {
|
||||||
if err != errSampleLimit {
|
if err != errSampleLimit {
|
||||||
t.Fatalf("Did not see expected sample limit error: %s", err)
|
t.Fatalf("Did not see expected sample limit error: %s", err)
|
||||||
}
|
}
|
||||||
testutil.Ok(t, slApp.Rollback())
|
assert.NoError(t, slApp.Rollback())
|
||||||
testutil.Equals(t, 9, total)
|
assert.Equal(t, 9, total)
|
||||||
testutil.Equals(t, 6, added)
|
assert.Equal(t, 6, added)
|
||||||
testutil.Equals(t, 0, seriesAdded)
|
assert.Equal(t, 0, seriesAdded)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoop_ChangingMetricString(t *testing.T) {
|
func TestScrapeLoop_ChangingMetricString(t *testing.T) {
|
||||||
|
@ -1397,13 +1398,13 @@ func TestScrapeLoop_ChangingMetricString(t *testing.T) {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte(`metric_a{a="1",b="1"} 1`), "", now)
|
_, _, _, err := sl.append(slApp, []byte(`metric_a{a="1",b="1"} 1`), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
slApp = sl.appender(context.Background())
|
slApp = sl.appender(context.Background())
|
||||||
_, _, _, err = sl.append(slApp, []byte(`metric_a{b="1",a="1"} 2`), "", now.Add(time.Minute))
|
_, _, _, err = sl.append(slApp, []byte(`metric_a{b="1",a="1"} 2`), "", now.Add(time.Minute))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
// DeepEqual will report NaNs as being different, so replace with a different value.
|
// DeepEqual will report NaNs as being different, so replace with a different value.
|
||||||
want := []sample{
|
want := []sample{
|
||||||
|
@ -1418,7 +1419,7 @@ func TestScrapeLoop_ChangingMetricString(t *testing.T) {
|
||||||
v: 2,
|
v: 2,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, capp.result, "Appended samples not as expected")
|
assert.Equal(t, want, capp.result, "Appended samples not as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopAppendStaleness(t *testing.T) {
|
func TestScrapeLoopAppendStaleness(t *testing.T) {
|
||||||
|
@ -1437,16 +1438,16 @@ func TestScrapeLoopAppendStaleness(t *testing.T) {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte("metric_a 1\n"), "", now)
|
_, _, _, err := sl.append(slApp, []byte("metric_a 1\n"), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
slApp = sl.appender(context.Background())
|
slApp = sl.appender(context.Background())
|
||||||
_, _, _, err = sl.append(slApp, []byte(""), "", now.Add(time.Second))
|
_, _, _, err = sl.append(slApp, []byte(""), "", now.Add(time.Second))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
ingestedNaN := math.Float64bits(app.result[1].v)
|
ingestedNaN := math.Float64bits(app.result[1].v)
|
||||||
testutil.Equals(t, value.StaleNaN, ingestedNaN, "Appended stale sample wasn't as expected")
|
assert.Equal(t, value.StaleNaN, ingestedNaN, "Appended stale sample wasn't as expected")
|
||||||
|
|
||||||
// DeepEqual will report NaNs as being different, so replace with a different value.
|
// DeepEqual will report NaNs as being different, so replace with a different value.
|
||||||
app.result[1].v = 42
|
app.result[1].v = 42
|
||||||
|
@ -1462,7 +1463,7 @@ func TestScrapeLoopAppendStaleness(t *testing.T) {
|
||||||
v: 42,
|
v: 42,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, app.result, "Appended samples not as expected")
|
assert.Equal(t, want, app.result, "Appended samples not as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopAppendNoStalenessIfTimestamp(t *testing.T) {
|
func TestScrapeLoopAppendNoStalenessIfTimestamp(t *testing.T) {
|
||||||
|
@ -1480,13 +1481,13 @@ func TestScrapeLoopAppendNoStalenessIfTimestamp(t *testing.T) {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte("metric_a 1 1000\n"), "", now)
|
_, _, _, err := sl.append(slApp, []byte("metric_a 1 1000\n"), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
slApp = sl.appender(context.Background())
|
slApp = sl.appender(context.Background())
|
||||||
_, _, _, err = sl.append(slApp, []byte(""), "", now.Add(time.Second))
|
_, _, _, err = sl.append(slApp, []byte(""), "", now.Add(time.Second))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
want := []sample{
|
want := []sample{
|
||||||
{
|
{
|
||||||
|
@ -1495,7 +1496,7 @@ func TestScrapeLoopAppendNoStalenessIfTimestamp(t *testing.T) {
|
||||||
v: 1,
|
v: 1,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, app.result, "Appended samples not as expected")
|
assert.Equal(t, want, app.result, "Appended samples not as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopRunReportsTargetDownOnScrapeError(t *testing.T) {
|
func TestScrapeLoopRunReportsTargetDownOnScrapeError(t *testing.T) {
|
||||||
|
@ -1523,7 +1524,7 @@ func TestScrapeLoopRunReportsTargetDownOnScrapeError(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
sl.run(10*time.Millisecond, time.Hour, nil)
|
sl.run(10*time.Millisecond, time.Hour, nil)
|
||||||
testutil.Equals(t, 0.0, appender.result[0].v, "bad 'up' value")
|
assert.Equal(t, 0.0, appender.result[0].v, "bad 'up' value")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopRunReportsTargetDownOnInvalidUTF8(t *testing.T) {
|
func TestScrapeLoopRunReportsTargetDownOnInvalidUTF8(t *testing.T) {
|
||||||
|
@ -1552,7 +1553,7 @@ func TestScrapeLoopRunReportsTargetDownOnInvalidUTF8(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
sl.run(10*time.Millisecond, time.Hour, nil)
|
sl.run(10*time.Millisecond, time.Hour, nil)
|
||||||
testutil.Equals(t, 0.0, appender.result[0].v, "bad 'up' value")
|
assert.Equal(t, 0.0, appender.result[0].v, "bad 'up' value")
|
||||||
}
|
}
|
||||||
|
|
||||||
type errorAppender struct {
|
type errorAppender struct {
|
||||||
|
@ -1593,8 +1594,8 @@ func TestScrapeLoopAppendGracefullyIfAmendOrOutOfOrderOrOutOfBounds(t *testing.T
|
||||||
now := time.Unix(1, 0)
|
now := time.Unix(1, 0)
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
total, added, seriesAdded, err := sl.append(slApp, []byte("out_of_order 1\namend 1\nnormal 1\nout_of_bounds 1\n"), "", now)
|
total, added, seriesAdded, err := sl.append(slApp, []byte("out_of_order 1\namend 1\nnormal 1\nout_of_bounds 1\n"), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
want := []sample{
|
want := []sample{
|
||||||
{
|
{
|
||||||
|
@ -1603,10 +1604,10 @@ func TestScrapeLoopAppendGracefullyIfAmendOrOutOfOrderOrOutOfBounds(t *testing.T
|
||||||
v: 1,
|
v: 1,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, app.result, "Appended samples not as expected")
|
assert.Equal(t, want, app.result, "Appended samples not as expected")
|
||||||
testutil.Equals(t, 4, total)
|
assert.Equal(t, 4, total)
|
||||||
testutil.Equals(t, 4, added)
|
assert.Equal(t, 4, added)
|
||||||
testutil.Equals(t, 1, seriesAdded)
|
assert.Equal(t, 1, seriesAdded)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopOutOfBoundsTimeError(t *testing.T) {
|
func TestScrapeLoopOutOfBoundsTimeError(t *testing.T) {
|
||||||
|
@ -1630,11 +1631,11 @@ func TestScrapeLoopOutOfBoundsTimeError(t *testing.T) {
|
||||||
now := time.Now().Add(20 * time.Minute)
|
now := time.Now().Add(20 * time.Minute)
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
total, added, seriesAdded, err := sl.append(slApp, []byte("normal 1\n"), "", now)
|
total, added, seriesAdded, err := sl.append(slApp, []byte("normal 1\n"), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
testutil.Equals(t, 1, total)
|
assert.Equal(t, 1, total)
|
||||||
testutil.Equals(t, 1, added)
|
assert.Equal(t, 1, added)
|
||||||
testutil.Equals(t, 0, seriesAdded)
|
assert.Equal(t, 0, seriesAdded)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1680,9 +1681,9 @@ func TestTargetScraperScrapeOK(t *testing.T) {
|
||||||
var buf bytes.Buffer
|
var buf bytes.Buffer
|
||||||
|
|
||||||
contentType, err := ts.scrape(context.Background(), &buf)
|
contentType, err := ts.scrape(context.Background(), &buf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, "text/plain; version=0.0.4", contentType)
|
assert.Equal(t, "text/plain; version=0.0.4", contentType)
|
||||||
testutil.Equals(t, "metric_a 1\nmetric_b 2\n", buf.String())
|
assert.Equal(t, "metric_a 1\nmetric_b 2\n", buf.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTargetScrapeScrapeCancel(t *testing.T) {
|
func TestTargetScrapeScrapeCancel(t *testing.T) {
|
||||||
|
@ -1733,7 +1734,7 @@ func TestTargetScrapeScrapeCancel(t *testing.T) {
|
||||||
case <-time.After(5 * time.Second):
|
case <-time.After(5 * time.Second):
|
||||||
t.Fatalf("Scrape function did not return unexpectedly")
|
t.Fatalf("Scrape function did not return unexpectedly")
|
||||||
case err := <-errc:
|
case err := <-errc:
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
// If this is closed in a defer above the function the test server
|
// If this is closed in a defer above the function the test server
|
||||||
// doesn't terminate and the test doesn't complete.
|
// doesn't terminate and the test doesn't complete.
|
||||||
|
@ -1764,7 +1765,7 @@ func TestTargetScrapeScrapeNotFound(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = ts.scrape(context.Background(), ioutil.Discard)
|
_, err = ts.scrape(context.Background(), ioutil.Discard)
|
||||||
testutil.Assert(t, strings.Contains(err.Error(), "404"), "Expected \"404 NotFound\" error but got: %s", err)
|
assert.True(t, strings.Contains(err.Error(), "404"), "Expected \"404 NotFound\" error but got: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// testScraper implements the scraper interface and allows setting values
|
// testScraper implements the scraper interface and allows setting values
|
||||||
|
@ -1817,8 +1818,8 @@ func TestScrapeLoop_RespectTimestamps(t *testing.T) {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte(`metric_a{a="1",b="1"} 1 0`), "", now)
|
_, _, _, err := sl.append(slApp, []byte(`metric_a{a="1",b="1"} 1 0`), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
want := []sample{
|
want := []sample{
|
||||||
{
|
{
|
||||||
|
@ -1827,7 +1828,7 @@ func TestScrapeLoop_RespectTimestamps(t *testing.T) {
|
||||||
v: 1,
|
v: 1,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, capp.result, "Appended samples not as expected")
|
assert.Equal(t, want, capp.result, "Appended samples not as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoop_DiscardTimestamps(t *testing.T) {
|
func TestScrapeLoop_DiscardTimestamps(t *testing.T) {
|
||||||
|
@ -1850,8 +1851,8 @@ func TestScrapeLoop_DiscardTimestamps(t *testing.T) {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte(`metric_a{a="1",b="1"} 1 0`), "", now)
|
_, _, _, err := sl.append(slApp, []byte(`metric_a{a="1",b="1"} 1 0`), "", now)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
want := []sample{
|
want := []sample{
|
||||||
{
|
{
|
||||||
|
@ -1860,7 +1861,7 @@ func TestScrapeLoop_DiscardTimestamps(t *testing.T) {
|
||||||
v: 1,
|
v: 1,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Equals(t, want, capp.result, "Appended samples not as expected")
|
assert.Equal(t, want, capp.result, "Appended samples not as expected")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopDiscardDuplicateLabels(t *testing.T) {
|
func TestScrapeLoopDiscardDuplicateLabels(t *testing.T) {
|
||||||
|
@ -1883,27 +1884,27 @@ func TestScrapeLoopDiscardDuplicateLabels(t *testing.T) {
|
||||||
// We add a good and a bad metric to check that both are discarded.
|
// We add a good and a bad metric to check that both are discarded.
|
||||||
slApp := sl.appender(ctx)
|
slApp := sl.appender(ctx)
|
||||||
_, _, _, err := sl.append(slApp, []byte("test_metric{le=\"500\"} 1\ntest_metric{le=\"600\",le=\"700\"} 1\n"), "", time.Time{})
|
_, _, _, err := sl.append(slApp, []byte("test_metric{le=\"500\"} 1\ntest_metric{le=\"600\",le=\"700\"} 1\n"), "", time.Time{})
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Ok(t, slApp.Rollback())
|
assert.NoError(t, slApp.Rollback())
|
||||||
|
|
||||||
q, err := s.Querier(ctx, time.Time{}.UnixNano(), 0)
|
q, err := s.Querier(ctx, time.Time{}.UnixNano(), 0)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
series := q.Select(false, nil, labels.MustNewMatcher(labels.MatchRegexp, "__name__", ".*"))
|
series := q.Select(false, nil, labels.MustNewMatcher(labels.MatchRegexp, "__name__", ".*"))
|
||||||
testutil.Equals(t, false, series.Next(), "series found in tsdb")
|
assert.Equal(t, false, series.Next(), "series found in tsdb")
|
||||||
testutil.Ok(t, series.Err())
|
assert.NoError(t, series.Err())
|
||||||
|
|
||||||
// We add a good metric to check that it is recorded.
|
// We add a good metric to check that it is recorded.
|
||||||
slApp = sl.appender(ctx)
|
slApp = sl.appender(ctx)
|
||||||
_, _, _, err = sl.append(slApp, []byte("test_metric{le=\"500\"} 1\n"), "", time.Time{})
|
_, _, _, err = sl.append(slApp, []byte("test_metric{le=\"500\"} 1\n"), "", time.Time{})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
q, err = s.Querier(ctx, time.Time{}.UnixNano(), 0)
|
q, err = s.Querier(ctx, time.Time{}.UnixNano(), 0)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
series = q.Select(false, nil, labels.MustNewMatcher(labels.MatchEqual, "le", "500"))
|
series = q.Select(false, nil, labels.MustNewMatcher(labels.MatchEqual, "le", "500"))
|
||||||
testutil.Equals(t, true, series.Next(), "series not found in tsdb")
|
assert.Equal(t, true, series.Next(), "series not found in tsdb")
|
||||||
testutil.Ok(t, series.Err())
|
assert.NoError(t, series.Err())
|
||||||
testutil.Equals(t, false, series.Next(), "more than one series found in tsdb")
|
assert.Equal(t, false, series.Next(), "more than one series found in tsdb")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeLoopDiscardUnnamedMetrics(t *testing.T) {
|
func TestScrapeLoopDiscardUnnamedMetrics(t *testing.T) {
|
||||||
|
@ -1932,15 +1933,15 @@ func TestScrapeLoopDiscardUnnamedMetrics(t *testing.T) {
|
||||||
|
|
||||||
slApp := sl.appender(context.Background())
|
slApp := sl.appender(context.Background())
|
||||||
_, _, _, err := sl.append(slApp, []byte("nok 1\nnok2{drop=\"drop\"} 1\n"), "", time.Time{})
|
_, _, _, err := sl.append(slApp, []byte("nok 1\nnok2{drop=\"drop\"} 1\n"), "", time.Time{})
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Ok(t, slApp.Rollback())
|
assert.NoError(t, slApp.Rollback())
|
||||||
testutil.Equals(t, errNameLabelMandatory, err)
|
assert.Equal(t, errNameLabelMandatory, err)
|
||||||
|
|
||||||
q, err := s.Querier(ctx, time.Time{}.UnixNano(), 0)
|
q, err := s.Querier(ctx, time.Time{}.UnixNano(), 0)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
series := q.Select(false, nil, labels.MustNewMatcher(labels.MatchRegexp, "__name__", ".*"))
|
series := q.Select(false, nil, labels.MustNewMatcher(labels.MatchRegexp, "__name__", ".*"))
|
||||||
testutil.Equals(t, false, series.Next(), "series found in tsdb")
|
assert.Equal(t, false, series.Next(), "series found in tsdb")
|
||||||
testutil.Ok(t, series.Err())
|
assert.NoError(t, series.Err())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestReusableConfig(t *testing.T) {
|
func TestReusableConfig(t *testing.T) {
|
||||||
|
@ -1999,14 +2000,14 @@ func TestReusableConfig(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, m := range match {
|
for i, m := range match {
|
||||||
testutil.Equals(t, true, reusableCache(variants[m[0]], variants[m[1]]), "match test %d", i)
|
assert.Equal(t, true, reusableCache(variants[m[0]], variants[m[1]]), "match test %d", i)
|
||||||
testutil.Equals(t, true, reusableCache(variants[m[1]], variants[m[0]]), "match test %d", i)
|
assert.Equal(t, true, reusableCache(variants[m[1]], variants[m[0]]), "match test %d", i)
|
||||||
testutil.Equals(t, true, reusableCache(variants[m[1]], variants[m[1]]), "match test %d", i)
|
assert.Equal(t, true, reusableCache(variants[m[1]], variants[m[1]]), "match test %d", i)
|
||||||
testutil.Equals(t, true, reusableCache(variants[m[0]], variants[m[0]]), "match test %d", i)
|
assert.Equal(t, true, reusableCache(variants[m[0]], variants[m[0]]), "match test %d", i)
|
||||||
}
|
}
|
||||||
for i, m := range noMatch {
|
for i, m := range noMatch {
|
||||||
testutil.Equals(t, false, reusableCache(variants[m[0]], variants[m[1]]), "not match test %d", i)
|
assert.Equal(t, false, reusableCache(variants[m[0]], variants[m[1]]), "not match test %d", i)
|
||||||
testutil.Equals(t, false, reusableCache(variants[m[1]], variants[m[0]]), "not match test %d", i)
|
assert.Equal(t, false, reusableCache(variants[m[1]], variants[m[0]]), "not match test %d", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2117,15 +2118,15 @@ func TestReuseScrapeCache(t *testing.T) {
|
||||||
sp.reload(s.newConfig)
|
sp.reload(s.newConfig)
|
||||||
for fp, newCacheAddr := range cacheAddr(sp) {
|
for fp, newCacheAddr := range cacheAddr(sp) {
|
||||||
if s.keep {
|
if s.keep {
|
||||||
testutil.Assert(t, initCacheAddr[fp] == newCacheAddr, "step %d: old cache and new cache are not the same", i)
|
assert.True(t, initCacheAddr[fp] == newCacheAddr, "step %d: old cache and new cache are not the same", i)
|
||||||
} else {
|
} else {
|
||||||
testutil.Assert(t, initCacheAddr[fp] != newCacheAddr, "step %d: old cache and new cache are the same", i)
|
assert.True(t, initCacheAddr[fp] != newCacheAddr, "step %d: old cache and new cache are the same", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
initCacheAddr = cacheAddr(sp)
|
initCacheAddr = cacheAddr(sp)
|
||||||
sp.reload(s.newConfig)
|
sp.reload(s.newConfig)
|
||||||
for fp, newCacheAddr := range cacheAddr(sp) {
|
for fp, newCacheAddr := range cacheAddr(sp) {
|
||||||
testutil.Assert(t, initCacheAddr[fp] == newCacheAddr, "step %d: reloading the exact config invalidates the cache", i)
|
assert.True(t, initCacheAddr[fp] == newCacheAddr, "step %d: reloading the exact config invalidates the cache", i)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2149,8 +2150,8 @@ func TestScrapeAddFast(t *testing.T) {
|
||||||
|
|
||||||
slApp := sl.appender(ctx)
|
slApp := sl.appender(ctx)
|
||||||
_, _, _, err := sl.append(slApp, []byte("up 1\n"), "", time.Time{})
|
_, _, _, err := sl.append(slApp, []byte("up 1\n"), "", time.Time{})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
|
|
||||||
// Poison the cache. There is just one entry, and one series in the
|
// Poison the cache. There is just one entry, and one series in the
|
||||||
// storage. Changing the ref will create a 'not found' error.
|
// storage. Changing the ref will create a 'not found' error.
|
||||||
|
@ -2160,8 +2161,8 @@ func TestScrapeAddFast(t *testing.T) {
|
||||||
|
|
||||||
slApp = sl.appender(ctx)
|
slApp = sl.appender(ctx)
|
||||||
_, _, _, err = sl.append(slApp, []byte("up 1\n"), "", time.Time{}.Add(time.Second))
|
_, _, _, err = sl.append(slApp, []byte("up 1\n"), "", time.Time{}.Add(time.Second))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Ok(t, slApp.Commit())
|
assert.NoError(t, slApp.Commit())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestReuseCacheRace(t *testing.T) {
|
func TestReuseCacheRace(t *testing.T) {
|
||||||
|
@ -2205,7 +2206,7 @@ func TestCheckAddError(t *testing.T) {
|
||||||
var appErrs appendErrors
|
var appErrs appendErrors
|
||||||
sl := scrapeLoop{l: log.NewNopLogger()}
|
sl := scrapeLoop{l: log.NewNopLogger()}
|
||||||
sl.checkAddError(nil, nil, nil, storage.ErrOutOfOrderSample, nil, &appErrs)
|
sl.checkAddError(nil, nil, nil, storage.ErrOutOfOrderSample, nil, &appErrs)
|
||||||
testutil.Equals(t, 1, appErrs.numOutOfOrder)
|
assert.Equal(t, 1, appErrs.numOutOfOrder)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestScrapeReportSingleAppender(t *testing.T) {
|
func TestScrapeReportSingleAppender(t *testing.T) {
|
||||||
|
@ -2248,7 +2249,7 @@ func TestScrapeReportSingleAppender(t *testing.T) {
|
||||||
start := time.Now()
|
start := time.Now()
|
||||||
for time.Since(start) < 3*time.Second {
|
for time.Since(start) < 3*time.Second {
|
||||||
q, err := s.Querier(ctx, time.Time{}.UnixNano(), time.Now().UnixNano())
|
q, err := s.Querier(ctx, time.Time{}.UnixNano(), time.Now().UnixNano())
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
series := q.Select(false, nil, labels.MustNewMatcher(labels.MatchRegexp, "__name__", ".+"))
|
series := q.Select(false, nil, labels.MustNewMatcher(labels.MatchRegexp, "__name__", ".+"))
|
||||||
|
|
||||||
c := 0
|
c := 0
|
||||||
|
@ -2259,7 +2260,7 @@ func TestScrapeReportSingleAppender(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, 0, c%9, "Appended samples not as expected: %d", c)
|
assert.Equal(t, 0, c%9, "Appended samples not as expected: %d", c)
|
||||||
q.Close()
|
q.Close()
|
||||||
}
|
}
|
||||||
cancel()
|
cancel()
|
||||||
|
|
|
@ -21,14 +21,14 @@ import (
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"net/url"
|
"net/url"
|
||||||
"reflect"
|
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/common/model"
|
|
||||||
|
|
||||||
config_util "github.com/prometheus/common/config"
|
config_util "github.com/prometheus/common/config"
|
||||||
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -40,9 +40,7 @@ func TestTargetLabels(t *testing.T) {
|
||||||
target := newTestTarget("example.com:80", 0, labels.FromStrings("job", "some_job", "foo", "bar"))
|
target := newTestTarget("example.com:80", 0, labels.FromStrings("job", "some_job", "foo", "bar"))
|
||||||
want := labels.FromStrings(model.JobLabel, "some_job", "foo", "bar")
|
want := labels.FromStrings(model.JobLabel, "some_job", "foo", "bar")
|
||||||
got := target.Labels()
|
got := target.Labels()
|
||||||
if !reflect.DeepEqual(want, got) {
|
assert.Equal(t, want, got)
|
||||||
t.Errorf("want base labels %v, got %v", want, got)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTargetOffset(t *testing.T) {
|
func TestTargetOffset(t *testing.T) {
|
||||||
|
@ -113,16 +111,14 @@ func TestTargetURL(t *testing.T) {
|
||||||
"cde": []string{"huu"},
|
"cde": []string{"huu"},
|
||||||
"xyz": []string{"hoo"},
|
"xyz": []string{"hoo"},
|
||||||
}
|
}
|
||||||
expectedURL := url.URL{
|
expectedURL := &url.URL{
|
||||||
Scheme: "https",
|
Scheme: "https",
|
||||||
Host: "example.com:1234",
|
Host: "example.com:1234",
|
||||||
Path: "/metricz",
|
Path: "/metricz",
|
||||||
RawQuery: expectedParams.Encode(),
|
RawQuery: expectedParams.Encode(),
|
||||||
}
|
}
|
||||||
|
|
||||||
if u := target.URL(); !reflect.DeepEqual(u.String(), expectedURL.String()) {
|
assert.Equal(t, expectedURL, target.URL())
|
||||||
t.Fatalf("Expected URL %q, but got %q", expectedURL.String(), u.String())
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func newTestTarget(targetURL string, deadline time.Duration, lbls labels.Labels) *Target {
|
func newTestTarget(targetURL string, deadline time.Duration, lbls labels.Labels) *Target {
|
||||||
|
|
|
@ -17,7 +17,7 @@ import (
|
||||||
"math/rand"
|
"math/rand"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSampleRing(t *testing.T) {
|
func TestSampleRing(t *testing.T) {
|
||||||
|
@ -77,9 +77,9 @@ func TestSampleRing(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if found {
|
if found {
|
||||||
testutil.Assert(t, sold.t >= s.t-c.delta, "%d: unexpected sample %d in buffer; buffer %v", i, sold.t, buffered)
|
assert.True(t, sold.t >= s.t-c.delta, "%d: unexpected sample %d in buffer; buffer %v", i, sold.t, buffered)
|
||||||
} else {
|
} else {
|
||||||
testutil.Assert(t, sold.t < s.t-c.delta, "%d: expected sample %d to be in buffer but was not; buffer %v", i, sold.t, buffered)
|
assert.True(t, sold.t < s.t-c.delta, "%d: expected sample %d to be in buffer but was not; buffer %v", i, sold.t, buffered)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -96,12 +96,12 @@ func TestBufferedSeriesIterator(t *testing.T) {
|
||||||
t, v := bit.At()
|
t, v := bit.At()
|
||||||
b = append(b, sample{t: t, v: v})
|
b = append(b, sample{t: t, v: v})
|
||||||
}
|
}
|
||||||
testutil.Equals(t, exp, b, "buffer mismatch")
|
assert.Equal(t, exp, b, "buffer mismatch")
|
||||||
}
|
}
|
||||||
sampleEq := func(ets int64, ev float64) {
|
sampleEq := func(ets int64, ev float64) {
|
||||||
ts, v := it.Values()
|
ts, v := it.Values()
|
||||||
testutil.Equals(t, ets, ts, "timestamp mismatch")
|
assert.Equal(t, ets, ts, "timestamp mismatch")
|
||||||
testutil.Equals(t, ev, v, "value mismatch")
|
assert.Equal(t, ev, v, "value mismatch")
|
||||||
}
|
}
|
||||||
|
|
||||||
it = NewBufferIterator(NewListSeriesIterator(samples{
|
it = NewBufferIterator(NewListSeriesIterator(samples{
|
||||||
|
@ -115,29 +115,29 @@ func TestBufferedSeriesIterator(t *testing.T) {
|
||||||
sample{t: 101, v: 10},
|
sample{t: 101, v: 10},
|
||||||
}), 2)
|
}), 2)
|
||||||
|
|
||||||
testutil.Assert(t, it.Seek(-123), "seek failed")
|
assert.True(t, it.Seek(-123), "seek failed")
|
||||||
sampleEq(1, 2)
|
sampleEq(1, 2)
|
||||||
bufferEq(nil)
|
bufferEq(nil)
|
||||||
|
|
||||||
testutil.Assert(t, it.Next(), "next failed")
|
assert.True(t, it.Next(), "next failed")
|
||||||
sampleEq(2, 3)
|
sampleEq(2, 3)
|
||||||
bufferEq([]sample{{t: 1, v: 2}})
|
bufferEq([]sample{{t: 1, v: 2}})
|
||||||
|
|
||||||
testutil.Assert(t, it.Next(), "next failed")
|
assert.True(t, it.Next(), "next failed")
|
||||||
testutil.Assert(t, it.Next(), "next failed")
|
assert.True(t, it.Next(), "next failed")
|
||||||
testutil.Assert(t, it.Next(), "next failed")
|
assert.True(t, it.Next(), "next failed")
|
||||||
sampleEq(5, 6)
|
sampleEq(5, 6)
|
||||||
bufferEq([]sample{{t: 2, v: 3}, {t: 3, v: 4}, {t: 4, v: 5}})
|
bufferEq([]sample{{t: 2, v: 3}, {t: 3, v: 4}, {t: 4, v: 5}})
|
||||||
|
|
||||||
testutil.Assert(t, it.Seek(5), "seek failed")
|
assert.True(t, it.Seek(5), "seek failed")
|
||||||
sampleEq(5, 6)
|
sampleEq(5, 6)
|
||||||
bufferEq([]sample{{t: 2, v: 3}, {t: 3, v: 4}, {t: 4, v: 5}})
|
bufferEq([]sample{{t: 2, v: 3}, {t: 3, v: 4}, {t: 4, v: 5}})
|
||||||
|
|
||||||
testutil.Assert(t, it.Seek(101), "seek failed")
|
assert.True(t, it.Seek(101), "seek failed")
|
||||||
sampleEq(101, 10)
|
sampleEq(101, 10)
|
||||||
bufferEq([]sample{{t: 99, v: 8}, {t: 100, v: 9}})
|
bufferEq([]sample{{t: 99, v: 8}, {t: 100, v: 9}})
|
||||||
|
|
||||||
testutil.Assert(t, !it.Next(), "next succeeded unexpectedly")
|
assert.True(t, !it.Next(), "next succeeded unexpectedly")
|
||||||
}
|
}
|
||||||
|
|
||||||
// At() should not be called once Next() returns false.
|
// At() should not be called once Next() returns false.
|
||||||
|
@ -147,7 +147,7 @@ func TestBufferedSeriesIteratorNoBadAt(t *testing.T) {
|
||||||
m := &mockSeriesIterator{
|
m := &mockSeriesIterator{
|
||||||
seek: func(int64) bool { return false },
|
seek: func(int64) bool { return false },
|
||||||
at: func() (int64, float64) {
|
at: func() (int64, float64) {
|
||||||
testutil.Assert(t, !done, "unexpectedly done")
|
assert.True(t, !done, "unexpectedly done")
|
||||||
done = true
|
done = true
|
||||||
return 0, 0
|
return 0, 0
|
||||||
},
|
},
|
||||||
|
@ -171,7 +171,7 @@ func BenchmarkBufferedSeriesIterator(b *testing.B) {
|
||||||
for it.Next() {
|
for it.Next() {
|
||||||
// scan everything
|
// scan everything
|
||||||
}
|
}
|
||||||
testutil.Ok(b, it.Err())
|
assert.NoError(b, it.Err())
|
||||||
}
|
}
|
||||||
|
|
||||||
type mockSeriesIterator struct {
|
type mockSeriesIterator struct {
|
||||||
|
|
|
@ -19,6 +19,7 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
tsdb_errors "github.com/prometheus/prometheus/tsdb/errors"
|
tsdb_errors "github.com/prometheus/prometheus/tsdb/errors"
|
||||||
)
|
)
|
||||||
|
|
|
@ -19,11 +19,11 @@ import (
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/util/teststorage"
|
"github.com/prometheus/prometheus/util/teststorage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestFanout_SelectSorted(t *testing.T) {
|
func TestFanout_SelectSorted(t *testing.T) {
|
||||||
|
@ -43,7 +43,7 @@ func TestFanout_SelectSorted(t *testing.T) {
|
||||||
app1.Add(inputLabel, 2000, 2)
|
app1.Add(inputLabel, 2000, 2)
|
||||||
inputTotalSize++
|
inputTotalSize++
|
||||||
err := app1.Commit()
|
err := app1.Commit()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
remoteStorage1 := teststorage.New(t)
|
remoteStorage1 := teststorage.New(t)
|
||||||
defer remoteStorage1.Close()
|
defer remoteStorage1.Close()
|
||||||
|
@ -55,7 +55,7 @@ func TestFanout_SelectSorted(t *testing.T) {
|
||||||
app2.Add(inputLabel, 5000, 5)
|
app2.Add(inputLabel, 5000, 5)
|
||||||
inputTotalSize++
|
inputTotalSize++
|
||||||
err = app2.Commit()
|
err = app2.Commit()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
remoteStorage2 := teststorage.New(t)
|
remoteStorage2 := teststorage.New(t)
|
||||||
defer remoteStorage2.Close()
|
defer remoteStorage2.Close()
|
||||||
|
@ -69,17 +69,17 @@ func TestFanout_SelectSorted(t *testing.T) {
|
||||||
inputTotalSize++
|
inputTotalSize++
|
||||||
|
|
||||||
err = app3.Commit()
|
err = app3.Commit()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
fanoutStorage := storage.NewFanout(nil, priStorage, remoteStorage1, remoteStorage2)
|
fanoutStorage := storage.NewFanout(nil, priStorage, remoteStorage1, remoteStorage2)
|
||||||
|
|
||||||
t.Run("querier", func(t *testing.T) {
|
t.Run("querier", func(t *testing.T) {
|
||||||
querier, err := fanoutStorage.Querier(context.Background(), 0, 8000)
|
querier, err := fanoutStorage.Querier(context.Background(), 0, 8000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "a")
|
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "a")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
seriesSet := querier.Select(true, nil, matcher)
|
seriesSet := querier.Select(true, nil, matcher)
|
||||||
|
|
||||||
|
@ -96,16 +96,16 @@ func TestFanout_SelectSorted(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Equals(t, labelsResult, outputLabel)
|
assert.Equal(t, labelsResult, outputLabel)
|
||||||
testutil.Equals(t, inputTotalSize, len(result))
|
assert.Equal(t, inputTotalSize, len(result))
|
||||||
})
|
})
|
||||||
t.Run("chunk querier", func(t *testing.T) {
|
t.Run("chunk querier", func(t *testing.T) {
|
||||||
querier, err := fanoutStorage.ChunkQuerier(ctx, 0, 8000)
|
querier, err := fanoutStorage.ChunkQuerier(ctx, 0, 8000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "a")
|
matcher, err := labels.NewMatcher(labels.MatchEqual, model.MetricNameLabel, "a")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
seriesSet := storage.NewSeriesSetFromChunkSeriesSet(querier.Select(true, nil, matcher))
|
seriesSet := storage.NewSeriesSetFromChunkSeriesSet(querier.Select(true, nil, matcher))
|
||||||
|
|
||||||
|
@ -122,9 +122,9 @@ func TestFanout_SelectSorted(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, seriesSet.Err())
|
assert.NoError(t, seriesSet.Err())
|
||||||
testutil.Equals(t, labelsResult, outputLabel)
|
assert.Equal(t, labelsResult, outputLabel)
|
||||||
testutil.Equals(t, inputTotalSize, len(result))
|
assert.Equal(t, inputTotalSize, len(result))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -157,7 +157,7 @@ func TestFanoutErrors(t *testing.T) {
|
||||||
|
|
||||||
t.Run("samples", func(t *testing.T) {
|
t.Run("samples", func(t *testing.T) {
|
||||||
querier, err := fanoutStorage.Querier(context.Background(), 0, 8000)
|
querier, err := fanoutStorage.Querier(context.Background(), 0, 8000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher := labels.MustNewMatcher(labels.MatchEqual, "a", "b")
|
matcher := labels.MustNewMatcher(labels.MatchEqual, "a", "b")
|
||||||
|
@ -169,20 +169,20 @@ func TestFanoutErrors(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if tc.err != nil {
|
if tc.err != nil {
|
||||||
testutil.NotOk(t, ss.Err())
|
assert.Error(t, ss.Err())
|
||||||
testutil.Equals(t, tc.err.Error(), ss.Err().Error())
|
assert.Equal(t, tc.err.Error(), ss.Err().Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
if tc.warning != nil {
|
if tc.warning != nil {
|
||||||
testutil.Assert(t, len(ss.Warnings()) > 0, "warnings expected")
|
assert.True(t, len(ss.Warnings()) > 0, "warnings expected")
|
||||||
testutil.NotOk(t, ss.Warnings()[0])
|
assert.Error(t, ss.Warnings()[0])
|
||||||
testutil.Equals(t, tc.warning.Error(), ss.Warnings()[0].Error())
|
assert.Equal(t, tc.warning.Error(), ss.Warnings()[0].Error())
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
t.Run("chunks", func(t *testing.T) {
|
t.Run("chunks", func(t *testing.T) {
|
||||||
t.Skip("enable once TestStorage and TSDB implements ChunkQuerier")
|
t.Skip("enable once TestStorage and TSDB implements ChunkQuerier")
|
||||||
querier, err := fanoutStorage.ChunkQuerier(context.Background(), 0, 8000)
|
querier, err := fanoutStorage.ChunkQuerier(context.Background(), 0, 8000)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer querier.Close()
|
defer querier.Close()
|
||||||
|
|
||||||
matcher := labels.MustNewMatcher(labels.MatchEqual, "a", "b")
|
matcher := labels.MustNewMatcher(labels.MatchEqual, "a", "b")
|
||||||
|
@ -194,14 +194,14 @@ func TestFanoutErrors(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if tc.err != nil {
|
if tc.err != nil {
|
||||||
testutil.NotOk(t, ss.Err())
|
assert.Error(t, ss.Err())
|
||||||
testutil.Equals(t, tc.err.Error(), ss.Err().Error())
|
assert.Equal(t, tc.err.Error(), ss.Err().Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
if tc.warning != nil {
|
if tc.warning != nil {
|
||||||
testutil.Assert(t, len(ss.Warnings()) > 0, "warnings expected")
|
assert.True(t, len(ss.Warnings()) > 0, "warnings expected")
|
||||||
testutil.NotOk(t, ss.Warnings()[0])
|
assert.Error(t, ss.Warnings()[0])
|
||||||
testutil.Equals(t, tc.warning.Error(), ss.Warnings()[0].Error())
|
assert.Equal(t, tc.warning.Error(), ss.Warnings()[0].Error())
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@ import (
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
||||||
"github.com/prometheus/prometheus/tsdb/chunks"
|
"github.com/prometheus/prometheus/tsdb/chunks"
|
||||||
|
|
|
@ -21,11 +21,11 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
||||||
"github.com/prometheus/prometheus/tsdb/tsdbutil"
|
"github.com/prometheus/prometheus/tsdb/tsdbutil"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestMergeQuerierWithChainMerger(t *testing.T) {
|
func TestMergeQuerierWithChainMerger(t *testing.T) {
|
||||||
|
@ -194,19 +194,19 @@ func TestMergeQuerierWithChainMerger(t *testing.T) {
|
||||||
for mergedQuerier.Next() {
|
for mergedQuerier.Next() {
|
||||||
mergedSeries = append(mergedSeries, mergedQuerier.At())
|
mergedSeries = append(mergedSeries, mergedQuerier.At())
|
||||||
}
|
}
|
||||||
testutil.Ok(t, mergedQuerier.Err())
|
assert.NoError(t, mergedQuerier.Err())
|
||||||
|
|
||||||
for _, actualSeries := range mergedSeries {
|
for _, actualSeries := range mergedSeries {
|
||||||
testutil.Assert(t, tc.expected.Next(), "Expected Next() to be true")
|
assert.True(t, tc.expected.Next(), "Expected Next() to be true")
|
||||||
expectedSeries := tc.expected.At()
|
expectedSeries := tc.expected.At()
|
||||||
testutil.Equals(t, expectedSeries.Labels(), actualSeries.Labels())
|
assert.Equal(t, expectedSeries.Labels(), actualSeries.Labels())
|
||||||
|
|
||||||
expSmpl, expErr := ExpandSamples(expectedSeries.Iterator(), nil)
|
expSmpl, expErr := ExpandSamples(expectedSeries.Iterator(), nil)
|
||||||
actSmpl, actErr := ExpandSamples(actualSeries.Iterator(), nil)
|
actSmpl, actErr := ExpandSamples(actualSeries.Iterator(), nil)
|
||||||
testutil.Equals(t, expErr, actErr)
|
assert.Equal(t, expErr, actErr)
|
||||||
testutil.Equals(t, expSmpl, actSmpl)
|
assert.Equal(t, expSmpl, actSmpl)
|
||||||
}
|
}
|
||||||
testutil.Assert(t, !tc.expected.Next(), "Expected Next() to be false")
|
assert.True(t, !tc.expected.Next(), "Expected Next() to be false")
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -364,19 +364,19 @@ func TestMergeChunkQuerierWithNoVerticalChunkSeriesMerger(t *testing.T) {
|
||||||
|
|
||||||
merged := NewMergeChunkQuerier([]ChunkQuerier{p}, qs, NewCompactingChunkSeriesMerger(nil)).Select(false, nil)
|
merged := NewMergeChunkQuerier([]ChunkQuerier{p}, qs, NewCompactingChunkSeriesMerger(nil)).Select(false, nil)
|
||||||
for merged.Next() {
|
for merged.Next() {
|
||||||
testutil.Assert(t, tc.expected.Next(), "Expected Next() to be true")
|
assert.True(t, tc.expected.Next(), "Expected Next() to be true")
|
||||||
actualSeries := merged.At()
|
actualSeries := merged.At()
|
||||||
expectedSeries := tc.expected.At()
|
expectedSeries := tc.expected.At()
|
||||||
testutil.Equals(t, expectedSeries.Labels(), actualSeries.Labels())
|
assert.Equal(t, expectedSeries.Labels(), actualSeries.Labels())
|
||||||
|
|
||||||
expChks, expErr := ExpandChunks(expectedSeries.Iterator())
|
expChks, expErr := ExpandChunks(expectedSeries.Iterator())
|
||||||
actChks, actErr := ExpandChunks(actualSeries.Iterator())
|
actChks, actErr := ExpandChunks(actualSeries.Iterator())
|
||||||
testutil.Equals(t, expErr, actErr)
|
assert.Equal(t, expErr, actErr)
|
||||||
testutil.Equals(t, expChks, actChks)
|
assert.Equal(t, expChks, actChks)
|
||||||
|
|
||||||
}
|
}
|
||||||
testutil.Ok(t, merged.Err())
|
assert.NoError(t, merged.Err())
|
||||||
testutil.Assert(t, !tc.expected.Next(), "Expected Next() to be false")
|
assert.True(t, !tc.expected.Next(), "Expected Next() to be false")
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -468,12 +468,12 @@ func TestCompactingChunkSeriesMerger(t *testing.T) {
|
||||||
} {
|
} {
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
t.Run(tc.name, func(t *testing.T) {
|
||||||
merged := m(tc.input...)
|
merged := m(tc.input...)
|
||||||
testutil.Equals(t, tc.expected.Labels(), merged.Labels())
|
assert.Equal(t, tc.expected.Labels(), merged.Labels())
|
||||||
actChks, actErr := ExpandChunks(merged.Iterator())
|
actChks, actErr := ExpandChunks(merged.Iterator())
|
||||||
expChks, expErr := ExpandChunks(tc.expected.Iterator())
|
expChks, expErr := ExpandChunks(tc.expected.Iterator())
|
||||||
|
|
||||||
testutil.Equals(t, expErr, actErr)
|
assert.Equal(t, expErr, actErr)
|
||||||
testutil.Equals(t, expChks, actChks)
|
assert.Equal(t, expChks, actChks)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -612,8 +612,8 @@ func TestChainSampleIterator(t *testing.T) {
|
||||||
} {
|
} {
|
||||||
merged := newChainSampleIterator(tc.input)
|
merged := newChainSampleIterator(tc.input)
|
||||||
actual, err := ExpandSamples(merged, nil)
|
actual, err := ExpandSamples(merged, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, tc.expected, actual)
|
assert.Equal(t, tc.expected, actual)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -655,9 +655,9 @@ func TestChainSampleIteratorSeek(t *testing.T) {
|
||||||
actual = append(actual, sample{t, v})
|
actual = append(actual, sample{t, v})
|
||||||
}
|
}
|
||||||
s, err := ExpandSamples(merged, nil)
|
s, err := ExpandSamples(merged, nil)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
actual = append(actual, s...)
|
actual = append(actual, s...)
|
||||||
testutil.Equals(t, tc.expected, actual)
|
assert.Equal(t, tc.expected, actual)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -689,7 +689,7 @@ func benchmarkDrain(seriesSet SeriesSet, b *testing.B) {
|
||||||
for n := 0; n < b.N; n++ {
|
for n := 0; n < b.N; n++ {
|
||||||
for seriesSet.Next() {
|
for seriesSet.Next() {
|
||||||
result, err = ExpandSamples(seriesSet.At().Iterator(), nil)
|
result, err = ExpandSamples(seriesSet.At().Iterator(), nil)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -789,9 +789,9 @@ func unwrapMockGenericQuerier(t *testing.T, qr genericQuerier) *mockGenericQueri
|
||||||
m, ok := qr.(*mockGenericQuerier)
|
m, ok := qr.(*mockGenericQuerier)
|
||||||
if !ok {
|
if !ok {
|
||||||
s, ok := qr.(*secondaryQuerier)
|
s, ok := qr.(*secondaryQuerier)
|
||||||
testutil.Assert(t, ok, "expected secondaryQuerier got something else")
|
assert.True(t, ok, "expected secondaryQuerier got something else")
|
||||||
m, ok = s.genericQuerier.(*mockGenericQuerier)
|
m, ok = s.genericQuerier.(*mockGenericQuerier)
|
||||||
testutil.Assert(t, ok, "expected mockGenericQuerier got something else")
|
assert.True(t, ok, "expected mockGenericQuerier got something else")
|
||||||
}
|
}
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
|
@ -922,10 +922,10 @@ func TestMergeGenericQuerierWithSecondaries_ErrorHandling(t *testing.T) {
|
||||||
for res.Next() {
|
for res.Next() {
|
||||||
lbls = append(lbls, res.At().Labels())
|
lbls = append(lbls, res.At().Labels())
|
||||||
}
|
}
|
||||||
testutil.Equals(t, tcase.expectedWarnings[0], res.Warnings())
|
assert.Equal(t, tcase.expectedWarnings[0], res.Warnings())
|
||||||
testutil.Equals(t, tcase.expectedErrs[0], res.Err())
|
assert.Equal(t, tcase.expectedErrs[0], res.Err())
|
||||||
testutil.Assert(t, errors.Is(res.Err(), tcase.expectedErrs[0]), "expected error doesn't match")
|
assert.True(t, errors.Is(res.Err(), tcase.expectedErrs[0]), "expected error doesn't match")
|
||||||
testutil.Equals(t, tcase.expectedSelectsSeries, lbls)
|
assert.Equal(t, tcase.expectedSelectsSeries, lbls)
|
||||||
|
|
||||||
for _, qr := range q.queriers {
|
for _, qr := range q.queriers {
|
||||||
m := unwrapMockGenericQuerier(t, qr)
|
m := unwrapMockGenericQuerier(t, qr)
|
||||||
|
@ -934,14 +934,14 @@ func TestMergeGenericQuerierWithSecondaries_ErrorHandling(t *testing.T) {
|
||||||
if len(q.queriers) == 1 {
|
if len(q.queriers) == 1 {
|
||||||
exp[0] = false
|
exp[0] = false
|
||||||
}
|
}
|
||||||
testutil.Equals(t, exp, m.sortedSeriesRequested)
|
assert.Equal(t, exp, m.sortedSeriesRequested)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
t.Run("LabelNames", func(t *testing.T) {
|
t.Run("LabelNames", func(t *testing.T) {
|
||||||
res, w, err := q.LabelNames()
|
res, w, err := q.LabelNames()
|
||||||
testutil.Equals(t, tcase.expectedWarnings[1], w)
|
assert.Equal(t, tcase.expectedWarnings[1], w)
|
||||||
testutil.Assert(t, errors.Is(err, tcase.expectedErrs[1]), "expected error doesn't match")
|
assert.True(t, errors.Is(err, tcase.expectedErrs[1]), "expected error doesn't match")
|
||||||
testutil.Equals(t, tcase.expectedLabels, res)
|
assert.Equal(t, tcase.expectedLabels, res)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
|
@ -949,14 +949,14 @@ func TestMergeGenericQuerierWithSecondaries_ErrorHandling(t *testing.T) {
|
||||||
for _, qr := range q.queriers {
|
for _, qr := range q.queriers {
|
||||||
m := unwrapMockGenericQuerier(t, qr)
|
m := unwrapMockGenericQuerier(t, qr)
|
||||||
|
|
||||||
testutil.Equals(t, 1, m.labelNamesCalls)
|
assert.Equal(t, 1, m.labelNamesCalls)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
t.Run("LabelValues", func(t *testing.T) {
|
t.Run("LabelValues", func(t *testing.T) {
|
||||||
res, w, err := q.LabelValues("test")
|
res, w, err := q.LabelValues("test")
|
||||||
testutil.Equals(t, tcase.expectedWarnings[2], w)
|
assert.Equal(t, tcase.expectedWarnings[2], w)
|
||||||
testutil.Assert(t, errors.Is(err, tcase.expectedErrs[2]), "expected error doesn't match")
|
assert.True(t, errors.Is(err, tcase.expectedErrs[2]), "expected error doesn't match")
|
||||||
testutil.Equals(t, tcase.expectedLabels, res)
|
assert.Equal(t, tcase.expectedLabels, res)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
|
@ -964,7 +964,7 @@ func TestMergeGenericQuerierWithSecondaries_ErrorHandling(t *testing.T) {
|
||||||
for _, qr := range q.queriers {
|
for _, qr := range q.queriers {
|
||||||
m := unwrapMockGenericQuerier(t, qr)
|
m := unwrapMockGenericQuerier(t, qr)
|
||||||
|
|
||||||
testutil.Equals(t, []string{"test"}, m.labelNamesRequested)
|
assert.Equal(t, []string{"test"}, m.labelNamesRequested)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -17,7 +17,7 @@ import (
|
||||||
"io"
|
"io"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
type mockedFlusher struct {
|
type mockedFlusher struct {
|
||||||
|
@ -45,48 +45,48 @@ func TestChunkedReaderCanReadFromChunkedWriter(t *testing.T) {
|
||||||
|
|
||||||
for _, msg := range msgs {
|
for _, msg := range msgs {
|
||||||
n, err := w.Write(msg)
|
n, err := w.Write(msg)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, len(msg), n)
|
assert.Equal(t, len(msg), n)
|
||||||
}
|
}
|
||||||
|
|
||||||
i := 0
|
i := 0
|
||||||
for ; i < 4; i++ {
|
for ; i < 4; i++ {
|
||||||
msg, err := r.Next()
|
msg, err := r.Next()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, i < len(msgs), "more messages then expected")
|
assert.True(t, i < len(msgs), "more messages then expected")
|
||||||
testutil.Equals(t, msgs[i], msg)
|
assert.Equal(t, msgs[i], msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Empty byte slice is skipped.
|
// Empty byte slice is skipped.
|
||||||
i++
|
i++
|
||||||
|
|
||||||
msg, err := r.Next()
|
msg, err := r.Next()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Assert(t, i < len(msgs), "more messages then expected")
|
assert.True(t, i < len(msgs), "more messages then expected")
|
||||||
testutil.Equals(t, msgs[i], msg)
|
assert.Equal(t, msgs[i], msg)
|
||||||
|
|
||||||
_, err = r.Next()
|
_, err = r.Next()
|
||||||
testutil.NotOk(t, err, "expected io.EOF")
|
assert.Error(t, err, "expected io.EOF")
|
||||||
testutil.Equals(t, io.EOF, err)
|
assert.Equal(t, io.EOF, err)
|
||||||
|
|
||||||
testutil.Equals(t, 5, f.flushed)
|
assert.Equal(t, 5, f.flushed)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestChunkedReader_Overflow(t *testing.T) {
|
func TestChunkedReader_Overflow(t *testing.T) {
|
||||||
b := &bytes.Buffer{}
|
b := &bytes.Buffer{}
|
||||||
_, err := NewChunkedWriter(b, &mockedFlusher{}).Write([]byte("twelve bytes"))
|
_, err := NewChunkedWriter(b, &mockedFlusher{}).Write([]byte("twelve bytes"))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
b2 := make([]byte, 12)
|
b2 := make([]byte, 12)
|
||||||
copy(b2, b.Bytes())
|
copy(b2, b.Bytes())
|
||||||
|
|
||||||
ret, err := NewChunkedReader(b, 12, nil).Next()
|
ret, err := NewChunkedReader(b, 12, nil).Next()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, "twelve bytes", string(ret))
|
assert.Equal(t, "twelve bytes", string(ret))
|
||||||
|
|
||||||
_, err = NewChunkedReader(bytes.NewReader(b2), 11, nil).Next()
|
_, err = NewChunkedReader(bytes.NewReader(b2), 11, nil).Next()
|
||||||
testutil.NotOk(t, err, "expect exceed limit error")
|
assert.Error(t, err, "expect exceed limit error")
|
||||||
testutil.Equals(t, "chunkedReader: message size exceeded the limit 11 bytes; got: 12 bytes", err.Error())
|
assert.Equal(t, "chunkedReader: message size exceeded the limit 11 bytes; got: 12 bytes", err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestChunkedReader_CorruptedFrame(t *testing.T) {
|
func TestChunkedReader_CorruptedFrame(t *testing.T) {
|
||||||
|
@ -94,13 +94,13 @@ func TestChunkedReader_CorruptedFrame(t *testing.T) {
|
||||||
w := NewChunkedWriter(b, &mockedFlusher{})
|
w := NewChunkedWriter(b, &mockedFlusher{})
|
||||||
|
|
||||||
n, err := w.Write([]byte("test1"))
|
n, err := w.Write([]byte("test1"))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 5, n)
|
assert.Equal(t, 5, n)
|
||||||
|
|
||||||
bs := b.Bytes()
|
bs := b.Bytes()
|
||||||
bs[9] = 1 // Malform the frame by changing one byte.
|
bs[9] = 1 // Malform the frame by changing one byte.
|
||||||
|
|
||||||
_, err = NewChunkedReader(bytes.NewReader(bs), 20, nil).Next()
|
_, err = NewChunkedReader(bytes.NewReader(bs), 20, nil).Next()
|
||||||
testutil.NotOk(t, err, "expected malformed frame")
|
assert.Error(t, err, "expected malformed frame")
|
||||||
testutil.Equals(t, "chunkedReader: corrupted frame; checksum mismatch", err.Error())
|
assert.Equal(t, "chunkedReader: corrupted frame; checksum mismatch", err.Error())
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ import (
|
||||||
|
|
||||||
"github.com/gogo/protobuf/proto"
|
"github.com/gogo/protobuf/proto"
|
||||||
"github.com/golang/snappy"
|
"github.com/golang/snappy"
|
||||||
|
"github.com/opentracing-contrib/go-stdlib/nethttp"
|
||||||
"github.com/opentracing/opentracing-go"
|
"github.com/opentracing/opentracing-go"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
@ -34,7 +35,6 @@ import (
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/common/version"
|
"github.com/prometheus/common/version"
|
||||||
|
|
||||||
"github.com/opentracing-contrib/go-stdlib/nethttp"
|
|
||||||
"github.com/prometheus/prometheus/prompb"
|
"github.com/prometheus/prometheus/prompb"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ import (
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
config_util "github.com/prometheus/common/config"
|
config_util "github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
var longErrMessage = strings.Repeat("error message", maxErrMsgLen)
|
var longErrMessage = strings.Repeat("error message", maxErrMsgLen)
|
||||||
|
@ -53,7 +53,7 @@ func TestStoreHTTPErrorHandling(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, test := range tests {
|
for _, test := range tests {
|
||||||
server := httptest.NewServer(
|
server := httptest.NewServer(
|
||||||
http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
http.Error(w, longErrMessage, test.code)
|
http.Error(w, longErrMessage, test.code)
|
||||||
|
@ -61,7 +61,7 @@ func TestStoreHTTPErrorHandling(t *testing.T) {
|
||||||
)
|
)
|
||||||
|
|
||||||
serverURL, err := url.Parse(server.URL)
|
serverURL, err := url.Parse(server.URL)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
conf := &ClientConfig{
|
conf := &ClientConfig{
|
||||||
URL: &config_util.URL{URL: serverURL},
|
URL: &config_util.URL{URL: serverURL},
|
||||||
|
@ -69,12 +69,16 @@ func TestStoreHTTPErrorHandling(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
hash, err := toHash(conf)
|
hash, err := toHash(conf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
c, err := NewWriteClient(hash, conf)
|
c, err := NewWriteClient(hash, conf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
err = c.Store(context.Background(), []byte{})
|
err = c.Store(context.Background(), []byte{})
|
||||||
testutil.ErrorEqual(t, err, test.err, "unexpected error in test %d", i)
|
if test.err != nil {
|
||||||
|
assert.EqualError(t, err, test.err.Error())
|
||||||
|
} else {
|
||||||
|
assert.NoError(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
server.Close()
|
server.Close()
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,7 @@ import (
|
||||||
"github.com/golang/snappy"
|
"github.com/golang/snappy"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/prompb"
|
"github.com/prometheus/prometheus/prompb"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
|
|
|
@ -17,10 +17,11 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/prompb"
|
"github.com/prometheus/prometheus/prompb"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestValidateLabelsAndMetricName(t *testing.T) {
|
func TestValidateLabelsAndMetricName(t *testing.T) {
|
||||||
|
@ -114,10 +115,10 @@ func TestValidateLabelsAndMetricName(t *testing.T) {
|
||||||
t.Run(test.description, func(t *testing.T) {
|
t.Run(test.description, func(t *testing.T) {
|
||||||
err := validateLabelsAndMetricName(test.input)
|
err := validateLabelsAndMetricName(test.input)
|
||||||
if test.expectedErr != "" {
|
if test.expectedErr != "" {
|
||||||
testutil.NotOk(t, err)
|
assert.Error(t, err)
|
||||||
testutil.Equals(t, test.expectedErr, err.Error())
|
assert.Equal(t, test.expectedErr, err.Error())
|
||||||
} else {
|
} else {
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -135,11 +136,11 @@ func TestConcreteSeriesSet(t *testing.T) {
|
||||||
c := &concreteSeriesSet{
|
c := &concreteSeriesSet{
|
||||||
series: []storage.Series{series1, series2},
|
series: []storage.Series{series1, series2},
|
||||||
}
|
}
|
||||||
testutil.Assert(t, c.Next(), "Expected Next() to be true.")
|
assert.True(t, c.Next(), "Expected Next() to be true.")
|
||||||
testutil.Equals(t, series1, c.At(), "Unexpected series returned.")
|
assert.Equal(t, series1, c.At(), "Unexpected series returned.")
|
||||||
testutil.Assert(t, c.Next(), "Expected Next() to be true.")
|
assert.True(t, c.Next(), "Expected Next() to be true.")
|
||||||
testutil.Equals(t, series2, c.At(), "Unexpected series returned.")
|
assert.Equal(t, series2, c.At(), "Unexpected series returned.")
|
||||||
testutil.Assert(t, !c.Next(), "Expected Next() to be false.")
|
assert.True(t, !c.Next(), "Expected Next() to be false.")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestConcreteSeriesClonesLabels(t *testing.T) {
|
func TestConcreteSeriesClonesLabels(t *testing.T) {
|
||||||
|
@ -152,13 +153,13 @@ func TestConcreteSeriesClonesLabels(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
gotLabels := cs.Labels()
|
gotLabels := cs.Labels()
|
||||||
testutil.Equals(t, lbls, gotLabels)
|
assert.Equal(t, lbls, gotLabels)
|
||||||
|
|
||||||
gotLabels[0].Value = "foo"
|
gotLabels[0].Value = "foo"
|
||||||
gotLabels[1].Value = "bar"
|
gotLabels[1].Value = "bar"
|
||||||
|
|
||||||
gotLabels = cs.Labels()
|
gotLabels = cs.Labels()
|
||||||
testutil.Equals(t, lbls, gotLabels)
|
assert.Equal(t, lbls, gotLabels)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFromQueryResultWithDuplicates(t *testing.T) {
|
func TestFromQueryResultWithDuplicates(t *testing.T) {
|
||||||
|
@ -182,9 +183,9 @@ func TestFromQueryResultWithDuplicates(t *testing.T) {
|
||||||
|
|
||||||
errSeries, isErrSeriesSet := series.(errSeriesSet)
|
errSeries, isErrSeriesSet := series.(errSeriesSet)
|
||||||
|
|
||||||
testutil.Assert(t, isErrSeriesSet, "Expected resulting series to be an errSeriesSet")
|
assert.True(t, isErrSeriesSet, "Expected resulting series to be an errSeriesSet")
|
||||||
errMessage := errSeries.Err().Error()
|
errMessage := errSeries.Err().Error()
|
||||||
testutil.Assert(t, errMessage == "duplicate label with name: foo", fmt.Sprintf("Expected error to be from duplicate label, but got: %s", errMessage))
|
assert.True(t, errMessage == "duplicate label with name: foo", fmt.Sprintf("Expected error to be from duplicate label, but got: %s", errMessage))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNegotiateResponseType(t *testing.T) {
|
func TestNegotiateResponseType(t *testing.T) {
|
||||||
|
@ -192,23 +193,23 @@ func TestNegotiateResponseType(t *testing.T) {
|
||||||
prompb.ReadRequest_STREAMED_XOR_CHUNKS,
|
prompb.ReadRequest_STREAMED_XOR_CHUNKS,
|
||||||
prompb.ReadRequest_SAMPLES,
|
prompb.ReadRequest_SAMPLES,
|
||||||
})
|
})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, prompb.ReadRequest_STREAMED_XOR_CHUNKS, r)
|
assert.Equal(t, prompb.ReadRequest_STREAMED_XOR_CHUNKS, r)
|
||||||
|
|
||||||
r2, err := NegotiateResponseType([]prompb.ReadRequest_ResponseType{
|
r2, err := NegotiateResponseType([]prompb.ReadRequest_ResponseType{
|
||||||
prompb.ReadRequest_SAMPLES,
|
prompb.ReadRequest_SAMPLES,
|
||||||
prompb.ReadRequest_STREAMED_XOR_CHUNKS,
|
prompb.ReadRequest_STREAMED_XOR_CHUNKS,
|
||||||
})
|
})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, prompb.ReadRequest_SAMPLES, r2)
|
assert.Equal(t, prompb.ReadRequest_SAMPLES, r2)
|
||||||
|
|
||||||
r3, err := NegotiateResponseType([]prompb.ReadRequest_ResponseType{})
|
r3, err := NegotiateResponseType([]prompb.ReadRequest_ResponseType{})
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, prompb.ReadRequest_SAMPLES, r3)
|
assert.Equal(t, prompb.ReadRequest_SAMPLES, r3)
|
||||||
|
|
||||||
_, err = NegotiateResponseType([]prompb.ReadRequest_ResponseType{20})
|
_, err = NegotiateResponseType([]prompb.ReadRequest_ResponseType{20})
|
||||||
testutil.NotOk(t, err, "expected error due to not supported requested response types")
|
assert.Error(t, err, "expected error due to not supported requested response types")
|
||||||
testutil.Equals(t, "server does not support any of the requested response types: [20]; supported: map[SAMPLES:{} STREAMED_XOR_CHUNKS:{}]", err.Error())
|
assert.Equal(t, "server does not support any of the requested response types: [20]; supported: map[SAMPLES:{} STREAMED_XOR_CHUNKS:{}]", err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestMergeLabels(t *testing.T) {
|
func TestMergeLabels(t *testing.T) {
|
||||||
|
@ -226,6 +227,6 @@ func TestMergeLabels(t *testing.T) {
|
||||||
expected: []prompb.Label{{Name: "aaa", Value: "foo"}, {Name: "bbb", Value: "bar"}, {Name: "ccc", Value: "bar"}, {Name: "ddd", Value: "foo"}},
|
expected: []prompb.Label{{Name: "aaa", Value: "foo"}, {Name: "bbb", Value: "bar"}, {Name: "ccc", Value: "bar"}, {Name: "ddd", Value: "foo"}},
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
testutil.Equals(t, tc.expected, MergeLabels(tc.primary, tc.secondary))
|
assert.Equal(t, tc.expected, MergeLabels(tc.primary, tc.secondary))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,10 +21,9 @@ package remote
|
||||||
import (
|
import (
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"go.uber.org/atomic"
|
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/client_golang/prometheus/promauto"
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
||||||
|
"go.uber.org/atomic"
|
||||||
)
|
)
|
||||||
|
|
||||||
var noReferenceReleases = promauto.NewCounter(prometheus.CounterOpts{
|
var noReferenceReleases = promauto.NewCounter(prometheus.CounterOpts{
|
||||||
|
|
|
@ -23,7 +23,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestIntern(t *testing.T) {
|
func TestIntern(t *testing.T) {
|
||||||
|
@ -32,8 +32,8 @@ func TestIntern(t *testing.T) {
|
||||||
interner.intern(testString)
|
interner.intern(testString)
|
||||||
interned, ok := interner.pool[testString]
|
interned, ok := interner.pool[testString]
|
||||||
|
|
||||||
testutil.Equals(t, true, ok)
|
assert.Equal(t, true, ok)
|
||||||
testutil.Assert(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
assert.True(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIntern_MultiRef(t *testing.T) {
|
func TestIntern_MultiRef(t *testing.T) {
|
||||||
|
@ -43,14 +43,14 @@ func TestIntern_MultiRef(t *testing.T) {
|
||||||
interner.intern(testString)
|
interner.intern(testString)
|
||||||
interned, ok := interner.pool[testString]
|
interned, ok := interner.pool[testString]
|
||||||
|
|
||||||
testutil.Equals(t, true, ok)
|
assert.Equal(t, true, ok)
|
||||||
testutil.Assert(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
assert.True(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
||||||
|
|
||||||
interner.intern(testString)
|
interner.intern(testString)
|
||||||
interned, ok = interner.pool[testString]
|
interned, ok = interner.pool[testString]
|
||||||
|
|
||||||
testutil.Equals(t, true, ok)
|
assert.Equal(t, true, ok)
|
||||||
testutil.Assert(t, interned.refs.Load() == 2, fmt.Sprintf("expected refs to be 2 but it was %d", interned.refs.Load()))
|
assert.True(t, interned.refs.Load() == 2, fmt.Sprintf("expected refs to be 2 but it was %d", interned.refs.Load()))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIntern_DeleteRef(t *testing.T) {
|
func TestIntern_DeleteRef(t *testing.T) {
|
||||||
|
@ -60,12 +60,12 @@ func TestIntern_DeleteRef(t *testing.T) {
|
||||||
interner.intern(testString)
|
interner.intern(testString)
|
||||||
interned, ok := interner.pool[testString]
|
interned, ok := interner.pool[testString]
|
||||||
|
|
||||||
testutil.Equals(t, true, ok)
|
assert.Equal(t, true, ok)
|
||||||
testutil.Assert(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
assert.True(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
||||||
|
|
||||||
interner.release(testString)
|
interner.release(testString)
|
||||||
_, ok = interner.pool[testString]
|
_, ok = interner.pool[testString]
|
||||||
testutil.Equals(t, false, ok)
|
assert.Equal(t, false, ok)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIntern_MultiRef_Concurrent(t *testing.T) {
|
func TestIntern_MultiRef_Concurrent(t *testing.T) {
|
||||||
|
@ -74,8 +74,8 @@ func TestIntern_MultiRef_Concurrent(t *testing.T) {
|
||||||
|
|
||||||
interner.intern(testString)
|
interner.intern(testString)
|
||||||
interned, ok := interner.pool[testString]
|
interned, ok := interner.pool[testString]
|
||||||
testutil.Equals(t, true, ok)
|
assert.Equal(t, true, ok)
|
||||||
testutil.Assert(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
assert.True(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
||||||
|
|
||||||
go interner.release(testString)
|
go interner.release(testString)
|
||||||
|
|
||||||
|
@ -86,6 +86,6 @@ func TestIntern_MultiRef_Concurrent(t *testing.T) {
|
||||||
interner.mtx.RLock()
|
interner.mtx.RLock()
|
||||||
interned, ok = interner.pool[testString]
|
interned, ok = interner.pool[testString]
|
||||||
interner.mtx.RUnlock()
|
interner.mtx.RUnlock()
|
||||||
testutil.Equals(t, true, ok)
|
assert.Equal(t, true, ok)
|
||||||
testutil.Assert(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
assert.True(t, interned.refs.Load() == 1, fmt.Sprintf("expected refs to be 1 but it was %d", interned.refs.Load()))
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,9 +26,9 @@ import (
|
||||||
"github.com/golang/snappy"
|
"github.com/golang/snappy"
|
||||||
"github.com/opentracing/opentracing-go"
|
"github.com/opentracing/opentracing-go"
|
||||||
"github.com/opentracing/opentracing-go/ext"
|
"github.com/opentracing/opentracing-go/ext"
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"go.uber.org/atomic"
|
"go.uber.org/atomic"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/relabel"
|
"github.com/prometheus/prometheus/pkg/relabel"
|
||||||
|
|
|
@ -18,8 +18,8 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"math"
|
"math"
|
||||||
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
|
||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
@ -30,19 +30,18 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/gogo/protobuf/proto"
|
"github.com/gogo/protobuf/proto"
|
||||||
"github.com/golang/snappy"
|
"github.com/golang/snappy"
|
||||||
"go.uber.org/atomic"
|
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
client_testutil "github.com/prometheus/client_golang/prometheus/testutil"
|
client_testutil "github.com/prometheus/client_golang/prometheus/testutil"
|
||||||
common_config "github.com/prometheus/common/config"
|
common_config "github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
"go.uber.org/atomic"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/timestamp"
|
"github.com/prometheus/prometheus/pkg/timestamp"
|
||||||
"github.com/prometheus/prometheus/prompb"
|
"github.com/prometheus/prometheus/prompb"
|
||||||
"github.com/prometheus/prometheus/tsdb/record"
|
"github.com/prometheus/prometheus/tsdb/record"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
"net/url"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const defaultFlushDeadline = 1 * time.Minute
|
const defaultFlushDeadline = 1 * time.Minute
|
||||||
|
@ -74,9 +73,9 @@ func TestSampleDelivery(t *testing.T) {
|
||||||
queueConfig.MaxSamplesPerSend = len(samples) / 2
|
queueConfig.MaxSamplesPerSend = len(samples) / 2
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestSampleDeliver")
|
dir, err := ioutil.TempDir("", "TestSampleDeliver")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
s := NewStorage(nil, nil, nil, dir, defaultFlushDeadline)
|
s := NewStorage(nil, nil, nil, dir, defaultFlushDeadline)
|
||||||
|
@ -96,9 +95,9 @@ func TestSampleDelivery(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
writeConfig.QueueConfig = queueConfig
|
writeConfig.QueueConfig = queueConfig
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
hash, err := toHash(writeConfig)
|
hash, err := toHash(writeConfig)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
qm := s.rws.queues[hash]
|
qm := s.rws.queues[hash]
|
||||||
qm.SetClient(c)
|
qm.SetClient(c)
|
||||||
|
|
||||||
|
@ -122,9 +121,9 @@ func TestSampleDeliveryTimeout(t *testing.T) {
|
||||||
cfg.BatchSendDeadline = model.Duration(100 * time.Millisecond)
|
cfg.BatchSendDeadline = model.Duration(100 * time.Millisecond)
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestSampleDeliveryTimeout")
|
dir, err := ioutil.TempDir("", "TestSampleDeliveryTimeout")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -165,9 +164,9 @@ func TestSampleDeliveryOrder(t *testing.T) {
|
||||||
c.expectSamples(samples, series)
|
c.expectSamples(samples, series)
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestSampleDeliveryOrder")
|
dir, err := ioutil.TempDir("", "TestSampleDeliveryOrder")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -186,9 +185,9 @@ func TestShutdown(t *testing.T) {
|
||||||
c := NewTestBlockedWriteClient()
|
c := NewTestBlockedWriteClient()
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestShutdown")
|
dir, err := ioutil.TempDir("", "TestShutdown")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -227,9 +226,9 @@ func TestSeriesReset(t *testing.T) {
|
||||||
numSeries := 25
|
numSeries := 25
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestSeriesReset")
|
dir, err := ioutil.TempDir("", "TestSeriesReset")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -241,9 +240,9 @@ func TestSeriesReset(t *testing.T) {
|
||||||
}
|
}
|
||||||
m.StoreSeries(series, i)
|
m.StoreSeries(series, i)
|
||||||
}
|
}
|
||||||
testutil.Equals(t, numSegments*numSeries, len(m.seriesLabels))
|
assert.Equal(t, numSegments*numSeries, len(m.seriesLabels))
|
||||||
m.SeriesReset(2)
|
m.SeriesReset(2)
|
||||||
testutil.Equals(t, numSegments*numSeries/2, len(m.seriesLabels))
|
assert.Equal(t, numSegments*numSeries/2, len(m.seriesLabels))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestReshard(t *testing.T) {
|
func TestReshard(t *testing.T) {
|
||||||
|
@ -259,9 +258,9 @@ func TestReshard(t *testing.T) {
|
||||||
cfg.MaxShards = 1
|
cfg.MaxShards = 1
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestReshard")
|
dir, err := ioutil.TempDir("", "TestReshard")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -274,7 +273,7 @@ func TestReshard(t *testing.T) {
|
||||||
go func() {
|
go func() {
|
||||||
for i := 0; i < len(samples); i += config.DefaultQueueConfig.Capacity {
|
for i := 0; i < len(samples); i += config.DefaultQueueConfig.Capacity {
|
||||||
sent := m.Append(samples[i : i+config.DefaultQueueConfig.Capacity])
|
sent := m.Append(samples[i : i+config.DefaultQueueConfig.Capacity])
|
||||||
testutil.Assert(t, sent, "samples not sent")
|
assert.True(t, sent, "samples not sent")
|
||||||
time.Sleep(100 * time.Millisecond)
|
time.Sleep(100 * time.Millisecond)
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
@ -335,7 +334,7 @@ func TestReleaseNoninternedString(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
metric := client_testutil.ToFloat64(noReferenceReleases)
|
metric := client_testutil.ToFloat64(noReferenceReleases)
|
||||||
testutil.Assert(t, metric == 0, "expected there to be no calls to release for strings that were not already interned: %d", int(metric))
|
assert.True(t, metric == 0, "expected there to be no calls to release for strings that were not already interned: %d", int(metric))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestShouldReshard(t *testing.T) {
|
func TestShouldReshard(t *testing.T) {
|
||||||
|
@ -377,7 +376,7 @@ func TestShouldReshard(t *testing.T) {
|
||||||
|
|
||||||
m.Stop()
|
m.Stop()
|
||||||
|
|
||||||
testutil.Equals(t, c.expectedToReshard, shouldReshard)
|
assert.Equal(t, c.expectedToReshard, shouldReshard)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -456,9 +455,7 @@ func (c *TestWriteClient) waitForExpectedSamples(tb testing.TB) {
|
||||||
c.mtx.Lock()
|
c.mtx.Lock()
|
||||||
defer c.mtx.Unlock()
|
defer c.mtx.Unlock()
|
||||||
for ts, expectedSamples := range c.expectedSamples {
|
for ts, expectedSamples := range c.expectedSamples {
|
||||||
if !reflect.DeepEqual(expectedSamples, c.receivedSamples[ts]) {
|
assert.Equal(tb, expectedSamples, c.receivedSamples[ts], ts)
|
||||||
tb.Fatalf("%s: Expected %v, got %v", ts, expectedSamples, c.receivedSamples[ts])
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -567,7 +564,7 @@ func BenchmarkSampleDelivery(b *testing.B) {
|
||||||
cfg.MaxShards = 1
|
cfg.MaxShards = 1
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "BenchmarkSampleDelivery")
|
dir, err := ioutil.TempDir("", "BenchmarkSampleDelivery")
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
defer os.RemoveAll(dir)
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -597,7 +594,7 @@ func BenchmarkStartup(b *testing.B) {
|
||||||
// Find the second largest segment; we will replay up to this.
|
// Find the second largest segment; we will replay up to this.
|
||||||
// (Second largest as WALWatcher will start tailing the largest).
|
// (Second largest as WALWatcher will start tailing the largest).
|
||||||
dirents, err := ioutil.ReadDir(dir)
|
dirents, err := ioutil.ReadDir(dir)
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
|
|
||||||
var segments []int
|
var segments []int
|
||||||
for _, dirent := range dirents {
|
for _, dirent := range dirents {
|
||||||
|
@ -619,7 +616,7 @@ func BenchmarkStartup(b *testing.B) {
|
||||||
m.watcher.SetStartTime(timestamp.Time(math.MaxInt64))
|
m.watcher.SetStartTime(timestamp.Time(math.MaxInt64))
|
||||||
m.watcher.MaxSegment = segments[len(segments)-2]
|
m.watcher.MaxSegment = segments[len(segments)-2]
|
||||||
err := m.watcher.Run()
|
err := m.watcher.Run()
|
||||||
testutil.Ok(b, err)
|
assert.NoError(b, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -650,7 +647,7 @@ func TestProcessExternalLabels(t *testing.T) {
|
||||||
expected: labels.Labels{{Name: "a", Value: "b"}},
|
expected: labels.Labels{{Name: "a", Value: "b"}},
|
||||||
},
|
},
|
||||||
} {
|
} {
|
||||||
testutil.Equals(t, tc.expected, processExternalLabels(tc.labels, tc.externalLabels))
|
assert.Equal(t, tc.expected, processExternalLabels(tc.labels, tc.externalLabels))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -659,9 +656,9 @@ func TestCalculateDesiredShards(t *testing.T) {
|
||||||
cfg := config.DefaultQueueConfig
|
cfg := config.DefaultQueueConfig
|
||||||
|
|
||||||
dir, err := ioutil.TempDir("", "TestCalculateDesiredShards")
|
dir, err := ioutil.TempDir("", "TestCalculateDesiredShards")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
metrics := newQueueManagerMetrics(nil, "", "")
|
metrics := newQueueManagerMetrics(nil, "", "")
|
||||||
|
@ -706,7 +703,7 @@ func TestCalculateDesiredShards(t *testing.T) {
|
||||||
for ; ts < 120*time.Second; ts += shardUpdateDuration {
|
for ; ts < 120*time.Second; ts += shardUpdateDuration {
|
||||||
addSamples(inputRate*int64(shardUpdateDuration/time.Second), ts)
|
addSamples(inputRate*int64(shardUpdateDuration/time.Second), ts)
|
||||||
m.numShards = m.calculateDesiredShards()
|
m.numShards = m.calculateDesiredShards()
|
||||||
testutil.Equals(t, 1, m.numShards)
|
assert.Equal(t, 1, m.numShards)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assume 100ms per request, or 10 requests per second per shard.
|
// Assume 100ms per request, or 10 requests per second per shard.
|
||||||
|
@ -728,10 +725,10 @@ func TestCalculateDesiredShards(t *testing.T) {
|
||||||
|
|
||||||
t.Log("desiredShards", m.numShards, "pendingSamples", pendingSamples)
|
t.Log("desiredShards", m.numShards, "pendingSamples", pendingSamples)
|
||||||
m.numShards = m.calculateDesiredShards()
|
m.numShards = m.calculateDesiredShards()
|
||||||
testutil.Assert(t, m.numShards >= minShards, "Shards are too low. desiredShards=%d, minShards=%d, t_seconds=%d", m.numShards, minShards, ts/time.Second)
|
assert.True(t, m.numShards >= minShards, "Shards are too low. desiredShards=%d, minShards=%d, t_seconds=%d", m.numShards, minShards, ts/time.Second)
|
||||||
testutil.Assert(t, m.numShards <= maxShards, "Shards are too high. desiredShards=%d, maxShards=%d, t_seconds=%d", m.numShards, maxShards, ts/time.Second)
|
assert.True(t, m.numShards <= maxShards, "Shards are too high. desiredShards=%d, maxShards=%d, t_seconds=%d", m.numShards, maxShards, ts/time.Second)
|
||||||
}
|
}
|
||||||
testutil.Assert(t, pendingSamples == 0, "Remote write never caught up, there are still %d pending samples.", pendingSamples)
|
assert.True(t, pendingSamples == 0, "Remote write never caught up, there are still %d pending samples.", pendingSamples)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestQueueManagerMetrics(t *testing.T) {
|
func TestQueueManagerMetrics(t *testing.T) {
|
||||||
|
@ -740,12 +737,12 @@ func TestQueueManagerMetrics(t *testing.T) {
|
||||||
|
|
||||||
// Make sure metrics pass linting.
|
// Make sure metrics pass linting.
|
||||||
problems, err := client_testutil.GatherAndLint(reg)
|
problems, err := client_testutil.GatherAndLint(reg)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 0, len(problems), "Metric linting problems detected: %v", problems)
|
assert.Equal(t, 0, len(problems), "Metric linting problems detected: %v", problems)
|
||||||
|
|
||||||
// Make sure all metrics were unregistered. A failure here means you need
|
// Make sure all metrics were unregistered. A failure here means you need
|
||||||
// unregister a metric in `queueManagerMetrics.unregister()`.
|
// unregister a metric in `queueManagerMetrics.unregister()`.
|
||||||
metrics.unregister()
|
metrics.unregister()
|
||||||
err = client_testutil.GatherAndCompare(reg, strings.NewReader(""))
|
err = client_testutil.GatherAndCompare(reg, strings.NewReader(""))
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
)
|
)
|
||||||
|
|
|
@ -18,23 +18,23 @@ import (
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
|
||||||
"sort"
|
"sort"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
config_util "github.com/prometheus/common/config"
|
config_util "github.com/prometheus/common/config"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/prompb"
|
"github.com/prometheus/prometheus/prompb"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestNoDuplicateReadConfigs(t *testing.T) {
|
func TestNoDuplicateReadConfigs(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestNoDuplicateReadConfigs")
|
dir, err := ioutil.TempDir("", "TestNoDuplicateReadConfigs")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.RemoveAll(dir)
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
cfg1 := config.RemoteReadConfig{
|
cfg1 := config.RemoteReadConfig{
|
||||||
|
@ -103,8 +103,8 @@ func TestNoDuplicateReadConfigs(t *testing.T) {
|
||||||
err := s.ApplyConfig(conf)
|
err := s.ApplyConfig(conf)
|
||||||
prometheus.Unregister(s.rws.highestTimestamp)
|
prometheus.Unregister(s.rws.highestTimestamp)
|
||||||
gotError := err != nil
|
gotError := err != nil
|
||||||
testutil.Equals(t, tc.err, gotError)
|
assert.Equal(t, tc.err, gotError)
|
||||||
testutil.Ok(t, s.Close())
|
assert.NoError(t, s.Close())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -170,12 +170,8 @@ func TestExternalLabelsQuerierAddExternalLabels(t *testing.T) {
|
||||||
sort.Slice(test.outMatchers, func(i, j int) bool { return test.outMatchers[i].Name < test.outMatchers[j].Name })
|
sort.Slice(test.outMatchers, func(i, j int) bool { return test.outMatchers[i].Name < test.outMatchers[j].Name })
|
||||||
sort.Slice(matchers, func(i, j int) bool { return matchers[i].Name < matchers[j].Name })
|
sort.Slice(matchers, func(i, j int) bool { return matchers[i].Name < matchers[j].Name })
|
||||||
|
|
||||||
if !reflect.DeepEqual(matchers, test.outMatchers) {
|
assert.Equal(t, test.outMatchers, matchers, "%d", i)
|
||||||
t.Fatalf("%d. unexpected matchers; want %v, got %v", i, test.outMatchers, matchers)
|
assert.Equal(t, test.added, added, "%d", i)
|
||||||
}
|
|
||||||
if !reflect.DeepEqual(added, test.added) {
|
|
||||||
t.Fatalf("%d. unexpected added labels; want %v, got %v", i, test.added, added)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,9 +200,9 @@ func TestSeriesSetFilter(t *testing.T) {
|
||||||
for _, tc := range tests {
|
for _, tc := range tests {
|
||||||
filtered := newSeriesSetFilter(FromQueryResult(true, tc.in), tc.toRemove)
|
filtered := newSeriesSetFilter(FromQueryResult(true, tc.in), tc.toRemove)
|
||||||
act, ws, err := ToQueryResult(filtered, 1e6)
|
act, ws, err := ToQueryResult(filtered, 1e6)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 0, len(ws))
|
assert.Equal(t, 0, len(ws))
|
||||||
testutil.Equals(t, tc.expected, act)
|
assert.Equal(t, tc.expected, act)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -495,21 +491,21 @@ func TestSampleAndChunkQueryableClient(t *testing.T) {
|
||||||
tc.callback,
|
tc.callback,
|
||||||
)
|
)
|
||||||
q, err := c.Querier(context.TODO(), tc.mint, tc.maxt)
|
q, err := c.Querier(context.TODO(), tc.mint, tc.maxt)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer testutil.Ok(t, q.Close())
|
defer assert.NoError(t, q.Close())
|
||||||
|
|
||||||
ss := q.Select(true, nil, tc.matchers...)
|
ss := q.Select(true, nil, tc.matchers...)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, storage.Warnings(nil), ss.Warnings())
|
assert.Equal(t, storage.Warnings(nil), ss.Warnings())
|
||||||
|
|
||||||
testutil.Equals(t, tc.expectedQuery, m.got)
|
assert.Equal(t, tc.expectedQuery, m.got)
|
||||||
|
|
||||||
var got []labels.Labels
|
var got []labels.Labels
|
||||||
for ss.Next() {
|
for ss.Next() {
|
||||||
got = append(got, ss.At().Labels())
|
got = append(got, ss.At().Labels())
|
||||||
}
|
}
|
||||||
testutil.Ok(t, ss.Err())
|
assert.NoError(t, ss.Err())
|
||||||
testutil.Equals(t, tc.expectedSeries, got)
|
assert.Equal(t, tc.expectedSeries, got)
|
||||||
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,10 +22,10 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"gopkg.in/yaml.v2"
|
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"gopkg.in/yaml.v2"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/logging"
|
"github.com/prometheus/prometheus/pkg/logging"
|
||||||
|
|
|
@ -20,13 +20,14 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
common_config "github.com/prometheus/common/config"
|
common_config "github.com/prometheus/common/config"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestStorageLifecycle(t *testing.T) {
|
func TestStorageLifecycle(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestStorageLifecycle")
|
dir, err := ioutil.TempDir("", "TestStorageLifecycle")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.RemoveAll(dir)
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
s := NewStorage(nil, nil, nil, dir, defaultFlushDeadline)
|
s := NewStorage(nil, nil, nil, dir, defaultFlushDeadline)
|
||||||
|
@ -51,21 +52,21 @@ func TestStorageLifecycle(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
|
|
||||||
// make sure remote write has a queue.
|
// make sure remote write has a queue.
|
||||||
testutil.Equals(t, 1, len(s.rws.queues))
|
assert.Equal(t, 1, len(s.rws.queues))
|
||||||
|
|
||||||
// make sure remote write has a queue.
|
// make sure remote write has a queue.
|
||||||
testutil.Equals(t, 1, len(s.queryables))
|
assert.Equal(t, 1, len(s.queryables))
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestUpdateRemoteReadConfigs(t *testing.T) {
|
func TestUpdateRemoteReadConfigs(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestUpdateRemoteReadConfigs")
|
dir, err := ioutil.TempDir("", "TestUpdateRemoteReadConfigs")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer os.RemoveAll(dir)
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
s := NewStorage(nil, nil, nil, dir, defaultFlushDeadline)
|
s := NewStorage(nil, nil, nil, dir, defaultFlushDeadline)
|
||||||
|
@ -73,15 +74,15 @@ func TestUpdateRemoteReadConfigs(t *testing.T) {
|
||||||
conf := &config.Config{
|
conf := &config.Config{
|
||||||
GlobalConfig: config.GlobalConfig{},
|
GlobalConfig: config.GlobalConfig{},
|
||||||
}
|
}
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
testutil.Equals(t, 0, len(s.queryables))
|
assert.Equal(t, 0, len(s.queryables))
|
||||||
|
|
||||||
conf.RemoteReadConfigs = []*config.RemoteReadConfig{
|
conf.RemoteReadConfigs = []*config.RemoteReadConfig{
|
||||||
&config.DefaultRemoteReadConfig,
|
&config.DefaultRemoteReadConfig,
|
||||||
}
|
}
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
testutil.Equals(t, 1, len(s.queryables))
|
assert.Equal(t, 1, len(s.queryables))
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@ import (
|
||||||
"github.com/go-kit/kit/log"
|
"github.com/go-kit/kit/log"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/client_golang/prometheus/promauto"
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/storage"
|
"github.com/prometheus/prometheus/storage"
|
||||||
|
|
|
@ -23,10 +23,11 @@ import (
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
common_config "github.com/prometheus/common/config"
|
common_config "github.com/prometheus/common/config"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/config"
|
"github.com/prometheus/prometheus/config"
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/pkg/relabel"
|
"github.com/prometheus/prometheus/pkg/relabel"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var cfg = config.RemoteWriteConfig{
|
var cfg = config.RemoteWriteConfig{
|
||||||
|
@ -42,9 +43,9 @@ var cfg = config.RemoteWriteConfig{
|
||||||
|
|
||||||
func TestNoDuplicateWriteConfigs(t *testing.T) {
|
func TestNoDuplicateWriteConfigs(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestNoDuplicateWriteConfigs")
|
dir, err := ioutil.TempDir("", "TestNoDuplicateWriteConfigs")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
cfg1 := config.RemoteWriteConfig{
|
cfg1 := config.RemoteWriteConfig{
|
||||||
|
@ -121,22 +122,22 @@ func TestNoDuplicateWriteConfigs(t *testing.T) {
|
||||||
}
|
}
|
||||||
err := s.ApplyConfig(conf)
|
err := s.ApplyConfig(conf)
|
||||||
gotError := err != nil
|
gotError := err != nil
|
||||||
testutil.Equals(t, tc.err, gotError)
|
assert.Equal(t, tc.err, gotError)
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRestartOnNameChange(t *testing.T) {
|
func TestRestartOnNameChange(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestRestartOnNameChange")
|
dir, err := ioutil.TempDir("", "TestRestartOnNameChange")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
hash, err := toHash(cfg)
|
hash, err := toHash(cfg)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
s := NewWriteStorage(nil, nil, dir, time.Millisecond)
|
s := NewWriteStorage(nil, nil, dir, time.Millisecond)
|
||||||
conf := &config.Config{
|
conf := &config.Config{
|
||||||
|
@ -145,25 +146,25 @@ func TestRestartOnNameChange(t *testing.T) {
|
||||||
&cfg,
|
&cfg,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
testutil.Equals(t, s.queues[hash].client().Name(), cfg.Name)
|
assert.Equal(t, s.queues[hash].client().Name(), cfg.Name)
|
||||||
|
|
||||||
// Change the queues name, ensure the queue has been restarted.
|
// Change the queues name, ensure the queue has been restarted.
|
||||||
conf.RemoteWriteConfigs[0].Name = "dev-2"
|
conf.RemoteWriteConfigs[0].Name = "dev-2"
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
hash, err = toHash(cfg)
|
hash, err = toHash(cfg)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, s.queues[hash].client().Name(), conf.RemoteWriteConfigs[0].Name)
|
assert.Equal(t, s.queues[hash].client().Name(), conf.RemoteWriteConfigs[0].Name)
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestUpdateWithRegisterer(t *testing.T) {
|
func TestUpdateWithRegisterer(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestRestartWithRegisterer")
|
dir, err := ioutil.TempDir("", "TestRestartWithRegisterer")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
s := NewWriteStorage(nil, prometheus.NewRegistry(), dir, time.Millisecond)
|
s := NewWriteStorage(nil, prometheus.NewRegistry(), dir, time.Millisecond)
|
||||||
|
@ -190,24 +191,24 @@ func TestUpdateWithRegisterer(t *testing.T) {
|
||||||
GlobalConfig: config.DefaultGlobalConfig,
|
GlobalConfig: config.DefaultGlobalConfig,
|
||||||
RemoteWriteConfigs: []*config.RemoteWriteConfig{c1, c2},
|
RemoteWriteConfigs: []*config.RemoteWriteConfig{c1, c2},
|
||||||
}
|
}
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
|
|
||||||
c1.QueueConfig.MaxShards = 10
|
c1.QueueConfig.MaxShards = 10
|
||||||
c2.QueueConfig.MaxShards = 10
|
c2.QueueConfig.MaxShards = 10
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
for _, queue := range s.queues {
|
for _, queue := range s.queues {
|
||||||
testutil.Equals(t, 10, queue.cfg.MaxShards)
|
assert.Equal(t, 10, queue.cfg.MaxShards)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestWriteStorageLifecycle(t *testing.T) {
|
func TestWriteStorageLifecycle(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestWriteStorageLifecycle")
|
dir, err := ioutil.TempDir("", "TestWriteStorageLifecycle")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
s := NewWriteStorage(nil, nil, dir, defaultFlushDeadline)
|
s := NewWriteStorage(nil, nil, dir, defaultFlushDeadline)
|
||||||
|
@ -218,17 +219,17 @@ func TestWriteStorageLifecycle(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
s.ApplyConfig(conf)
|
s.ApplyConfig(conf)
|
||||||
testutil.Equals(t, 1, len(s.queues))
|
assert.Equal(t, 1, len(s.queues))
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestUpdateExternalLabels(t *testing.T) {
|
func TestUpdateExternalLabels(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestUpdateExternalLabels")
|
dir, err := ioutil.TempDir("", "TestUpdateExternalLabels")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
s := NewWriteStorage(nil, prometheus.NewRegistry(), dir, time.Second)
|
s := NewWriteStorage(nil, prometheus.NewRegistry(), dir, time.Second)
|
||||||
|
@ -241,27 +242,27 @@ func TestUpdateExternalLabels(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
hash, err := toHash(conf.RemoteWriteConfigs[0])
|
hash, err := toHash(conf.RemoteWriteConfigs[0])
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
s.ApplyConfig(conf)
|
s.ApplyConfig(conf)
|
||||||
testutil.Equals(t, 1, len(s.queues))
|
assert.Equal(t, 1, len(s.queues))
|
||||||
testutil.Equals(t, labels.Labels(nil), s.queues[hash].externalLabels)
|
assert.Equal(t, labels.Labels(nil), s.queues[hash].externalLabels)
|
||||||
|
|
||||||
conf.GlobalConfig.ExternalLabels = externalLabels
|
conf.GlobalConfig.ExternalLabels = externalLabels
|
||||||
hash, err = toHash(conf.RemoteWriteConfigs[0])
|
hash, err = toHash(conf.RemoteWriteConfigs[0])
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
s.ApplyConfig(conf)
|
s.ApplyConfig(conf)
|
||||||
testutil.Equals(t, 1, len(s.queues))
|
assert.Equal(t, 1, len(s.queues))
|
||||||
testutil.Equals(t, externalLabels, s.queues[hash].externalLabels)
|
assert.Equal(t, externalLabels, s.queues[hash].externalLabels)
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestWriteStorageApplyConfigsIdempotent(t *testing.T) {
|
func TestWriteStorageApplyConfigsIdempotent(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestWriteStorageApplyConfigsIdempotent")
|
dir, err := ioutil.TempDir("", "TestWriteStorageApplyConfigsIdempotent")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
s := NewWriteStorage(nil, nil, dir, defaultFlushDeadline)
|
s := NewWriteStorage(nil, nil, dir, defaultFlushDeadline)
|
||||||
|
@ -279,25 +280,25 @@ func TestWriteStorageApplyConfigsIdempotent(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
hash, err := toHash(conf.RemoteWriteConfigs[0])
|
hash, err := toHash(conf.RemoteWriteConfigs[0])
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
s.ApplyConfig(conf)
|
s.ApplyConfig(conf)
|
||||||
testutil.Equals(t, 1, len(s.queues))
|
assert.Equal(t, 1, len(s.queues))
|
||||||
|
|
||||||
s.ApplyConfig(conf)
|
s.ApplyConfig(conf)
|
||||||
testutil.Equals(t, 1, len(s.queues))
|
assert.Equal(t, 1, len(s.queues))
|
||||||
_, hashExists := s.queues[hash]
|
_, hashExists := s.queues[hash]
|
||||||
testutil.Assert(t, hashExists, "Queue pointer should have remained the same")
|
assert.True(t, hashExists, "Queue pointer should have remained the same")
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestWriteStorageApplyConfigsPartialUpdate(t *testing.T) {
|
func TestWriteStorageApplyConfigsPartialUpdate(t *testing.T) {
|
||||||
dir, err := ioutil.TempDir("", "TestWriteStorageApplyConfigsPartialUpdate")
|
dir, err := ioutil.TempDir("", "TestWriteStorageApplyConfigsPartialUpdate")
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
defer func() {
|
defer func() {
|
||||||
testutil.Ok(t, os.RemoveAll(dir))
|
assert.NoError(t, os.RemoveAll(dir))
|
||||||
}()
|
}()
|
||||||
|
|
||||||
s := NewWriteStorage(nil, nil, dir, defaultFlushDeadline)
|
s := NewWriteStorage(nil, nil, dir, defaultFlushDeadline)
|
||||||
|
@ -335,15 +336,15 @@ func TestWriteStorageApplyConfigsPartialUpdate(t *testing.T) {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
testutil.Equals(t, 3, len(s.queues))
|
assert.Equal(t, 3, len(s.queues))
|
||||||
|
|
||||||
hashes := make([]string, len(conf.RemoteWriteConfigs))
|
hashes := make([]string, len(conf.RemoteWriteConfigs))
|
||||||
queues := make([]*QueueManager, len(conf.RemoteWriteConfigs))
|
queues := make([]*QueueManager, len(conf.RemoteWriteConfigs))
|
||||||
storeHashes := func() {
|
storeHashes := func() {
|
||||||
for i := range conf.RemoteWriteConfigs {
|
for i := range conf.RemoteWriteConfigs {
|
||||||
hash, err := toHash(conf.RemoteWriteConfigs[i])
|
hash, err := toHash(conf.RemoteWriteConfigs[i])
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
hashes[i] = hash
|
hashes[i] = hash
|
||||||
queues[i] = s.queues[hash]
|
queues[i] = s.queues[hash]
|
||||||
}
|
}
|
||||||
|
@ -357,32 +358,32 @@ func TestWriteStorageApplyConfigsPartialUpdate(t *testing.T) {
|
||||||
GlobalConfig: config.GlobalConfig{},
|
GlobalConfig: config.GlobalConfig{},
|
||||||
RemoteWriteConfigs: []*config.RemoteWriteConfig{c0, c1, c2},
|
RemoteWriteConfigs: []*config.RemoteWriteConfig{c0, c1, c2},
|
||||||
}
|
}
|
||||||
testutil.Ok(t, s.ApplyConfig(conf))
|
assert.NoError(t, s.ApplyConfig(conf))
|
||||||
testutil.Equals(t, 3, len(s.queues))
|
assert.Equal(t, 3, len(s.queues))
|
||||||
|
|
||||||
_, hashExists := s.queues[hashes[0]]
|
_, hashExists := s.queues[hashes[0]]
|
||||||
testutil.Assert(t, !hashExists, "The queue for the first remote write configuration should have been restarted because the relabel configuration has changed.")
|
assert.True(t, !hashExists, "The queue for the first remote write configuration should have been restarted because the relabel configuration has changed.")
|
||||||
q, hashExists := s.queues[hashes[1]]
|
q, hashExists := s.queues[hashes[1]]
|
||||||
testutil.Assert(t, hashExists, "Hash of unchanged queue should have remained the same")
|
assert.True(t, hashExists, "Hash of unchanged queue should have remained the same")
|
||||||
testutil.Assert(t, q == queues[1], "Pointer of unchanged queue should have remained the same")
|
assert.True(t, q == queues[1], "Pointer of unchanged queue should have remained the same")
|
||||||
_, hashExists = s.queues[hashes[2]]
|
_, hashExists = s.queues[hashes[2]]
|
||||||
testutil.Assert(t, !hashExists, "The queue for the third remote write configuration should have been restarted because the timeout has changed.")
|
assert.True(t, !hashExists, "The queue for the third remote write configuration should have been restarted because the timeout has changed.")
|
||||||
|
|
||||||
storeHashes()
|
storeHashes()
|
||||||
secondClient := s.queues[hashes[1]].client()
|
secondClient := s.queues[hashes[1]].client()
|
||||||
// Update c1.
|
// Update c1.
|
||||||
c1.HTTPClientConfig.BearerToken = "bar"
|
c1.HTTPClientConfig.BearerToken = "bar"
|
||||||
err = s.ApplyConfig(conf)
|
err = s.ApplyConfig(conf)
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
testutil.Equals(t, 3, len(s.queues))
|
assert.Equal(t, 3, len(s.queues))
|
||||||
|
|
||||||
_, hashExists = s.queues[hashes[0]]
|
_, hashExists = s.queues[hashes[0]]
|
||||||
testutil.Assert(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
assert.True(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
||||||
q, hashExists = s.queues[hashes[1]]
|
q, hashExists = s.queues[hashes[1]]
|
||||||
testutil.Assert(t, hashExists, "Hash of queue with secret change should have remained the same")
|
assert.True(t, hashExists, "Hash of queue with secret change should have remained the same")
|
||||||
testutil.Assert(t, secondClient != q.client(), "Pointer of a client with a secret change should not be the same")
|
assert.True(t, secondClient != q.client(), "Pointer of a client with a secret change should not be the same")
|
||||||
_, hashExists = s.queues[hashes[2]]
|
_, hashExists = s.queues[hashes[2]]
|
||||||
testutil.Assert(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
assert.True(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
||||||
|
|
||||||
storeHashes()
|
storeHashes()
|
||||||
// Delete c0.
|
// Delete c0.
|
||||||
|
@ -391,15 +392,15 @@ func TestWriteStorageApplyConfigsPartialUpdate(t *testing.T) {
|
||||||
RemoteWriteConfigs: []*config.RemoteWriteConfig{c1, c2},
|
RemoteWriteConfigs: []*config.RemoteWriteConfig{c1, c2},
|
||||||
}
|
}
|
||||||
s.ApplyConfig(conf)
|
s.ApplyConfig(conf)
|
||||||
testutil.Equals(t, 2, len(s.queues))
|
assert.Equal(t, 2, len(s.queues))
|
||||||
|
|
||||||
_, hashExists = s.queues[hashes[0]]
|
_, hashExists = s.queues[hashes[0]]
|
||||||
testutil.Assert(t, !hashExists, "If a config is removed, the queue should be stopped and recreated.")
|
assert.True(t, !hashExists, "If a config is removed, the queue should be stopped and recreated.")
|
||||||
_, hashExists = s.queues[hashes[1]]
|
_, hashExists = s.queues[hashes[1]]
|
||||||
testutil.Assert(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
assert.True(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
||||||
_, hashExists = s.queues[hashes[2]]
|
_, hashExists = s.queues[hashes[2]]
|
||||||
testutil.Assert(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
assert.True(t, hashExists, "Pointer of unchanged queue should have remained the same")
|
||||||
|
|
||||||
err = s.Close()
|
err = s.Close()
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,20 +17,19 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
html_template "html/template"
|
||||||
"math"
|
"math"
|
||||||
"net/url"
|
"net/url"
|
||||||
"regexp"
|
"regexp"
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
|
text_template "text/template"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
html_template "html/template"
|
|
||||||
text_template "text/template"
|
|
||||||
|
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/model"
|
"github.com/prometheus/common/model"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
"github.com/prometheus/prometheus/util/strutil"
|
"github.com/prometheus/prometheus/util/strutil"
|
||||||
)
|
)
|
||||||
|
|
|
@ -20,9 +20,10 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/promql"
|
"github.com/prometheus/prometheus/promql"
|
||||||
"github.com/prometheus/prometheus/util/testutil"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestTemplateExpansion(t *testing.T) {
|
func TestTemplateExpansion(t *testing.T) {
|
||||||
|
@ -283,14 +284,14 @@ func TestTemplateExpansion(t *testing.T) {
|
||||||
result, err = expander.Expand()
|
result, err = expander.Expand()
|
||||||
}
|
}
|
||||||
if s.shouldFail {
|
if s.shouldFail {
|
||||||
testutil.NotOk(t, err, "%v", s.text)
|
assert.Error(t, err, "%v", s.text)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
testutil.Ok(t, err)
|
assert.NoError(t, err)
|
||||||
|
|
||||||
if err == nil {
|
if err == nil {
|
||||||
testutil.Equals(t, result, s.output)
|
assert.Equal(t, result, s.output)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,7 @@ import (
|
||||||
"github.com/go-kit/kit/log/level"
|
"github.com/go-kit/kit/log/level"
|
||||||
"github.com/oklog/ulid"
|
"github.com/oklog/ulid"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
|
||||||
"github.com/prometheus/prometheus/pkg/labels"
|
"github.com/prometheus/prometheus/pkg/labels"
|
||||||
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
"github.com/prometheus/prometheus/tsdb/chunkenc"
|
||||||
"github.com/prometheus/prometheus/tsdb/chunks"
|
"github.com/prometheus/prometheus/tsdb/chunks"
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue