mirror of https://github.com/status-im/consul.git
Clean up tests, use switch to default session.Behavior value if unspecified, unrecognized
This commit is contained in:
parent
47241fc1c8
commit
6ef03a806c
|
@ -87,7 +87,7 @@ func TestSessionCreateDelete(t *testing.T) {
|
||||||
"Node": srv.agent.config.NodeName,
|
"Node": srv.agent.config.NodeName,
|
||||||
"Checks": []string{consul.SerfCheckID, "consul"},
|
"Checks": []string{consul.SerfCheckID, "consul"},
|
||||||
"LockDelay": "20s",
|
"LockDelay": "20s",
|
||||||
"Behavior": "delete",
|
"Behavior": structs.SessionKeysDelete,
|
||||||
}
|
}
|
||||||
enc.Encode(raw)
|
enc.Encode(raw)
|
||||||
|
|
||||||
|
@ -280,7 +280,7 @@ func TestSessionDeleteDestroy(t *testing.T) {
|
||||||
t.Fatalf("should work")
|
t.Fatalf("should work")
|
||||||
}
|
}
|
||||||
|
|
||||||
// now destroy the session, this should delete the key create above
|
// now destroy the session, this should delete the key created above
|
||||||
req, err = http.NewRequest("PUT", "/v1/session/destroy/"+id, nil)
|
req, err = http.NewRequest("PUT", "/v1/session/destroy/"+id, nil)
|
||||||
resp = httptest.NewRecorder()
|
resp = httptest.NewRecorder()
|
||||||
obj, err = srv.SessionDestroy(resp, req)
|
obj, err = srv.SessionDestroy(resp, req)
|
||||||
|
@ -301,71 +301,3 @@ func TestSessionDeleteDestroy(t *testing.T) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSessionDeleteGet(t *testing.T) {
|
|
||||||
httpTest(t, func(srv *HTTPServer) {
|
|
||||||
id := makeTestSessionDelete(t, srv)
|
|
||||||
|
|
||||||
req, err := http.NewRequest("GET",
|
|
||||||
"/v1/session/info/"+id, nil)
|
|
||||||
resp := httptest.NewRecorder()
|
|
||||||
obj, err := srv.SessionGet(resp, req)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
respObj, ok := obj.(structs.Sessions)
|
|
||||||
if !ok {
|
|
||||||
t.Fatalf("should work")
|
|
||||||
}
|
|
||||||
if len(respObj) != 1 {
|
|
||||||
t.Fatalf("bad: %v", respObj)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSessionDeleteList(t *testing.T) {
|
|
||||||
httpTest(t, func(srv *HTTPServer) {
|
|
||||||
var ids []string
|
|
||||||
for i := 0; i < 10; i++ {
|
|
||||||
ids = append(ids, makeTestSessionDelete(t, srv))
|
|
||||||
}
|
|
||||||
|
|
||||||
req, err := http.NewRequest("GET", "/v1/session/list", nil)
|
|
||||||
resp := httptest.NewRecorder()
|
|
||||||
obj, err := srv.SessionList(resp, req)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
respObj, ok := obj.(structs.Sessions)
|
|
||||||
if !ok {
|
|
||||||
t.Fatalf("should work")
|
|
||||||
}
|
|
||||||
if len(respObj) != 10 {
|
|
||||||
t.Fatalf("bad: %v", respObj)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSessionsDeleteForNode(t *testing.T) {
|
|
||||||
httpTest(t, func(srv *HTTPServer) {
|
|
||||||
var ids []string
|
|
||||||
for i := 0; i < 10; i++ {
|
|
||||||
ids = append(ids, makeTestSessionDelete(t, srv))
|
|
||||||
}
|
|
||||||
|
|
||||||
req, err := http.NewRequest("GET",
|
|
||||||
"/v1/session/node/"+srv.agent.config.NodeName, nil)
|
|
||||||
resp := httptest.NewRecorder()
|
|
||||||
obj, err := srv.SessionsForNode(resp, req)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
respObj, ok := obj.(structs.Sessions)
|
|
||||||
if !ok {
|
|
||||||
t.Fatalf("should work")
|
|
||||||
}
|
|
||||||
if len(respObj) != 10 {
|
|
||||||
t.Fatalf("bad: %v", respObj)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
|
@ -28,7 +28,11 @@ func (s *Session) Apply(args *structs.SessionRequest, reply *string) error {
|
||||||
if args.Session.Node == "" && args.Op == structs.SessionCreate {
|
if args.Session.Node == "" && args.Op == structs.SessionCreate {
|
||||||
return fmt.Errorf("Must provide Node")
|
return fmt.Errorf("Must provide Node")
|
||||||
}
|
}
|
||||||
if args.Session.Behavior == "" {
|
switch args.Session.Behavior {
|
||||||
|
case structs.SessionKeysRelease, structs.SessionKeysDelete:
|
||||||
|
// we like it, use it
|
||||||
|
|
||||||
|
default:
|
||||||
args.Session.Behavior = structs.SessionKeysRelease // force default behavior
|
args.Session.Behavior = structs.SessionKeysRelease // force default behavior
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -108,6 +108,9 @@ func TestSessionEndpoint_DeleteApply(t *testing.T) {
|
||||||
if s.Name != "my-session" {
|
if s.Name != "my-session" {
|
||||||
t.Fatalf("bad: %v", s)
|
t.Fatalf("bad: %v", s)
|
||||||
}
|
}
|
||||||
|
if s.Behavior != structs.SessionKeysDelete {
|
||||||
|
t.Fatalf("bad: %v", s)
|
||||||
|
}
|
||||||
|
|
||||||
// Do a delete
|
// Do a delete
|
||||||
arg.Op = structs.SessionDestroy
|
arg.Op = structs.SessionDestroy
|
||||||
|
@ -169,50 +172,6 @@ func TestSessionEndpoint_Get(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSessionEndpoint_DeleteGet(t *testing.T) {
|
|
||||||
dir1, s1 := testServer(t)
|
|
||||||
defer os.RemoveAll(dir1)
|
|
||||||
defer s1.Shutdown()
|
|
||||||
client := rpcClient(t, s1)
|
|
||||||
defer client.Close()
|
|
||||||
|
|
||||||
testutil.WaitForLeader(t, client.Call, "dc1")
|
|
||||||
|
|
||||||
s1.fsm.State().EnsureNode(1, structs.Node{"foo", "127.0.0.1"})
|
|
||||||
arg := structs.SessionRequest{
|
|
||||||
Datacenter: "dc1",
|
|
||||||
Op: structs.SessionCreate,
|
|
||||||
Session: structs.Session{
|
|
||||||
Node: "foo",
|
|
||||||
Behavior: structs.SessionKeysDelete,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
var out string
|
|
||||||
if err := client.Call("Session.Apply", &arg, &out); err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
getR := structs.SessionSpecificRequest{
|
|
||||||
Datacenter: "dc1",
|
|
||||||
Session: out,
|
|
||||||
}
|
|
||||||
var sessions structs.IndexedSessions
|
|
||||||
if err := client.Call("Session.Get", &getR, &sessions); err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if sessions.Index == 0 {
|
|
||||||
t.Fatalf("Bad: %v", sessions)
|
|
||||||
}
|
|
||||||
if len(sessions.Sessions) != 1 {
|
|
||||||
t.Fatalf("Bad: %v", sessions)
|
|
||||||
}
|
|
||||||
s := sessions.Sessions[0]
|
|
||||||
if s.ID != out {
|
|
||||||
t.Fatalf("bad: %v", s)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSessionEndpoint_List(t *testing.T) {
|
func TestSessionEndpoint_List(t *testing.T) {
|
||||||
dir1, s1 := testServer(t)
|
dir1, s1 := testServer(t)
|
||||||
defer os.RemoveAll(dir1)
|
defer os.RemoveAll(dir1)
|
||||||
|
@ -264,58 +223,6 @@ func TestSessionEndpoint_List(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSessionEndpoint_DeleteList(t *testing.T) {
|
|
||||||
dir1, s1 := testServer(t)
|
|
||||||
defer os.RemoveAll(dir1)
|
|
||||||
defer s1.Shutdown()
|
|
||||||
client := rpcClient(t, s1)
|
|
||||||
defer client.Close()
|
|
||||||
|
|
||||||
testutil.WaitForLeader(t, client.Call, "dc1")
|
|
||||||
|
|
||||||
s1.fsm.State().EnsureNode(1, structs.Node{"foo", "127.0.0.1"})
|
|
||||||
ids := []string{}
|
|
||||||
for i := 0; i < 5; i++ {
|
|
||||||
arg := structs.SessionRequest{
|
|
||||||
Datacenter: "dc1",
|
|
||||||
Op: structs.SessionCreate,
|
|
||||||
Session: structs.Session{
|
|
||||||
Node: "foo",
|
|
||||||
Behavior: structs.SessionKeysDelete,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
var out string
|
|
||||||
if err := client.Call("Session.Apply", &arg, &out); err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
ids = append(ids, out)
|
|
||||||
}
|
|
||||||
|
|
||||||
getR := structs.DCSpecificRequest{
|
|
||||||
Datacenter: "dc1",
|
|
||||||
}
|
|
||||||
var sessions structs.IndexedSessions
|
|
||||||
if err := client.Call("Session.List", &getR, &sessions); err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if sessions.Index == 0 {
|
|
||||||
t.Fatalf("Bad: %v", sessions)
|
|
||||||
}
|
|
||||||
if len(sessions.Sessions) != 5 {
|
|
||||||
t.Fatalf("Bad: %v", sessions.Sessions)
|
|
||||||
}
|
|
||||||
for i := 0; i < len(sessions.Sessions); i++ {
|
|
||||||
s := sessions.Sessions[i]
|
|
||||||
if !strContains(ids, s.ID) {
|
|
||||||
t.Fatalf("bad: %v", s)
|
|
||||||
}
|
|
||||||
if s.Node != "foo" {
|
|
||||||
t.Fatalf("bad: %v", s)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSessionEndpoint_NodeSessions(t *testing.T) {
|
func TestSessionEndpoint_NodeSessions(t *testing.T) {
|
||||||
dir1, s1 := testServer(t)
|
dir1, s1 := testServer(t)
|
||||||
defer os.RemoveAll(dir1)
|
defer os.RemoveAll(dir1)
|
||||||
|
@ -373,62 +280,3 @@ func TestSessionEndpoint_NodeSessions(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSessionEndpoint_DeleteNodeSessions(t *testing.T) {
|
|
||||||
dir1, s1 := testServer(t)
|
|
||||||
defer os.RemoveAll(dir1)
|
|
||||||
defer s1.Shutdown()
|
|
||||||
client := rpcClient(t, s1)
|
|
||||||
defer client.Close()
|
|
||||||
|
|
||||||
testutil.WaitForLeader(t, client.Call, "dc1")
|
|
||||||
|
|
||||||
s1.fsm.State().EnsureNode(1, structs.Node{"foo", "127.0.0.1"})
|
|
||||||
s1.fsm.State().EnsureNode(1, structs.Node{"bar", "127.0.0.1"})
|
|
||||||
ids := []string{}
|
|
||||||
for i := 0; i < 10; i++ {
|
|
||||||
arg := structs.SessionRequest{
|
|
||||||
Datacenter: "dc1",
|
|
||||||
Op: structs.SessionCreate,
|
|
||||||
Session: structs.Session{
|
|
||||||
Node: "bar",
|
|
||||||
Behavior: structs.SessionKeysDelete,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
if i < 5 {
|
|
||||||
arg.Session.Node = "foo"
|
|
||||||
}
|
|
||||||
var out string
|
|
||||||
if err := client.Call("Session.Apply", &arg, &out); err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
if i < 5 {
|
|
||||||
ids = append(ids, out)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
getR := structs.NodeSpecificRequest{
|
|
||||||
Datacenter: "dc1",
|
|
||||||
Node: "foo",
|
|
||||||
}
|
|
||||||
var sessions structs.IndexedSessions
|
|
||||||
if err := client.Call("Session.NodeSessions", &getR, &sessions); err != nil {
|
|
||||||
t.Fatalf("err: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if sessions.Index == 0 {
|
|
||||||
t.Fatalf("Bad: %v", sessions)
|
|
||||||
}
|
|
||||||
if len(sessions.Sessions) != 5 {
|
|
||||||
t.Fatalf("Bad: %v", sessions.Sessions)
|
|
||||||
}
|
|
||||||
for i := 0; i < len(sessions.Sessions); i++ {
|
|
||||||
s := sessions.Sessions[i]
|
|
||||||
if !strContains(ids, s.ID) {
|
|
||||||
t.Fatalf("bad: %v", s)
|
|
||||||
}
|
|
||||||
if s.Node != "foo" {
|
|
||||||
t.Fatalf("bad: %v", s)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
@ -1327,8 +1327,11 @@ func (s *StateStore) SessionCreate(index uint64, session *structs.Session) error
|
||||||
return fmt.Errorf("Missing Session ID")
|
return fmt.Errorf("Missing Session ID")
|
||||||
}
|
}
|
||||||
|
|
||||||
// make sure we have a default set for session.Behavior
|
switch session.Behavior {
|
||||||
if session.Behavior == "" {
|
case structs.SessionKeysRelease, structs.SessionKeysDelete:
|
||||||
|
// we like
|
||||||
|
default:
|
||||||
|
// force SessionKeysRelease
|
||||||
session.Behavior = structs.SessionKeysRelease
|
session.Behavior = structs.SessionKeysRelease
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue