137641f090
The Add method on the multinode DB interface accepts a set of parameters which are already fields in the nodes.Node struct excluding the name field. When adding a new node, you're forced to call UpdateName() method after calling the Add() method in order to save a node and update the name. This change allows passing the nodes.Node entity which includes the name field. With this, a new node can be added together with the name without invoking the UpdateName() method. Change-Id: I281ec628dffaade35d6db4479a84f39636200072
126 lines
4.1 KiB
Go
126 lines
4.1 KiB
Go
// Copyright (C) 2020 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package nodes_test
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"storj.io/common/testcontext"
|
|
"storj.io/common/testrand"
|
|
"storj.io/storj/multinode"
|
|
"storj.io/storj/multinode/multinodedb/multinodedbtest"
|
|
"storj.io/storj/multinode/nodes"
|
|
)
|
|
|
|
func TestNodesDB(t *testing.T) {
|
|
multinodedbtest.Run(t, func(ctx *testcontext.Context, t *testing.T, db multinode.DB) {
|
|
nodesRepository := db.Nodes()
|
|
|
|
nodeID := testrand.NodeID()
|
|
apiSecret := []byte("secret")
|
|
publicAddress := "228.13.38.1:8081"
|
|
|
|
err := nodesRepository.Add(ctx, nodes.Node{ID: nodeID, APISecret: apiSecret, PublicAddress: publicAddress})
|
|
assert.NoError(t, err)
|
|
|
|
node, err := nodesRepository.Get(ctx, nodeID)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, node.ID.Bytes(), nodeID.Bytes())
|
|
assert.Equal(t, node.APISecret, apiSecret)
|
|
assert.Equal(t, node.PublicAddress, publicAddress)
|
|
|
|
allNodes, err := nodesRepository.List(ctx)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, len(allNodes), 1)
|
|
assert.Equal(t, node.ID.Bytes(), allNodes[0].ID.Bytes())
|
|
assert.Equal(t, node.APISecret, allNodes[0].APISecret)
|
|
assert.Equal(t, node.PublicAddress, allNodes[0].PublicAddress)
|
|
|
|
newName := "Alice"
|
|
err = nodesRepository.UpdateName(ctx, nodeID, newName)
|
|
assert.NoError(t, err)
|
|
|
|
node, err = nodesRepository.Get(ctx, nodeID)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, node.Name, newName)
|
|
|
|
err = nodesRepository.Remove(ctx, nodeID)
|
|
assert.NoError(t, err)
|
|
|
|
_, err = nodesRepository.List(ctx)
|
|
assert.Error(t, err)
|
|
assert.True(t, nodes.ErrNoNode.Has(err))
|
|
|
|
_, err = nodesRepository.Get(ctx, nodeID)
|
|
assert.Error(t, err)
|
|
assert.True(t, nodes.ErrNoNode.Has(err))
|
|
|
|
t.Run("pagination tests", func(t *testing.T) {
|
|
const nodesAmount = 10
|
|
nodeList := make([]nodes.Node, 0)
|
|
for i := 0; i < nodesAmount; i++ {
|
|
node := nodes.Node{
|
|
ID: testrand.NodeID(),
|
|
APISecret: []byte{uint8(i)},
|
|
PublicAddress: fmt.Sprintf("%d", i),
|
|
Name: fmt.Sprintf("%d", i),
|
|
}
|
|
nodeList = append(nodeList, node)
|
|
err := nodesRepository.Add(ctx, node)
|
|
require.NoError(t, err)
|
|
}
|
|
page, err := nodesRepository.ListPaged(ctx, nodes.Cursor{
|
|
Limit: 2,
|
|
Page: 1,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, page.TotalCount, int64(nodesAmount))
|
|
assert.Equal(t, 2, len(page.Nodes))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[0].ID.Bytes(), page.Nodes[0].ID.Bytes()))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[1].ID.Bytes(), page.Nodes[1].ID.Bytes()))
|
|
page, err = nodesRepository.ListPaged(ctx, nodes.Cursor{
|
|
Limit: 2,
|
|
Page: 2,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, page.TotalCount, int64(nodesAmount))
|
|
assert.Equal(t, 2, len(page.Nodes))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[2].ID.Bytes(), page.Nodes[0].ID.Bytes()))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[3].ID.Bytes(), page.Nodes[1].ID.Bytes()))
|
|
page, err = nodesRepository.ListPaged(ctx, nodes.Cursor{
|
|
Limit: 2,
|
|
Page: 3,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, page.TotalCount, int64(nodesAmount))
|
|
assert.Equal(t, 2, len(page.Nodes))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[4].ID.Bytes(), page.Nodes[0].ID.Bytes()))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[5].ID.Bytes(), page.Nodes[1].ID.Bytes()))
|
|
page, err = nodesRepository.ListPaged(ctx, nodes.Cursor{
|
|
Limit: 2,
|
|
Page: 4,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, page.TotalCount, int64(nodesAmount))
|
|
assert.Equal(t, 2, len(page.Nodes))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[6].ID.Bytes(), page.Nodes[0].ID.Bytes()))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[7].ID.Bytes(), page.Nodes[1].ID.Bytes()))
|
|
page, err = nodesRepository.ListPaged(ctx, nodes.Cursor{
|
|
Limit: 2,
|
|
Page: 5,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, page.TotalCount, int64(nodesAmount))
|
|
assert.Equal(t, 2, len(page.Nodes))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[8].ID.Bytes(), page.Nodes[0].ID.Bytes()))
|
|
assert.Equal(t, 0, bytes.Compare(nodeList[9].ID.Bytes(), page.Nodes[1].ID.Bytes()))
|
|
})
|
|
})
|
|
}
|