mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
consul: Adding SessionList to snapshot
This commit is contained in:
parent
c19806464b
commit
8772068163
@ -1480,3 +1480,13 @@ func (s *StateSnapshot) NodeChecks(node string) structs.HealthChecks {
|
|||||||
func (s *StateSnapshot) KVSDump(stream chan<- interface{}) error {
|
func (s *StateSnapshot) KVSDump(stream chan<- interface{}) error {
|
||||||
return s.store.kvsTable.StreamTxn(stream, s.tx, "id")
|
return s.store.kvsTable.StreamTxn(stream, s.tx, "id")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// SessionList is used to list all the open sessions
|
||||||
|
func (s *StateSnapshot) SessionList() ([]*structs.Session, error) {
|
||||||
|
res, err := s.store.sessionTable.GetTxn(s.tx, "id")
|
||||||
|
out := make([]*structs.Session, len(res))
|
||||||
|
for i, raw := range res {
|
||||||
|
out[i] = raw.(*structs.Session)
|
||||||
|
}
|
||||||
|
return out, err
|
||||||
|
}
|
||||||
|
@ -636,6 +636,21 @@ func TestStoreSnapshot(t *testing.T) {
|
|||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add some sessions
|
||||||
|
session := &structs.Session{Node: "foo"}
|
||||||
|
if err := store.SessionCreate(16, session); err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
session = &structs.Session{Node: "bar"}
|
||||||
|
if err := store.SessionCreate(17, session); err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
d.Session = session.ID
|
||||||
|
if ok, err := store.KVSLock(18, d); err != nil || !ok {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
// Take a snapshot
|
// Take a snapshot
|
||||||
snap, err := store.Snapshot()
|
snap, err := store.Snapshot()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -644,7 +659,7 @@ func TestStoreSnapshot(t *testing.T) {
|
|||||||
defer snap.Close()
|
defer snap.Close()
|
||||||
|
|
||||||
// Check the last nodes
|
// Check the last nodes
|
||||||
if idx := snap.LastIndex(); idx != 15 {
|
if idx := snap.LastIndex(); idx != 18 {
|
||||||
t.Fatalf("bad: %v", idx)
|
t.Fatalf("bad: %v", idx)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -699,14 +714,23 @@ func TestStoreSnapshot(t *testing.T) {
|
|||||||
t.Fatalf("missing KVS entries!")
|
t.Fatalf("missing KVS entries!")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check there are 2 sessions
|
||||||
|
sessions, err := snap.SessionList()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if len(sessions) != 2 {
|
||||||
|
t.Fatalf("missing sessions")
|
||||||
|
}
|
||||||
|
|
||||||
// Make some changes!
|
// Make some changes!
|
||||||
if err := store.EnsureService(14, "foo", &structs.NodeService{"db", "db", []string{"slave"}, 8000}); err != nil {
|
if err := store.EnsureService(19, "foo", &structs.NodeService{"db", "db", []string{"slave"}, 8000}); err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
if err := store.EnsureService(15, "bar", &structs.NodeService{"db", "db", []string{"master"}, 8000}); err != nil {
|
if err := store.EnsureService(20, "bar", &structs.NodeService{"db", "db", []string{"master"}, 8000}); err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
if err := store.EnsureNode(16, structs.Node{"baz", "127.0.0.3"}); err != nil {
|
if err := store.EnsureNode(21, structs.Node{"baz", "127.0.0.3"}); err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
checkAfter := &structs.HealthCheck{
|
checkAfter := &structs.HealthCheck{
|
||||||
@ -716,11 +740,11 @@ func TestStoreSnapshot(t *testing.T) {
|
|||||||
Status: structs.HealthCritical,
|
Status: structs.HealthCritical,
|
||||||
ServiceID: "db",
|
ServiceID: "db",
|
||||||
}
|
}
|
||||||
if err := store.EnsureCheck(17, checkAfter); err != nil {
|
if err := store.EnsureCheck(22, checkAfter); err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := store.KVSDelete(18, "/web/a"); err != nil {
|
if err := store.KVSDelete(23, "/web/b"); err != nil {
|
||||||
t.Fatalf("err: %v", err)
|
t.Fatalf("err: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -773,6 +797,15 @@ func TestStoreSnapshot(t *testing.T) {
|
|||||||
if len(ents) != 2 {
|
if len(ents) != 2 {
|
||||||
t.Fatalf("missing KVS entries!")
|
t.Fatalf("missing KVS entries!")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check there are 2 sessions
|
||||||
|
sessions, err = snap.SessionList()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if len(sessions) != 2 {
|
||||||
|
t.Fatalf("missing sessions")
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEnsureCheck(t *testing.T) {
|
func TestEnsureCheck(t *testing.T) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user