mirror of
https://github.com/prometheus/prometheus.git
synced 2025-03-05 20:59:13 -08:00
Add a testcase for http-sd
Signed-off-by: servak <fservak@gmail.com>
This commit is contained in:
parent
3ab5fe9d7c
commit
b027452c1e
|
@ -162,3 +162,241 @@ func TestContentTypeRegex(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSourceDisappeared(t *testing.T) {
|
||||||
|
var stubResponse string
|
||||||
|
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
w.Header().Set("Content-Type", "application/json")
|
||||||
|
fmt.Fprintln(w, stubResponse)
|
||||||
|
}))
|
||||||
|
t.Cleanup(ts.Close)
|
||||||
|
|
||||||
|
cases := []struct {
|
||||||
|
responses []string
|
||||||
|
expectedTargets [][]*targetgroup.Group
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
responses: []string{
|
||||||
|
`[]`,
|
||||||
|
`[]`,
|
||||||
|
},
|
||||||
|
expectedTargets: [][]*targetgroup.Group{{}, {}},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
responses: []string{
|
||||||
|
`[{"labels": {"k": "1"}, "targets": ["127.0.0.1"]}]`,
|
||||||
|
`[{"labels": {"k": "1"}, "targets": ["127.0.0.1"]}, {"labels": {"k": "2"}, "targets": ["127.0.0.1"]}]`,
|
||||||
|
},
|
||||||
|
expectedTargets: [][]*targetgroup.Group{
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("1"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("1"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("2"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 1),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
responses: []string{
|
||||||
|
`[{"labels": {"k": "1"}, "targets": ["127.0.0.1"]}, {"labels": {"k": "2"}, "targets": ["127.0.0.1"]}]`,
|
||||||
|
`[{"labels": {"k": "1"}, "targets": ["127.0.0.1"]}]`,
|
||||||
|
},
|
||||||
|
expectedTargets: [][]*targetgroup.Group{
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("1"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("2"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 1),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("1"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: nil,
|
||||||
|
Labels: nil,
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 1),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
responses: []string{
|
||||||
|
`[{"labels": {"k": "1"}, "targets": ["127.0.0.1"]}, {"labels": {"k": "2"}, "targets": ["127.0.0.1"]}, {"labels": {"k": "3"}, "targets": ["127.0.0.1"]}]`,
|
||||||
|
`[{"labels": {"k": "1"}, "targets": ["127.0.0.1"]}]`,
|
||||||
|
`[{"labels": {"k": "v"}, "targets": ["127.0.0.2"]}, {"labels": {"k": "vv"}, "targets": ["127.0.0.3"]}]`,
|
||||||
|
},
|
||||||
|
expectedTargets: [][]*targetgroup.Group{
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("1"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("2"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 1),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("3"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 2),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.1"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("1"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: nil,
|
||||||
|
Labels: nil,
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 1),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: nil,
|
||||||
|
Labels: nil,
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 2),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.2"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("v"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 0),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Targets: []model.LabelSet{
|
||||||
|
{
|
||||||
|
model.AddressLabel: model.LabelValue("127.0.0.3"),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Labels: model.LabelSet{
|
||||||
|
model.LabelName("k"): model.LabelValue("vv"),
|
||||||
|
model.LabelName("__meta_url"): model.LabelValue(ts.URL + "/http_disappeared.json"),
|
||||||
|
},
|
||||||
|
Source: urlSource(ts.URL+"/http_disappeared.json", 1),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg := SDConfig{
|
||||||
|
HTTPClientConfig: config.DefaultHTTPClientConfig,
|
||||||
|
URL: ts.URL + "/http_disappeared.json",
|
||||||
|
RefreshInterval: model.Duration(1 * time.Second),
|
||||||
|
}
|
||||||
|
d, err := NewDiscovery(&cfg, log.NewNopLogger())
|
||||||
|
require.NoError(t, err)
|
||||||
|
for _, test := range cases {
|
||||||
|
ctx := context.Background()
|
||||||
|
for i, res := range test.responses {
|
||||||
|
stubResponse = res
|
||||||
|
tgs, err := d.refresh(ctx)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, test.expectedTargets[i], tgs)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue