mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-26 19:17:24 +00:00
0c4017cc20
Replace `neofs-api-go` module with `neofs-sdk-go`. Adapt to NeoFS response statuses in the implementation of NeoFS oracle. Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
92 lines
2.3 KiB
Go
92 lines
2.3 KiB
Go
package neofs
|
|
|
|
import (
|
|
"errors"
|
|
"net/url"
|
|
"testing"
|
|
|
|
cid "github.com/nspcc-dev/neofs-sdk-go/container/id"
|
|
"github.com/nspcc-dev/neofs-sdk-go/object"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestParseRange(t *testing.T) {
|
|
t.Run("valid", func(t *testing.T) {
|
|
r, err := parseRange("13|87")
|
|
require.NoError(t, err)
|
|
require.Equal(t, uint64(13), r.GetOffset())
|
|
require.Equal(t, uint64(87), r.GetLength())
|
|
})
|
|
t.Run("missing offset", func(t *testing.T) {
|
|
_, err := parseRange("|87")
|
|
require.Error(t, err)
|
|
})
|
|
t.Run("missing length", func(t *testing.T) {
|
|
_, err := parseRange("13|")
|
|
require.Error(t, err)
|
|
})
|
|
t.Run("missing separator", func(t *testing.T) {
|
|
_, err := parseRange("1387")
|
|
require.Error(t, err)
|
|
})
|
|
t.Run("invalid number", func(t *testing.T) {
|
|
_, err := parseRange("ab|87")
|
|
require.Error(t, err)
|
|
})
|
|
}
|
|
|
|
func TestParseNeoFSURL(t *testing.T) {
|
|
cStr := "C3swfg8MiMJ9bXbeFG6dWJTCoHp9hAEZkHezvbSwK1Cc"
|
|
containerID := cid.New()
|
|
require.NoError(t, containerID.Parse(cStr))
|
|
|
|
oStr := "3nQH1L8u3eM9jt2mZCs6MyjzdjerdSzBkXCYYj4M4Znk"
|
|
oid := object.NewID()
|
|
require.NoError(t, oid.Parse(oStr))
|
|
|
|
validPrefix := "neofs:" + cStr + "/" + oStr
|
|
objectAddr := object.NewAddress()
|
|
objectAddr.SetContainerID(containerID)
|
|
objectAddr.SetObjectID(oid)
|
|
|
|
testCases := []struct {
|
|
url string
|
|
params []string
|
|
err error
|
|
}{
|
|
{validPrefix, nil, nil},
|
|
{validPrefix + "/", []string{""}, nil},
|
|
{validPrefix + "/range/1|2", []string{"range", "1|2"}, nil},
|
|
{"neoffs:" + cStr + "/" + oStr, nil, ErrInvalidScheme},
|
|
{"neofs:" + cStr, nil, ErrMissingObject},
|
|
{"neofs:" + cStr + "ooo/" + oStr, nil, ErrInvalidContainer},
|
|
{"neofs:" + cStr + "/ooo" + oStr, nil, ErrInvalidObject},
|
|
}
|
|
for _, tc := range testCases {
|
|
t.Run(tc.url, func(t *testing.T) {
|
|
u, err := url.Parse(tc.url)
|
|
require.NoError(t, err)
|
|
oa, ps, err := parseNeoFSURL(u)
|
|
if tc.err != nil {
|
|
require.True(t, errors.Is(err, tc.err), "got: %#v", err)
|
|
return
|
|
}
|
|
require.NoError(t, err)
|
|
require.Equal(t, objectAddr, oa)
|
|
require.Equal(t, len(tc.params), len(ps))
|
|
if len(ps) != 0 {
|
|
require.Equal(t, tc.params, ps)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_checkUTF8(t *testing.T) {
|
|
_, err := checkUTF8([]byte{0xFF})
|
|
require.Error(t, err)
|
|
|
|
a := []byte{1, 2, 3}
|
|
b, err := checkUTF8(a)
|
|
require.NoError(t, err)
|
|
require.Equal(t, a, b)
|
|
}
|