forked from TrueCloudLab/frostfs-api-go
79f72e10c9
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
88 lines
1.9 KiB
Go
88 lines
1.9 KiB
Go
package object
|
|
|
|
import (
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/nspcc-dev/neofs-api-go/pkg/container"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestAddress_SetContainerID(t *testing.T) {
|
|
a := NewAddress()
|
|
|
|
cid := container.NewID()
|
|
cid.SetSHA256(randSHA256Checksum(t))
|
|
|
|
a.SetContainerID(cid)
|
|
|
|
require.Equal(t, cid, a.ContainerID())
|
|
}
|
|
|
|
func TestAddress_SetObjectID(t *testing.T) {
|
|
a := NewAddress()
|
|
|
|
oid := randID(t)
|
|
|
|
a.SetObjectID(oid)
|
|
|
|
require.Equal(t, oid, a.ObjectID())
|
|
}
|
|
|
|
func TestAddress_Parse(t *testing.T) {
|
|
cid := container.NewID()
|
|
cid.SetSHA256(randSHA256Checksum(t))
|
|
|
|
oid := NewID()
|
|
oid.SetSHA256(randSHA256Checksum(t))
|
|
|
|
t.Run("should parse successful", func(t *testing.T) {
|
|
s := strings.Join([]string{cid.String(), oid.String()}, addressSeparator)
|
|
a := NewAddress()
|
|
|
|
require.NoError(t, a.Parse(s))
|
|
require.Equal(t, oid, a.ObjectID())
|
|
require.Equal(t, cid, a.ContainerID())
|
|
})
|
|
|
|
t.Run("should fail for bad address", func(t *testing.T) {
|
|
s := strings.Join([]string{cid.String()}, addressSeparator)
|
|
require.EqualError(t, NewAddress().Parse(s), errInvalidAddressString.Error())
|
|
})
|
|
|
|
t.Run("should fail on container.ID", func(t *testing.T) {
|
|
s := strings.Join([]string{"1", "2"}, addressSeparator)
|
|
require.Error(t, NewAddress().Parse(s))
|
|
})
|
|
|
|
t.Run("should fail on object.ID", func(t *testing.T) {
|
|
s := strings.Join([]string{cid.String(), "2"}, addressSeparator)
|
|
require.Error(t, NewAddress().Parse(s))
|
|
})
|
|
}
|
|
|
|
func TestAddressEncoding(t *testing.T) {
|
|
a := NewAddress()
|
|
a.SetObjectID(randID(t))
|
|
a.SetContainerID(randCID(t))
|
|
|
|
t.Run("binary", func(t *testing.T) {
|
|
data, err := a.Marshal()
|
|
require.NoError(t, err)
|
|
|
|
a2 := NewAddress()
|
|
require.NoError(t, a2.Unmarshal(data))
|
|
|
|
require.Equal(t, a, a2)
|
|
})
|
|
|
|
t.Run("json", func(t *testing.T) {
|
|
data, err := a.MarshalJSON()
|
|
require.NoError(t, err)
|
|
|
|
a2 := NewAddress()
|
|
require.NoError(t, a2.UnmarshalJSON(data))
|
|
|
|
require.Equal(t, a, a2)
|
|
})
|
|
}
|