mirror of https://github.com/tidwall/tile38.git
Moved metrics into step test
This commit is contained in:
parent
906824323b
commit
97da6d70c4
|
@ -1,42 +1,54 @@
|
||||||
package tests
|
package tests
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func downloadURLWithStatusCode(t *testing.T, u string) (int, string) {
|
func subTestMetrics(t *testing.T, mc *mockServer) {
|
||||||
|
runStep(t, mc, "basic", metrics_basic_test)
|
||||||
|
}
|
||||||
|
|
||||||
|
func downloadURLWithStatusCode(u string) (int, string, error) {
|
||||||
resp, err := http.Get(u)
|
resp, err := http.Get(u)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
return 0, "", err
|
||||||
}
|
}
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
body, err := io.ReadAll(resp.Body)
|
body, err := io.ReadAll(resp.Body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
return 0, "", err
|
||||||
}
|
}
|
||||||
return resp.StatusCode, string(body)
|
return resp.StatusCode, string(body), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func subTestMetrics(t *testing.T, mc *mockServer) {
|
func metrics_basic_test(mc *mockServer) error {
|
||||||
|
|
||||||
mc.Do("SET", "metrics_test_1", "1", "FIELD", "foo", 5.5, "POINT", 5, 5)
|
mc.Do("SET", "metrics_test_1", "1", "FIELD", "foo", 5.5, "POINT", 5, 5)
|
||||||
mc.Do("SET", "metrics_test_2", "2", "FIELD", "foo", 19.19, "POINT", 19, 19)
|
mc.Do("SET", "metrics_test_2", "2", "FIELD", "foo", 19.19, "POINT", 19, 19)
|
||||||
mc.Do("SET", "metrics_test_2", "3", "FIELD", "foo", 19.19, "POINT", 19, 19)
|
mc.Do("SET", "metrics_test_2", "3", "FIELD", "foo", 19.19, "POINT", 19, 19)
|
||||||
mc.Do("SET", "metrics_test_2", "truck1:driver", "STRING", "John Denton")
|
mc.Do("SET", "metrics_test_2", "truck1:driver", "STRING", "John Denton")
|
||||||
|
|
||||||
status, index := downloadURLWithStatusCode(t, "http://127.0.0.1:4321/")
|
status, index, err := downloadURLWithStatusCode("http://127.0.0.1:4321/")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
if status != 200 {
|
if status != 200 {
|
||||||
t.Fatalf("Expected status code 200, got: %d", status)
|
return fmt.Errorf("Expected status code 200, got: %d", status)
|
||||||
}
|
}
|
||||||
if !strings.Contains(index, "<a href") {
|
if !strings.Contains(index, "<a href") {
|
||||||
t.Fatalf("missing link on index page")
|
return fmt.Errorf("missing link on index page")
|
||||||
}
|
}
|
||||||
|
|
||||||
status, metrics := downloadURLWithStatusCode(t, "http://127.0.0.1:4321/metrics")
|
status, metrics, err := downloadURLWithStatusCode("http://127.0.0.1:4321/metrics")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
if status != 200 {
|
if status != 200 {
|
||||||
t.Fatalf("Expected status code 200, got: %d", status)
|
return fmt.Errorf("Expected status code 200, got: %d", status)
|
||||||
}
|
}
|
||||||
for _, want := range []string{
|
for _, want := range []string{
|
||||||
`tile38_connected_clients`,
|
`tile38_connected_clients`,
|
||||||
|
@ -50,7 +62,8 @@ func subTestMetrics(t *testing.T, mc *mockServer) {
|
||||||
`role="leader"`,
|
`role="leader"`,
|
||||||
} {
|
} {
|
||||||
if !strings.Contains(metrics, want) {
|
if !strings.Contains(metrics, want) {
|
||||||
t.Fatalf("wanted metric: %s, got: %s", want, metrics)
|
return fmt.Errorf("wanted metric: %s, got: %s", want, metrics)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue