agent: Updating tests for new API

pull/68/head
Armon Dadgar 2014-04-21 13:11:05 -07:00
parent 386d60f8b2
commit e2ea4804bd
4 changed files with 57 additions and 52 deletions

View File

@ -4,6 +4,7 @@ import (
"fmt" "fmt"
"github.com/hashicorp/consul/consul/structs" "github.com/hashicorp/consul/consul/structs"
"net/http" "net/http"
"net/http/httptest"
"os" "os"
"testing" "testing"
"time" "time"
@ -115,14 +116,14 @@ func TestCatalogNodes(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.CatalogNodes(nil, req) resp := httptest.NewRecorder()
obj, err := srv.CatalogNodes(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
if idx == 0 { // Verify an index is set
t.Fatalf("bad: %v", idx) assertIndex(t, resp)
}
nodes := obj.(structs.Nodes) nodes := obj.(structs.Nodes)
if len(nodes) != 2 { if len(nodes) != 2 {
@ -170,7 +171,8 @@ func TestCatalogNodes_Blocking(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.CatalogNodes(nil, req) resp := httptest.NewRecorder()
obj, err := srv.CatalogNodes(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
@ -180,7 +182,7 @@ func TestCatalogNodes_Blocking(t *testing.T) {
t.Fatalf("too fast") t.Fatalf("too fast")
} }
if idx <= out.Index { if idx := getIndex(t, resp); idx <= out.Index {
t.Fatalf("bad: %v", idx) t.Fatalf("bad: %v", idx)
} }
@ -218,14 +220,13 @@ func TestCatalogServices(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.CatalogServices(nil, req) resp := httptest.NewRecorder()
obj, err := srv.CatalogServices(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
if idx == 0 { assertIndex(t, resp)
t.Fatalf("bad: %v", idx)
}
services := obj.(structs.Services) services := obj.(structs.Services)
if len(services) != 2 { if len(services) != 2 {
@ -262,14 +263,13 @@ func TestCatalogServiceNodes(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.CatalogServiceNodes(nil, req) resp := httptest.NewRecorder()
obj, err := srv.CatalogServiceNodes(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
if idx == 0 { assertIndex(t, resp)
t.Fatalf("bad: %v", idx)
}
nodes := obj.(structs.ServiceNodes) nodes := obj.(structs.ServiceNodes)
if len(nodes) != 1 { if len(nodes) != 1 {
@ -306,14 +306,12 @@ func TestCatalogNodeServices(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.CatalogNodeServices(nil, req) resp := httptest.NewRecorder()
obj, err := srv.CatalogNodeServices(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
if idx == 0 {
t.Fatalf("bad: %v", idx)
}
services := obj.(*structs.NodeServices) services := obj.(*structs.NodeServices)
if len(services.Services) != 1 { if len(services.Services) != 1 {

View File

@ -4,6 +4,7 @@ import (
"fmt" "fmt"
"github.com/hashicorp/consul/consul/structs" "github.com/hashicorp/consul/consul/structs"
"net/http" "net/http"
"net/http/httptest"
"os" "os"
"testing" "testing"
"time" "time"
@ -23,14 +24,12 @@ func TestHealthChecksInState(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.HealthChecksInState(nil, req) resp := httptest.NewRecorder()
obj, err := srv.HealthChecksInState(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
if idx == 0 {
t.Fatalf("bad: %v", idx)
}
// Should be 1 health check for the server // Should be 1 health check for the server
nodes := obj.(structs.HealthChecks) nodes := obj.(structs.HealthChecks)
@ -54,14 +53,12 @@ func TestHealthNodeChecks(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.HealthNodeChecks(nil, req) resp := httptest.NewRecorder()
obj, err := srv.HealthNodeChecks(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
if idx == 0 {
t.Fatalf("bad: %v", idx)
}
// Should be 1 health check for the server // Should be 1 health check for the server
nodes := obj.(structs.HealthChecks) nodes := obj.(structs.HealthChecks)
@ -100,14 +97,12 @@ func TestHealthServiceChecks(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.HealthServiceChecks(nil, req) resp := httptest.NewRecorder()
obj, err := srv.HealthServiceChecks(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
if idx == 0 {
t.Fatalf("bad: %v", idx)
}
// Should be 1 health check for consul // Should be 1 health check for consul
nodes := obj.(structs.HealthChecks) nodes := obj.(structs.HealthChecks)
@ -130,14 +125,12 @@ func TestHealthServiceNodes(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
idx, obj, err := srv.HealthServiceNodes(nil, req) resp := httptest.NewRecorder()
obj, err := srv.HealthServiceNodes(resp, req)
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
if idx == 0 {
t.Fatalf("bad: %v", idx)
}
// Should be 1 health check for consul // Should be 1 health check for consul
nodes := obj.(structs.CheckServiceNodes) nodes := obj.(structs.CheckServiceNodes)

View File

@ -9,6 +9,7 @@ import (
"net/http" "net/http"
"net/http/httptest" "net/http/httptest"
"os" "os"
"strconv"
"testing" "testing"
"time" "time"
) )
@ -69,7 +70,7 @@ func TestContentTypeIsJSON(t *testing.T) {
func TestParseWait(t *testing.T) { func TestParseWait(t *testing.T) {
resp := httptest.NewRecorder() resp := httptest.NewRecorder()
var b structs.BlockingQuery var b structs.QueryOptions
req, err := http.NewRequest("GET", req, err := http.NewRequest("GET",
"/v1/catalog/nodes?wait=60s&index=1000", nil) "/v1/catalog/nodes?wait=60s&index=1000", nil)
@ -91,7 +92,7 @@ func TestParseWait(t *testing.T) {
func TestParseWait_InvalidTime(t *testing.T) { func TestParseWait_InvalidTime(t *testing.T) {
resp := httptest.NewRecorder() resp := httptest.NewRecorder()
var b structs.BlockingQuery var b structs.QueryOptions
req, err := http.NewRequest("GET", req, err := http.NewRequest("GET",
"/v1/catalog/nodes?wait=60foo&index=1000", nil) "/v1/catalog/nodes?wait=60foo&index=1000", nil)
@ -110,7 +111,7 @@ func TestParseWait_InvalidTime(t *testing.T) {
func TestParseWait_InvalidIndex(t *testing.T) { func TestParseWait_InvalidIndex(t *testing.T) {
resp := httptest.NewRecorder() resp := httptest.NewRecorder()
var b structs.BlockingQuery var b structs.QueryOptions
req, err := http.NewRequest("GET", req, err := http.NewRequest("GET",
"/v1/catalog/nodes?wait=60s&index=foo", nil) "/v1/catalog/nodes?wait=60s&index=foo", nil)
@ -126,3 +127,24 @@ func TestParseWait_InvalidIndex(t *testing.T) {
t.Fatalf("bad code: %v", resp.Code) t.Fatalf("bad code: %v", resp.Code)
} }
} }
// assertIndex tests that X-Consul-Index is set and non-zero
func assertIndex(t *testing.T, resp *httptest.ResponseRecorder) {
header := resp.Header().Get("X-Consul-Index")
if header == "" || header == "0" {
t.Fatalf("Bad: %v", header)
}
}
// getIndex parses X-Consul-Index
func getIndex(t *testing.T, resp *httptest.ResponseRecorder) uint64 {
header := resp.Header().Get("X-Consul-Index")
if header == "" {
t.Fatalf("Bad: %v", header)
}
val, err := strconv.Atoi(header)
if err != nil {
t.Fatalf("Bad: %v", header)
}
return uint64(val)
}

View File

@ -57,11 +57,7 @@ func TestKVSEndpoint_PUT_GET_DELETE(t *testing.T) {
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
header := resp.Header().Get("X-Consul-Index")
if header == "" {
t.Fatalf("Bad: %v", header)
}
res, ok := obj.(structs.DirEntries) res, ok := obj.(structs.DirEntries)
if !ok { if !ok {
@ -138,11 +134,7 @@ func TestKVSEndpoint_Recurse(t *testing.T) {
if err != nil { if err != nil {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
assertIndex(t, resp)
header := resp.Header().Get("X-Consul-Index")
if header == "" {
t.Fatalf("Bad: %v", header)
}
res, ok := obj.(structs.DirEntries) res, ok := obj.(structs.DirEntries)
if !ok { if !ok {