forked from TrueCloudLab/frostfs-api-go
91eade02cd
Signed-off-by: Alex Vanin <alexey@nspcc.ru>
136 lines
3.3 KiB
Go
136 lines
3.3 KiB
Go
package object_test
|
|
|
|
import (
|
|
"crypto/rand"
|
|
"crypto/sha256"
|
|
"testing"
|
|
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/object"
|
|
v2object "github.com/nspcc-dev/neofs-api-go/v2/object"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
var (
|
|
eqV2Matches = map[object.SearchMatchType]v2object.MatchType{
|
|
object.MatchUnknown: v2object.MatchUnknown,
|
|
object.MatchStringEqual: v2object.MatchStringEqual,
|
|
}
|
|
)
|
|
|
|
func TestMatch(t *testing.T) {
|
|
t.Run("known matches", func(t *testing.T) {
|
|
for i := object.MatchUnknown; i <= object.MatchStringEqual; i++ {
|
|
require.Equal(t, eqV2Matches[i], i.ToV2())
|
|
require.Equal(t, object.SearchMatchFromV2(i.ToV2()), i)
|
|
}
|
|
})
|
|
|
|
t.Run("unknown matches", func(t *testing.T) {
|
|
require.Equal(t, (object.MatchStringEqual + 1).ToV2(), v2object.MatchUnknown)
|
|
require.Equal(t, object.SearchMatchFromV2(v2object.MatchStringEqual+1), object.MatchUnknown)
|
|
})
|
|
}
|
|
|
|
func TestFilter(t *testing.T) {
|
|
inputs := [][]string{
|
|
{"user-header", "user-value"},
|
|
}
|
|
|
|
filters := object.NewSearchFilters()
|
|
for i := range inputs {
|
|
filters.AddFilter(inputs[i][0], inputs[i][1], object.MatchStringEqual)
|
|
}
|
|
|
|
require.Len(t, filters, len(inputs))
|
|
for i := range inputs {
|
|
require.Equal(t, inputs[i][0], filters[i].Header())
|
|
require.Equal(t, inputs[i][1], filters[i].Value())
|
|
require.Equal(t, object.MatchStringEqual, filters[i].Operation())
|
|
}
|
|
|
|
v2 := filters.ToV2()
|
|
newFilters := object.NewSearchFiltersFromV2(v2)
|
|
require.Equal(t, filters, newFilters)
|
|
}
|
|
|
|
func TestSearchFilters_AddRootFilter(t *testing.T) {
|
|
fs := new(object.SearchFilters)
|
|
|
|
fs.AddRootFilter()
|
|
|
|
require.Len(t, *fs, 1)
|
|
|
|
f := (*fs)[0]
|
|
|
|
require.Equal(t, object.MatchStringEqual, f.Operation())
|
|
require.Equal(t, v2object.FilterPropertyRoot, f.Header())
|
|
require.Equal(t, v2object.BooleanPropertyValueTrue, f.Value())
|
|
}
|
|
|
|
func TestSearchFilters_AddNonRootFilter(t *testing.T) {
|
|
fs := new(object.SearchFilters)
|
|
|
|
fs.AddNonRootFilter()
|
|
|
|
require.Len(t, *fs, 1)
|
|
|
|
f := (*fs)[0]
|
|
|
|
require.Equal(t, object.MatchStringEqual, f.Operation())
|
|
require.Equal(t, v2object.FilterPropertyRoot, f.Header())
|
|
require.Equal(t, v2object.BooleanPropertyValueFalse, f.Value())
|
|
}
|
|
|
|
func TestSearchFilters_AddPhyFilter(t *testing.T) {
|
|
fs := new(object.SearchFilters)
|
|
|
|
fs.AddPhyFilter()
|
|
|
|
require.Len(t, *fs, 1)
|
|
|
|
f := (*fs)[0]
|
|
|
|
require.Equal(t, object.MatchStringEqual, f.Operation())
|
|
require.Equal(t, v2object.FilterPropertyPhy, f.Header())
|
|
require.Equal(t, v2object.BooleanPropertyValueTrue, f.Value())
|
|
}
|
|
|
|
func TestSearchFilters_AddNonPhyFilter(t *testing.T) {
|
|
fs := new(object.SearchFilters)
|
|
|
|
fs.AddNonPhyFilter()
|
|
|
|
require.Len(t, *fs, 1)
|
|
|
|
f := (*fs)[0]
|
|
|
|
require.Equal(t, object.MatchStringEqual, f.Operation())
|
|
require.Equal(t, v2object.FilterPropertyPhy, f.Header())
|
|
require.Equal(t, v2object.BooleanPropertyValueFalse, f.Value())
|
|
}
|
|
|
|
func testOID() *object.ID {
|
|
cs := [sha256.Size]byte{}
|
|
|
|
rand.Read(cs[:])
|
|
|
|
id := object.NewID()
|
|
id.SetSHA256(cs)
|
|
|
|
return id
|
|
}
|
|
|
|
func TestSearchFilters_AddParentIDFilter(t *testing.T) {
|
|
par := testOID()
|
|
|
|
fs := object.SearchFilters{}
|
|
fs.AddParentIDFilter(object.MatchStringEqual, par)
|
|
|
|
fsV2 := fs.ToV2()
|
|
|
|
require.Len(t, fsV2, 1)
|
|
|
|
require.Equal(t, v2object.FilterHeaderParent, fsV2[0].GetKey())
|
|
require.Equal(t, par.String(), fsV2[0].GetValue())
|
|
require.Equal(t, v2object.MatchStringEqual, fsV2[0].GetMatchType())
|
|
}
|