forked from TrueCloudLab/frostfs-api-go
9ec57ee9f8
Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
154 lines
3.5 KiB
Go
154 lines
3.5 KiB
Go
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"
|
|
goproto "google.golang.org/protobuf/proto"
|
|
)
|
|
|
|
func TestOwnerID_StableMarshal(t *testing.T) {
|
|
ownerFrom := new(refs.OwnerID)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
ownerFrom.SetValue([]byte("Owner ID"))
|
|
|
|
wire, err := ownerFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
ownerTo := new(refs.OwnerID)
|
|
require.NoError(t, ownerTo.Unmarshal(wire))
|
|
|
|
require.Equal(t, ownerFrom, ownerTo)
|
|
})
|
|
}
|
|
|
|
func TestContainerID_StableMarshal(t *testing.T) {
|
|
cnrFrom := new(refs.ContainerID)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
cnrFrom.SetValue([]byte("Container ID"))
|
|
|
|
wire, err := cnrFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
cnrTo := new(refs.ContainerID)
|
|
require.NoError(t, cnrTo.Unmarshal(wire))
|
|
|
|
require.Equal(t, cnrFrom, cnrTo)
|
|
})
|
|
}
|
|
|
|
func TestObjectID_StableMarshal(t *testing.T) {
|
|
objectIDFrom := new(refs.ObjectID)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
objectIDFrom.SetValue([]byte("Object ID"))
|
|
|
|
wire, err := objectIDFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
objectIDTo := new(refs.ObjectID)
|
|
require.NoError(t, objectIDTo.Unmarshal(wire))
|
|
|
|
require.Equal(t, objectIDFrom, objectIDTo)
|
|
})
|
|
}
|
|
|
|
func TestAddress_StableMarshal(t *testing.T) {
|
|
cid := []byte("Container ID")
|
|
oid := []byte("Object ID")
|
|
|
|
addressFrom := generateAddress(cid, oid)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
wire, err := addressFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
addressTo := new(refs.Address)
|
|
require.NoError(t, addressTo.Unmarshal(wire))
|
|
|
|
require.Equal(t, addressFrom, addressTo)
|
|
})
|
|
}
|
|
|
|
func TestChecksum_StableMarshal(t *testing.T) {
|
|
checksumFrom := new(refs.Checksum)
|
|
transport := new(grpc.Checksum)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
checksumFrom.SetType(refs.TillichZemor)
|
|
checksumFrom.SetSum([]byte("Homomorphic Hash"))
|
|
|
|
wire, err := checksumFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
err = goproto.Unmarshal(wire, transport)
|
|
require.NoError(t, err)
|
|
|
|
checksumTo := refs.ChecksumFromGRPCMessage(transport)
|
|
require.Equal(t, checksumFrom, checksumTo)
|
|
})
|
|
}
|
|
|
|
func TestSignature_StableMarshal(t *testing.T) {
|
|
signatureFrom := generateSignature("Public Key", "Signature")
|
|
transport := new(grpc.Signature)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
wire, err := signatureFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
err = goproto.Unmarshal(wire, transport)
|
|
require.NoError(t, err)
|
|
|
|
signatureTo := refs.SignatureFromGRPCMessage(transport)
|
|
require.Equal(t, signatureFrom, signatureTo)
|
|
})
|
|
}
|
|
|
|
func TestVersion_StableMarshal(t *testing.T) {
|
|
versionFrom := generateVersion(2, 0)
|
|
transport := new(grpc.Version)
|
|
|
|
t.Run("non empty", func(t *testing.T) {
|
|
wire, err := versionFrom.StableMarshal(nil)
|
|
require.NoError(t, err)
|
|
|
|
err = goproto.Unmarshal(wire, transport)
|
|
require.NoError(t, err)
|
|
|
|
versionTo := refs.VersionFromGRPCMessage(transport)
|
|
require.Equal(t, versionFrom, versionTo)
|
|
})
|
|
}
|
|
|
|
func generateSignature(k, v string) *refs.Signature {
|
|
sig := new(refs.Signature)
|
|
sig.SetKey([]byte(k))
|
|
sig.SetSign([]byte(v))
|
|
|
|
return sig
|
|
}
|
|
|
|
func generateVersion(maj, min uint32) *refs.Version {
|
|
version := new(refs.Version)
|
|
version.SetMajor(maj)
|
|
version.SetMinor(min)
|
|
|
|
return version
|
|
}
|
|
|
|
func generateAddress(bCid, bOid []byte) *refs.Address {
|
|
addr := new(refs.Address)
|
|
|
|
cid := new(refs.ContainerID)
|
|
cid.SetValue(bCid)
|
|
|
|
oid := new(refs.ObjectID)
|
|
oid.SetValue(bOid)
|
|
|
|
return addr
|
|
}
|