forked from TrueCloudLab/frostfs-sdk-go
[#80] netmap: process subnet in selection
Signed-off-by: Evgenii Stratonikov <evgeniy@nspcc.ru>
This commit is contained in:
parent
b49404d9b6
commit
279a5a1e0b
4 changed files with 135 additions and 2 deletions
|
@ -1,13 +1,117 @@
|
|||
package netmap
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"strconv"
|
||||
"testing"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/v2/netmap"
|
||||
subnetid "github.com/nspcc-dev/neofs-sdk-go/subnet/id"
|
||||
"github.com/stretchr/testify/assert"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
const subnetAttrPrefix = "__NEOFS_SUBNET"
|
||||
|
||||
func subnetAttrName(subnet uint32) string {
|
||||
return subnetAttrPrefix + "." +
|
||||
strconv.FormatUint(uint64(subnet), 10) + ".ENABLED"
|
||||
}
|
||||
|
||||
func TestPlacementPolicy_Subnet(t *testing.T) {
|
||||
nodes := []NodeInfo{
|
||||
nodeInfoFromAttributes("ID", "0", "City", "Paris"),
|
||||
nodeInfoFromAttributes("ID", "1", "City", "Paris"),
|
||||
nodeInfoFromAttributes("ID", "2", "City", "London"),
|
||||
nodeInfoFromAttributes("ID", "3", "City", "London"),
|
||||
nodeInfoFromAttributes("ID", "4", "City", "Toronto"),
|
||||
nodeInfoFromAttributes("ID", "5", "City", "Toronto"),
|
||||
nodeInfoFromAttributes("ID", "6", "City", "Tokyo"),
|
||||
nodeInfoFromAttributes("ID", "7", "City", "Tokyo"),
|
||||
}
|
||||
var id subnetid.ID
|
||||
nodes[0].ExitSubnet(id)
|
||||
|
||||
id.SetNumber(1)
|
||||
nodes[2].EnterSubnet(id)
|
||||
nodes[4].EnterSubnet(id)
|
||||
|
||||
id.SetNumber(2)
|
||||
nodes[5].EnterSubnet(id)
|
||||
nodes[6].EnterSubnet(id)
|
||||
nodes[7].EnterSubnet(id)
|
||||
|
||||
nm, err := NewNetmap(NodesFromInfo(nodes))
|
||||
require.NoError(t, err)
|
||||
|
||||
t.Run("select 2 nodes from the default subnet in Paris", func(t *testing.T) {
|
||||
p := newPlacementPolicy(0,
|
||||
[]*Replica{newReplica(1, "S")},
|
||||
[]*Selector{newSelector("S", "City", ClauseSame, 2, "F")},
|
||||
[]*Filter{newFilter("F", "City", "Paris", OpEQ)})
|
||||
|
||||
_, err := nm.GetContainerNodes(p, nil)
|
||||
require.True(t, errors.Is(err, ErrNotEnoughNodes), "got: %v", err)
|
||||
})
|
||||
t.Run("select 2 nodes from the default subnet in London", func(t *testing.T) {
|
||||
p := newPlacementPolicy(0,
|
||||
[]*Replica{newReplica(1, "S")},
|
||||
[]*Selector{newSelector("S", "City", ClauseSame, 2, "F")},
|
||||
[]*Filter{newFilter("F", "City", "London", OpEQ)})
|
||||
|
||||
v, err := nm.GetContainerNodes(p, nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
nodes := v.Flatten()
|
||||
require.Equal(t, 2, len(nodes))
|
||||
for _, n := range v.Flatten() {
|
||||
id := n.Attribute("ID")
|
||||
require.Contains(t, []string{"2", "3"}, id)
|
||||
}
|
||||
})
|
||||
t.Run("select 2 nodes from the default subnet in Toronto", func(t *testing.T) {
|
||||
p := newPlacementPolicy(0,
|
||||
[]*Replica{newReplica(1, "S")},
|
||||
[]*Selector{newSelector("S", "City", ClauseSame, 2, "F")},
|
||||
[]*Filter{newFilter("F", "City", "Toronto", OpEQ)})
|
||||
|
||||
v, err := nm.GetContainerNodes(p, nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
nodes := v.Flatten()
|
||||
require.Equal(t, 2, len(nodes))
|
||||
for _, n := range v.Flatten() {
|
||||
id := n.Attribute("ID")
|
||||
require.Contains(t, []string{"4", "5"}, id)
|
||||
}
|
||||
})
|
||||
t.Run("select 3 nodes from the non-default subnet", func(t *testing.T) {
|
||||
p := newPlacementPolicy(0,
|
||||
[]*Replica{newReplica(3, "")},
|
||||
nil, nil)
|
||||
p.SetSubnetID(newSubnetID(2))
|
||||
|
||||
v, err := nm.GetContainerNodes(p, nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
nodes := v.Flatten()
|
||||
require.Equal(t, 3, len(nodes))
|
||||
for _, n := range v.Flatten() {
|
||||
id := n.Attribute("ID")
|
||||
require.Contains(t, []string{"5", "6", "7"}, id)
|
||||
}
|
||||
})
|
||||
t.Run("select nodes from the subnet via filter", func(t *testing.T) {
|
||||
p := newPlacementPolicy(0,
|
||||
[]*Replica{newReplica(1, "")},
|
||||
nil,
|
||||
[]*Filter{newFilter(MainFilterName, subnetAttrName(2), "True", OpEQ, nil)})
|
||||
|
||||
_, err := nm.GetContainerNodes(p, nil)
|
||||
require.Error(t, err)
|
||||
})
|
||||
}
|
||||
|
||||
func TestPlacementPolicy_CBFWithEmptySelector(t *testing.T) {
|
||||
nodes := []NodeInfo{
|
||||
nodeInfoFromAttributes("ID", "1", "Attr", "Same"),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue