mirror of
https://github.com/status-im/consul.git
synced 2025-01-28 06:25:25 +00:00
Adds node snap and watch tests as well as a general watch test.
This commit is contained in:
parent
c8d0d09087
commit
005a7e0ab1
@ -206,6 +206,20 @@ func TestStateStore_ReapTombstones(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestStateStore_GetTableWatch(t *testing.T) {
|
||||||
|
s := testStateStore(t)
|
||||||
|
|
||||||
|
// This test does two things - it makes sure there's no full table
|
||||||
|
// watch for KVS, and it makes sure that asking for a watch that
|
||||||
|
// doesn't exist causes a panic.
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r == nil {
|
||||||
|
t.Fatalf("didn't get expected panic")
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
s.GetTableWatch("kvs")
|
||||||
|
}
|
||||||
|
|
||||||
func TestStateStore_EnsureRegistration(t *testing.T) {
|
func TestStateStore_EnsureRegistration(t *testing.T) {
|
||||||
s := testStateStore(t)
|
s := testStateStore(t)
|
||||||
|
|
||||||
@ -504,6 +518,66 @@ func TestStateStore_DeleteNode(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestStateStore_Node_Snapshot(t *testing.T) {
|
||||||
|
s := testStateStore(t)
|
||||||
|
|
||||||
|
// Create some nodes in the state store.
|
||||||
|
testRegisterNode(t, s, 0, "node0")
|
||||||
|
testRegisterNode(t, s, 1, "node1")
|
||||||
|
testRegisterNode(t, s, 2, "node2")
|
||||||
|
|
||||||
|
// Snapshot the nodes.
|
||||||
|
snap := s.Snapshot()
|
||||||
|
defer snap.Close()
|
||||||
|
|
||||||
|
// Verify the snapshot.
|
||||||
|
if idx := snap.LastIndex(); idx != 2 {
|
||||||
|
t.Fatalf("bad index: %d", idx)
|
||||||
|
}
|
||||||
|
dump, err := snap.NodeDump()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
if n := len(dump); n != 3 {
|
||||||
|
t.Fatalf("bad node count: %d", n)
|
||||||
|
}
|
||||||
|
for i, node := range dump {
|
||||||
|
if node.CreateIndex != uint64(i) || node.ModifyIndex != uint64(i) {
|
||||||
|
t.Fatalf("bad node index: %d, %d", node.CreateIndex, node.ModifyIndex)
|
||||||
|
}
|
||||||
|
name := fmt.Sprintf("node%d", i)
|
||||||
|
if node.Node != name {
|
||||||
|
t.Fatalf("bad: %#v", node)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestStateStore_Node_Watches(t *testing.T) {
|
||||||
|
s := testStateStore(t)
|
||||||
|
|
||||||
|
// Call functions that update the nodes table and make sure a watch fires
|
||||||
|
// each time.
|
||||||
|
verifyWatch(t, s.GetTableWatch("nodes"), func() {
|
||||||
|
req := &structs.RegisterRequest{
|
||||||
|
Node: "node1",
|
||||||
|
}
|
||||||
|
if err := s.EnsureRegistration(1, req); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
verifyWatch(t, s.GetTableWatch("nodes"), func() {
|
||||||
|
node := &structs.Node{Node: "node2"}
|
||||||
|
if err := s.EnsureNode(2, node); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
verifyWatch(t, s.GetTableWatch("nodes"), func() {
|
||||||
|
if err := s.DeleteNode(3, "node2"); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func TestStateStore_EnsureService(t *testing.T) {
|
func TestStateStore_EnsureService(t *testing.T) {
|
||||||
s := testStateStore(t)
|
s := testStateStore(t)
|
||||||
|
|
||||||
@ -2113,7 +2187,7 @@ func TestStateStore_ACL_Snapshot_Restore(t *testing.T) {
|
|||||||
func TestStateStore_ACL_Watches(t *testing.T) {
|
func TestStateStore_ACL_Watches(t *testing.T) {
|
||||||
s := testStateStore(t)
|
s := testStateStore(t)
|
||||||
|
|
||||||
// Call functions that update the ACLs table and make sure a watch fires
|
// Call functions that update the acls table and make sure a watch fires
|
||||||
// each time.
|
// each time.
|
||||||
verifyWatch(t, s.GetTableWatch("acls"), func() {
|
verifyWatch(t, s.GetTableWatch("acls"), func() {
|
||||||
if err := s.ACLSet(1, &structs.ACL{ID: "acl1"}); err != nil {
|
if err := s.ACLSet(1, &structs.ACL{ID: "acl1"}); err != nil {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user