frostfs-api-go/container
Evgenii Stratonikov 7aebd82a84
Some checks failed
Tests and linters / Lint (pull_request) Failing after 53s
DCO action / DCO (pull_request) Failing after 1m35s
Tests and linters / Tests (pull_request) Successful in 1m38s
Tests and linters / Tests with -race (pull_request) Successful in 1m39s
protogen: Treat bytes field as non-nullable
In protobuf 3.12 they have added an support for `optional` keyword,
which has made it into the main branch in 3.15.
https://github.com/protocolbuffers/protobuf/blob/main/docs/implementing_proto3_presence.md
https://github.com/protocolbuffers/protobuf/blob/v3.12.0/docs/field_presence.md#presence-in-proto3-apis

This means that without an explicit `optional` keyword field presence
for scalars is not tracked, thus empty string in JSON should be
unmarshaled to a nil byte slice. Relevant decoding code and tests from
protojson:
fb995f184a/internal/impl/message_reflect_field.go (L327)
fb995f184a/encoding/protojson/decode_test.go (L134)
fb995f184a/encoding/protojson/decode_test.go (L156)

We do not support `optional` keyword and the generator will fail if it sees on.
So only implement the default behaviour.

Signed-off-by: Evgenii Stratonikov <e.stratonikov@yadro.com>
2024-10-11 10:17:45 +03:00
..
grpc protogen: Treat bytes field as non-nullable 2024-10-11 10:17:45 +03:00
test [#112] container: Remove GetExtendedACL 2024-09-02 14:10:49 +03:00
attributes.go [#27] *: Resolve godot linter warnings 2023-05-03 14:15:56 +03:00
attributes_test.go Rename package name 2023-03-07 13:42:36 +03:00
convert.go [#112] container: Remove GetExtendedACL 2024-09-02 14:10:49 +03:00
json.go Rename package name 2023-03-07 13:42:36 +03:00
marshal.go [#112] container: Remove GetExtendedACL 2024-09-02 14:10:49 +03:00
message_test.go [#112] container: Remove GetExtendedACL 2024-09-02 14:10:49 +03:00
status.go Rename package name 2023-03-07 13:42:36 +03:00
status_test.go Rename package name 2023-03-07 13:42:36 +03:00
types.go [#112] container: Remove GetExtendedACL 2024-09-02 14:10:49 +03:00