[#77] protogen: Add tests for JSON format
All checks were successful
DCO action / DCO (pull_request) Successful in 38s
Tests and linters / Tests (1.19) (pull_request) Successful in 39s
Tests and linters / Tests (1.20) (pull_request) Successful in 49s
Tests and linters / Lint (pull_request) Successful in 58s
Tests and linters / Tests with -race (pull_request) Successful in 1m3s
All checks were successful
DCO action / DCO (pull_request) Successful in 38s
Tests and linters / Tests (1.19) (pull_request) Successful in 39s
Tests and linters / Tests (1.20) (pull_request) Successful in 49s
Tests and linters / Lint (pull_request) Successful in 58s
Tests and linters / Tests with -race (pull_request) Successful in 1m3s
Signed-off-by: Evgenii Stratonikov <e.stratonikov@yadro.com>
This commit is contained in:
parent
4fa9ee7181
commit
cc0199d82b
1 changed files with 68 additions and 33 deletions
|
@ -8,6 +8,7 @@ import (
|
||||||
"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/util/proto/test"
|
"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/util/proto/test"
|
||||||
generated "git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/util/proto/test/custom"
|
generated "git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/util/proto/test/custom"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
"google.golang.org/protobuf/encoding/protojson"
|
||||||
goproto "google.golang.org/protobuf/proto"
|
goproto "google.golang.org/protobuf/proto"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -51,33 +52,64 @@ func TestStableMarshalSingle(t *testing.T) {
|
||||||
}
|
}
|
||||||
for _, tc := range marshalCases {
|
for _, tc := range marshalCases {
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
t.Run(tc.name, func(t *testing.T) {
|
||||||
r := tc.input.MarshalProtobuf(nil)
|
t.Run("proto", func(t *testing.T) {
|
||||||
require.Equal(t, len(r), tc.input.StableSize())
|
r := tc.input.MarshalProtobuf(nil)
|
||||||
require.NotEmpty(t, r)
|
require.Equal(t, len(r), tc.input.StableSize())
|
||||||
|
require.NotEmpty(t, r)
|
||||||
|
|
||||||
var actual test.Primitives
|
var actual test.Primitives
|
||||||
require.NoError(t, goproto.Unmarshal(r, &actual))
|
require.NoError(t, goproto.Unmarshal(r, &actual))
|
||||||
|
|
||||||
var actualFrostfs generated.Primitives
|
var actualFrostfs generated.Primitives
|
||||||
require.NoError(t, actualFrostfs.UnmarshalProtobuf(r))
|
require.NoError(t, actualFrostfs.UnmarshalProtobuf(r))
|
||||||
require.Equal(t, tc.input, &actualFrostfs)
|
require.Equal(t, tc.input, &actualFrostfs)
|
||||||
|
|
||||||
// Compare each field directly, because proto-generated code has private fields.
|
primitivesEqual(t, tc.input, &actual)
|
||||||
require.Equal(t, tc.input.FieldA, actual.FieldA)
|
})
|
||||||
require.Equal(t, tc.input.FieldB, actual.FieldB)
|
t.Run("json", func(t *testing.T) {
|
||||||
require.Equal(t, tc.input.FieldC, actual.FieldC)
|
r, err := tc.input.MarshalJSON()
|
||||||
require.Equal(t, tc.input.FieldD, actual.FieldD)
|
require.NoError(t, err)
|
||||||
require.Equal(t, tc.input.FieldE, actual.FieldE)
|
require.NotEmpty(t, r)
|
||||||
require.Equal(t, tc.input.FieldF, actual.FieldF)
|
|
||||||
require.Equal(t, tc.input.FieldG, actual.FieldG)
|
var actual test.Primitives
|
||||||
require.Equal(t, tc.input.FieldI, actual.FieldI)
|
require.NoError(t, protojson.Unmarshal(r, &actual))
|
||||||
require.Equal(t, tc.input.FieldJ, actual.FieldJ)
|
|
||||||
require.Equal(t, tc.input.FieldK, actual.FieldK)
|
var actualFrostfs generated.Primitives
|
||||||
require.EqualValues(t, tc.input.FieldH, actual.FieldH)
|
require.NoError(t, actualFrostfs.UnmarshalJSON(r))
|
||||||
|
require.Equal(t, tc.input, &actualFrostfs)
|
||||||
|
|
||||||
|
primitivesEqual(t, tc.input, &actual)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func primitivesEqual(t *testing.T, a *generated.Primitives, b *test.Primitives) {
|
||||||
|
// Compare each field directly, because proto-generated code has private fields.
|
||||||
|
require.Equal(t, a.FieldA, b.FieldA)
|
||||||
|
require.Equal(t, a.FieldB, b.FieldB)
|
||||||
|
require.Equal(t, a.FieldC, b.FieldC)
|
||||||
|
require.Equal(t, a.FieldD, b.FieldD)
|
||||||
|
require.Equal(t, a.FieldE, b.FieldE)
|
||||||
|
require.Equal(t, a.FieldF, b.FieldF)
|
||||||
|
require.Equal(t, a.FieldG, b.FieldG)
|
||||||
|
require.Equal(t, a.FieldI, b.FieldI)
|
||||||
|
require.Equal(t, a.FieldJ, b.FieldJ)
|
||||||
|
require.Equal(t, a.FieldK, b.FieldK)
|
||||||
|
require.EqualValues(t, a.FieldH, b.FieldH)
|
||||||
|
}
|
||||||
|
|
||||||
|
func repPrimitivesEqual(t *testing.T, a *generated.RepPrimitives, b *test.RepPrimitives) {
|
||||||
|
// Compare each field directly, because proto-generated code has private fields.
|
||||||
|
require.Equal(t, a.FieldA, b.FieldA)
|
||||||
|
require.Equal(t, a.FieldB, b.FieldB)
|
||||||
|
require.Equal(t, a.FieldC, b.FieldC)
|
||||||
|
require.Equal(t, a.FieldD, b.FieldD)
|
||||||
|
require.Equal(t, a.FieldE, b.FieldE)
|
||||||
|
require.Equal(t, a.FieldF, b.FieldF)
|
||||||
|
require.Equal(t, a.FieldFu, b.FieldFu)
|
||||||
|
}
|
||||||
|
|
||||||
func randIntSlice[T protoInt](n int, includeZero bool) []T {
|
func randIntSlice[T protoInt](n int, includeZero bool) []T {
|
||||||
r := make([]T, n)
|
r := make([]T, n)
|
||||||
if n == 0 {
|
if n == 0 {
|
||||||
|
@ -142,21 +174,24 @@ func TestStableMarshalRep(t *testing.T) {
|
||||||
}
|
}
|
||||||
for _, tc := range marshalCases {
|
for _, tc := range marshalCases {
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
t.Run(tc.name, func(t *testing.T) {
|
||||||
r := tc.input.MarshalProtobuf(nil)
|
t.Run("proto", func(t *testing.T) {
|
||||||
require.Equal(t, len(r), tc.input.StableSize())
|
r := tc.input.MarshalProtobuf(nil)
|
||||||
require.NotEmpty(t, r)
|
require.Equal(t, len(r), tc.input.StableSize())
|
||||||
|
require.NotEmpty(t, r)
|
||||||
|
|
||||||
var actual test.RepPrimitives
|
var actual test.RepPrimitives
|
||||||
require.NoError(t, goproto.Unmarshal(r, &actual))
|
require.NoError(t, goproto.Unmarshal(r, &actual))
|
||||||
|
repPrimitivesEqual(t, tc.input, &actual)
|
||||||
|
})
|
||||||
|
t.Run("json", func(t *testing.T) {
|
||||||
|
r, err := tc.input.MarshalJSON()
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.NotEmpty(t, r)
|
||||||
|
|
||||||
// Compare each field directly, because proto-generated code has private fields.
|
var actual test.RepPrimitives
|
||||||
require.Equal(t, tc.input.FieldA, actual.FieldA)
|
require.NoError(t, protojson.Unmarshal(r, &actual))
|
||||||
require.Equal(t, tc.input.FieldB, actual.FieldB)
|
repPrimitivesEqual(t, tc.input, &actual)
|
||||||
require.Equal(t, tc.input.FieldC, actual.FieldC)
|
})
|
||||||
require.Equal(t, tc.input.FieldD, actual.FieldD)
|
|
||||||
require.Equal(t, tc.input.FieldE, actual.FieldE)
|
|
||||||
require.Equal(t, tc.input.FieldF, actual.FieldF)
|
|
||||||
require.Equal(t, tc.input.FieldFu, actual.FieldFu)
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue