forked from TrueCloudLab/frostfs-api-go
Add stable marshal for refs package
Signed-off-by: Alex Vanin <alexey@nspcc.ru>
This commit is contained in:
parent
f8e6908e50
commit
2c33e22db5
2 changed files with 246 additions and 0 deletions
157
v2/refs/marshal.go
Normal file
157
v2/refs/marshal.go
Normal file
|
@ -0,0 +1,157 @@
|
|||
package refs
|
||||
|
||||
import (
|
||||
"encoding/binary"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/util/proto"
|
||||
)
|
||||
|
||||
const (
|
||||
OwnerIDValField = 1
|
||||
|
||||
ContainerIDValField = 1
|
||||
|
||||
ObjectIDValField = 1
|
||||
|
||||
AddressContainerField = 1
|
||||
AddressObjectField = 2
|
||||
)
|
||||
|
||||
func (o *OwnerID) StableMarshal(buf []byte) ([]byte, error) {
|
||||
if o == nil {
|
||||
return []byte{}, nil
|
||||
}
|
||||
|
||||
if buf == nil {
|
||||
buf = make([]byte, o.StableSize())
|
||||
}
|
||||
|
||||
_, err := proto.BytesMarshal(OwnerIDValField, buf, o.val)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return buf, nil
|
||||
}
|
||||
|
||||
func (o *OwnerID) StableSize() int {
|
||||
if o == nil {
|
||||
return 0
|
||||
}
|
||||
return proto.BytesSize(OwnerIDValField, o.val)
|
||||
}
|
||||
|
||||
func (c *ContainerID) StableMarshal(buf []byte) ([]byte, error) {
|
||||
if c == nil {
|
||||
return []byte{}, nil
|
||||
}
|
||||
|
||||
if buf == nil {
|
||||
buf = make([]byte, c.StableSize())
|
||||
}
|
||||
|
||||
_, err := proto.BytesMarshal(ContainerIDValField, buf, c.val)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return buf, nil
|
||||
}
|
||||
|
||||
func (c *ContainerID) StableSize() int {
|
||||
if c == nil {
|
||||
return 0
|
||||
}
|
||||
return proto.BytesSize(ContainerIDValField, c.val)
|
||||
}
|
||||
|
||||
func (o *ObjectID) StableMarshal(buf []byte) ([]byte, error) {
|
||||
if o == nil {
|
||||
return []byte{}, nil
|
||||
}
|
||||
|
||||
if buf == nil {
|
||||
buf = make([]byte, o.StableSize())
|
||||
}
|
||||
|
||||
_, err := proto.BytesMarshal(ObjectIDValField, buf, o.val)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return buf, nil
|
||||
}
|
||||
|
||||
func (o *ObjectID) StableSize() int {
|
||||
if o == nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
return proto.BytesSize(ObjectIDValField, o.val)
|
||||
}
|
||||
|
||||
func (a *Address) StableMarshal(buf []byte) ([]byte, error) {
|
||||
if a == nil {
|
||||
return []byte{}, nil
|
||||
}
|
||||
|
||||
if buf == nil {
|
||||
buf = make([]byte, a.StableSize())
|
||||
}
|
||||
|
||||
var (
|
||||
offset, n int
|
||||
prefix uint64
|
||||
err error
|
||||
)
|
||||
|
||||
if a.cid != nil {
|
||||
prefix, _ = proto.NestedStructurePrefix(AddressContainerField)
|
||||
offset = binary.PutUvarint(buf, prefix)
|
||||
|
||||
n = a.cid.StableSize()
|
||||
offset += binary.PutUvarint(buf[offset:], uint64(n))
|
||||
|
||||
_, err = a.cid.StableMarshal(buf[offset:])
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
offset += n
|
||||
}
|
||||
|
||||
if a.oid != nil {
|
||||
prefix, _ = proto.NestedStructurePrefix(AddressObjectField)
|
||||
offset += binary.PutUvarint(buf[offset:], prefix)
|
||||
|
||||
n = a.oid.StableSize()
|
||||
offset += binary.PutUvarint(buf[offset:], uint64(n))
|
||||
|
||||
_, err = a.oid.StableMarshal(buf[offset:])
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
return buf, nil
|
||||
}
|
||||
|
||||
func (a *Address) StableSize() (size int) {
|
||||
if a == nil {
|
||||
return 0
|
||||
}
|
||||
|
||||
if a.cid != nil {
|
||||
_, ln := proto.NestedStructurePrefix(AddressContainerField)
|
||||
n := a.cid.StableSize()
|
||||
size += ln + proto.VarUIntSize(uint64(n)) + n
|
||||
}
|
||||
|
||||
if a.oid != nil {
|
||||
_, ln := proto.NestedStructurePrefix(AddressObjectField)
|
||||
n := a.oid.StableSize()
|
||||
size += ln + proto.VarUIntSize(uint64(n)) + n
|
||||
}
|
||||
|
||||
return size
|
||||
}
|
89
v2/refs/marshal_test.go
Normal file
89
v2/refs/marshal_test.go
Normal file
|
@ -0,0 +1,89 @@
|
|||
package refs_test
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/nspcc-dev/neofs-api-go/v2/refs"
|
||||
grpc "github.com/nspcc-dev/neofs-api-go/v2/refs/grpc"
|
||||
"github.com/stretchr/testify/require"
|
||||
)
|
||||
|
||||
func TestOwnerID_StableMarshal(t *testing.T) {
|
||||
ownerFrom := new(refs.OwnerID)
|
||||
ownerTransport := new(grpc.OwnerID)
|
||||
|
||||
t.Run("non empty", func(t *testing.T) {
|
||||
ownerFrom.SetValue([]byte("Owner ID"))
|
||||
|
||||
wire, err := ownerFrom.StableMarshal(nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
err = ownerTransport.Unmarshal(wire)
|
||||
require.NoError(t, err)
|
||||
|
||||
ownerTo := refs.OwnerIDFromGRPCMessage(ownerTransport)
|
||||
require.Equal(t, ownerFrom, ownerTo)
|
||||
})
|
||||
}
|
||||
|
||||
func TestContainerID_StableMarshal(t *testing.T) {
|
||||
cnrFrom := new(refs.ContainerID)
|
||||
cnrTransport := new(grpc.ContainerID)
|
||||
|
||||
t.Run("non empty", func(t *testing.T) {
|
||||
cnrFrom.SetValue([]byte("Container ID"))
|
||||
|
||||
wire, err := cnrFrom.StableMarshal(nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
err = cnrTransport.Unmarshal(wire)
|
||||
require.NoError(t, err)
|
||||
|
||||
cnrTo := refs.ContainerIDFromGRPCMessage(cnrTransport)
|
||||
require.Equal(t, cnrFrom, cnrTo)
|
||||
})
|
||||
}
|
||||
|
||||
func TestObjectID_StableMarshal(t *testing.T) {
|
||||
objectIDFrom := new(refs.ObjectID)
|
||||
objectIDTransport := new(grpc.ObjectID)
|
||||
|
||||
t.Run("non empty", func(t *testing.T) {
|
||||
objectIDFrom.SetValue([]byte("Object ID"))
|
||||
|
||||
wire, err := objectIDFrom.StableMarshal(nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
err = objectIDTransport.Unmarshal(wire)
|
||||
require.NoError(t, err)
|
||||
|
||||
objectIDTo := refs.ObjectIDFromGRPCMessage(objectIDTransport)
|
||||
require.Equal(t, objectIDFrom, objectIDTo)
|
||||
})
|
||||
}
|
||||
|
||||
func TestAddress_StableMarshal(t *testing.T) {
|
||||
addressFrom := new(refs.Address)
|
||||
|
||||
cnr := new(refs.ContainerID)
|
||||
cnr.SetValue([]byte("Container ID"))
|
||||
|
||||
objectID := new(refs.ObjectID)
|
||||
objectID.SetValue([]byte("Object ID"))
|
||||
|
||||
addressTransport := new(grpc.Address)
|
||||
|
||||
t.Run("non empty", func(t *testing.T) {
|
||||
addressFrom.SetContainerID(cnr)
|
||||
addressFrom.SetObjectID(objectID)
|
||||
|
||||
wire, err := addressFrom.StableMarshal(nil)
|
||||
require.NoError(t, err)
|
||||
|
||||
err = addressTransport.Unmarshal(wire)
|
||||
require.NoError(t, err)
|
||||
|
||||
addressTo := refs.AddressFromGRPCMessage(addressTransport)
|
||||
require.Equal(t, addressFrom, addressTo)
|
||||
})
|
||||
}
|
Loading…
Reference in a new issue