mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-11 13:57:36 -08:00
Fix promtool check config not erroring properly on failures (#10952)
Signed-off-by: Julien Pivotto <roidelapluie@o11y.eu>
This commit is contained in:
parent
90583c8906
commit
13bd4fd3c8
|
@ -344,6 +344,7 @@ func CheckConfig(agentMode, checkSyntaxOnly bool, lintSettings lintConfig, files
|
||||||
ruleFiles, err := checkConfig(agentMode, f, checkSyntaxOnly)
|
ruleFiles, err := checkConfig(agentMode, f, checkSyntaxOnly)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Fprintln(os.Stderr, " FAILED:", err)
|
fmt.Fprintln(os.Stderr, " FAILED:", err)
|
||||||
|
hasErrors = true
|
||||||
failed = true
|
failed = true
|
||||||
} else {
|
} else {
|
||||||
if len(ruleFiles) > 0 {
|
if len(ruleFiles) > 0 {
|
||||||
|
|
|
@ -14,13 +14,16 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"net/url"
|
"net/url"
|
||||||
"os"
|
"os"
|
||||||
|
"os/exec"
|
||||||
"runtime"
|
"runtime"
|
||||||
"strings"
|
"strings"
|
||||||
|
"syscall"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
@ -30,6 +33,21 @@ import (
|
||||||
"github.com/prometheus/prometheus/model/rulefmt"
|
"github.com/prometheus/prometheus/model/rulefmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var promtoolPath = os.Args[0]
|
||||||
|
|
||||||
|
func TestMain(m *testing.M) {
|
||||||
|
for i, arg := range os.Args {
|
||||||
|
if arg == "-test.main" {
|
||||||
|
os.Args = append(os.Args[:i], os.Args[i+1:]...)
|
||||||
|
main()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
exitCode := m.Run()
|
||||||
|
os.Exit(exitCode)
|
||||||
|
}
|
||||||
|
|
||||||
func TestQueryRange(t *testing.T) {
|
func TestQueryRange(t *testing.T) {
|
||||||
s, getRequest := mockServer(200, `{"status": "success", "data": {"resultType": "matrix", "result": []}}`)
|
s, getRequest := mockServer(200, `{"status": "success", "data": {"resultType": "matrix", "result": []}}`)
|
||||||
defer s.Close()
|
defer s.Close()
|
||||||
|
@ -359,3 +377,59 @@ func TestCheckMetricsExtended(t *testing.T) {
|
||||||
},
|
},
|
||||||
}, stats)
|
}, stats)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestExitCodes(t *testing.T) {
|
||||||
|
if testing.Short() {
|
||||||
|
t.Skip("skipping test in short mode.")
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, c := range []struct {
|
||||||
|
file string
|
||||||
|
exitCode int
|
||||||
|
lintIssue bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
file: "prometheus-config.good.yml",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
file: "prometheus-config.bad.yml",
|
||||||
|
exitCode: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
file: "prometheus-config.nonexistent.yml",
|
||||||
|
exitCode: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
file: "prometheus-config.lint.yml",
|
||||||
|
lintIssue: true,
|
||||||
|
exitCode: 3,
|
||||||
|
},
|
||||||
|
} {
|
||||||
|
t.Run(c.file, func(t *testing.T) {
|
||||||
|
for _, lintFatal := range []bool{true, false} {
|
||||||
|
t.Run(fmt.Sprintf("%t", lintFatal), func(t *testing.T) {
|
||||||
|
args := []string{"-test.main", "check", "config", "testdata/" + c.file}
|
||||||
|
if lintFatal {
|
||||||
|
args = append(args, "--lint-fatal")
|
||||||
|
}
|
||||||
|
tool := exec.Command(promtoolPath, args...)
|
||||||
|
err := tool.Run()
|
||||||
|
if c.exitCode == 0 || (c.lintIssue && !lintFatal) {
|
||||||
|
require.NoError(t, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
require.Error(t, err)
|
||||||
|
|
||||||
|
var exitError *exec.ExitError
|
||||||
|
if errors.As(err, &exitError) {
|
||||||
|
status := exitError.Sys().(syscall.WaitStatus)
|
||||||
|
require.Equal(t, c.exitCode, status.ExitStatus())
|
||||||
|
} else {
|
||||||
|
t.Errorf("unable to retrieve the exit status for promtool: %v", err)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
1
cmd/promtool/testdata/prometheus-config.bad.yml
vendored
Normal file
1
cmd/promtool/testdata/prometheus-config.bad.yml
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
not-prometheus:
|
0
cmd/promtool/testdata/prometheus-config.good.yml
vendored
Normal file
0
cmd/promtool/testdata/prometheus-config.good.yml
vendored
Normal file
2
cmd/promtool/testdata/prometheus-config.lint.yml
vendored
Normal file
2
cmd/promtool/testdata/prometheus-config.lint.yml
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
rule_files:
|
||||||
|
- prometheus-rules.lint.yml
|
17
cmd/promtool/testdata/prometheus-rules.lint.yml
vendored
Normal file
17
cmd/promtool/testdata/prometheus-rules.lint.yml
vendored
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
groups:
|
||||||
|
- name: example
|
||||||
|
rules:
|
||||||
|
- alert: HighRequestLatency
|
||||||
|
expr: job:request_latency_seconds:mean5m{job="myjob"} > 0.5
|
||||||
|
for: 10m
|
||||||
|
labels:
|
||||||
|
severity: page
|
||||||
|
annotations:
|
||||||
|
summary: High request latency
|
||||||
|
- alert: HighRequestLatency
|
||||||
|
expr: job:request_latency_seconds:mean5m{job="myjob"} > 0.5
|
||||||
|
for: 10m
|
||||||
|
labels:
|
||||||
|
severity: page
|
||||||
|
annotations:
|
||||||
|
summary: High request latency
|
Loading…
Reference in a new issue