mirror of https://github.com/hashicorp/consul
Adds a test for node UUID or name lookups.
parent
35fd064a79
commit
15e2e64c00
|
@ -680,7 +680,7 @@ func (s *StateStore) NodeService(nodeName string, serviceID string) (uint64, *st
|
|||
}
|
||||
}
|
||||
|
||||
// NodeServices is used to query service registrations by node ID.
|
||||
// NodeServices is used to query service registrations by node name or UUID.
|
||||
func (s *StateStore) NodeServices(ws memdb.WatchSet, nodeNameOrID string) (uint64, *structs.NodeServices, error) {
|
||||
tx := s.db.Txn(false)
|
||||
defer tx.Abort()
|
||||
|
|
|
@ -579,6 +579,105 @@ func TestStateStore_GetNodesByMeta(t *testing.T) {
|
|||
}
|
||||
}
|
||||
|
||||
func TestStateStore_NodeServices(t *testing.T) {
|
||||
s := testStateStore(t)
|
||||
|
||||
// Register some nodes with similar IDs.
|
||||
{
|
||||
req := &structs.RegisterRequest{
|
||||
ID: types.NodeID("40e4a748-2192-161a-0510-aaaaaaaaaaaa"),
|
||||
Node: "node1",
|
||||
Address: "1.2.3.4",
|
||||
}
|
||||
if err := s.EnsureRegistration(1, req); err != nil {
|
||||
t.Fatalf("err: %s", err)
|
||||
}
|
||||
}
|
||||
{
|
||||
req := &structs.RegisterRequest{
|
||||
ID: types.NodeID("40e4a748-2192-161a-0510-bbbbbbbbbbbb"),
|
||||
Node: "node2",
|
||||
Address: "5.6.7.8",
|
||||
}
|
||||
if err := s.EnsureRegistration(2, req); err != nil {
|
||||
t.Fatalf("err: %s", err)
|
||||
}
|
||||
}
|
||||
|
||||
// Look up by name.
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "node1")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns == nil || ns.Node.Node != "node1" {
|
||||
t.Fatalf("bad: %#v", *ns)
|
||||
}
|
||||
}
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "node2")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns == nil || ns.Node.Node != "node2" {
|
||||
t.Fatalf("bad: %#v", *ns)
|
||||
}
|
||||
}
|
||||
|
||||
// Look up by UUID.
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "40e4a748-2192-161a-0510-aaaaaaaaaaaa")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns == nil || ns.Node.Node != "node1" {
|
||||
t.Fatalf("bad: %#v", ns)
|
||||
}
|
||||
}
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "40e4a748-2192-161a-0510-bbbbbbbbbbbb")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns == nil || ns.Node.Node != "node2" {
|
||||
t.Fatalf("bad: %#v", ns)
|
||||
}
|
||||
}
|
||||
|
||||
// Ambiguous prefix.
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "40e4a748-2192-161a-0510")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns != nil {
|
||||
t.Fatalf("bad: %#v", ns)
|
||||
}
|
||||
}
|
||||
|
||||
// Bad node, and not a UUID (should not get a UUID error).
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "nope")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns != nil {
|
||||
t.Fatalf("bad: %#v", ns)
|
||||
}
|
||||
}
|
||||
|
||||
// Specific prefix.
|
||||
{
|
||||
_, ns, err := s.NodeServices(nil, "40e4a748-2192-161a-0510-bb")
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
if ns == nil || ns.Node.Node != "node2" {
|
||||
t.Fatalf("bad: %#v", ns)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestStateStore_DeleteNode(t *testing.T) {
|
||||
s := testStateStore(t)
|
||||
|
||||
|
|
Loading…
Reference in New Issue