record_accesor: fix return value for flb_ra_get_kv_pair when get_ra_parser fails. #10105
+3
−3
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
Fix return value for
flb_ra_get_kv_pair
whenget_ra_parser
fails.Description
When a record accesor is created but has no hints, usually because it is invalid or truncated, it will be generated without any hints. When that happens the call
get_ra_parser
fails. The functionflb_ra_get_kv_pair
callsget_ra_parser
as well asflb_ra_key_value_get
. Ifget_ra_parser
fails it returns FLB_FALSE but the function returns the value offlb_ra_key_value_get
directly which returns 0 on success and -1 on failure.All of this weird, unexpected behaviour casues a failure in the
structured_metadata_map_invalid_ra_key
test in theflb-rt-out_loki
test binary.To remedy the situation I updated the documentation for
flb_ra_get_kv_pair
as well as updated the return value when failingget_ra_parser
to -1. I double checked all code callingflb_ra_get_kv_pair
:All of these files expect the convention laid out by
flb_ra_key_value_get
.This should fix the tests added in #9530.
Enter
[N/A]
in the box, if an item is not applicable to your change.Testing
Before we can approve your change; please submit the following in a comment:
If this is a change to packaging of containers or native binaries then please confirm it works for all targets.
ok-package-test
label to test for all targets (requires maintainer to do).Documentation
Backporting
Fluent Bit is licensed under Apache 2.0, by submitting this pull request I understand that this code will be released under the terms of that license.