-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Auto Generation of Component Configuration from metadata.yaml #27003
Conversation
Amazing summary! Thank you, Kevin.
I'm a bit concerned about splitting the validation logic and introducing the
If we are bringing the fork to our repo, do we need to stick to the json-schema requirements and behavior? Maybe we can change it to generate the code that we expect including the |
we don't - the nice thing with sticking to the current logic for validation is that it gets us 80/20 of the way there and gives us an incremental way to move forward |
I am going to mark this as draft then, feel free to mark it as ready whenever that is the case |
On the fork front: have we reported the issues upstream? Do we know if changes like these would be accepted? |
Not yet - I do have a branch which I'll be creating a pull request for.
Since we are adding non-jsonschema specific logic (eg. adding a `canBeNil`
option and other logic that is specific to the otel collecto), its unlikely
that it will be accepted
…On Wed, Sep 20, 2023 at 1:29 AM Pablo Baeyens ***@***.***> wrote:
On the fork front: have we reported the issues upstream? Do we know if
changes like these would be accepted?
—
Reply to this email directly, view it on GitHub
<#27003 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AADD52OVHN7RIH6MED4LYELX3KSOXANCNFSM6AAAAAA46SOLRI>
.
You are receiving this because you authored the thread.Message ID:
<open-telemetry/opentelemetry-collector-contrib/pull/27003/c1727226106@
github.com>
|
@@ -7,3 +7,41 @@ status: | |||
distributions: [core, contrib, observiq, splunk, sumo, aws] | |||
codeowners: | |||
active: [atingchen] | |||
config: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it would be good to pick another exporter where there is a heavy reuse of shared config objects, like the HTTPSettings. How would it be handled in the schema?
This PR was marked stale due to lack of activity. It will be closed in 14 days. |
Closed as inactive. Feel free to reopen if this PR is still being worked on. |
As an alternative to |
Also, there are even more validation packages going against struct tags (rather than tying to protobuf), so a solution that allows to specify the tags in the IDL would be all that's needed. Here's a pretty simple (to reproduce) library that allows specifying struct tags: https://github.com/favadi/protoc-go-inject-tag |
Hi, everyone! I opened a PR which aims to build upon this one. If you are interested in this project, please feel free to take a look. My PR does differ from this one in a few notable ways:
Thank you all for your contributions! And in particular I'd like to give a huge thank you to @kevinslin for establishing a nice base on which others can build upon, and for gathering so much feedback! |
Nice! I'm glad someone is taking over this work. I got pulled into a
different direction and was never able to finish
…On Tue, Aug 13, 2024 at 11:09 AM Paulin Todev ***@***.***> wrote:
Hi, everyone! I opened a PR
<open-telemetry/opentelemetry-collector#10694>
which aims to build upon this one. If you are interested in this project,
please feel free to take a look.
My PR does differ from this one in a few notable ways:
- I am trying to avoid having go-jsonschema code inside the Collector
repo. For now I'm using a fork of go-jsonschema under my own GitHub
username.
- I am avoiding pointers in the generated structs by setting a default
value in the schema. When there's a default value, go-jsonschema
doesn't generate pointers.
Thank you all for your contributions! And in particular I'd like to give a
huge thank you to @kevinslin <https://github.com/kevinslin> for
establishing a nice base on which others can build upon, and for gathering
so much feedback!
—
Reply to this email directly, view it on GitHub
<#27003 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AADD52PITPBNCRHQAA6MAK3ZRJDV5AVCNFSM6AAAAABMOZGQWWVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDEOBWHAZTIMRZGU>
.
You are receiving this because you were mentioned.Message ID:
<open-telemetry/opentelemetry-collector-contrib/pull/27003/c2286834295@
github.com>
|
Description:
This is an initial change to have
mdatagen
also generate component configuration.This works as described in https://docs.google.com/document/d/15SMsJAdE1BHAmwf8cLXBvsHDrezXOHniaRZafjO-5e4/edit
We are using go-jsonschema for doing yaml->jsonschema->gocode + validation. This library currently has many limitations (but is also the closest in terms of fulfilling the design goals).
This PR is a work in progress but I'm bringing it up to get feedback on a few design decisions that came up during development
Link to tracking Issue: #24189
Design Decisions
The following are design decisions that I'm looking for feedback on. I have listed a recommended approach for each choice. If there is anything I've missed (design wise), feel free to also bring it up in the review.
on pointer fields
go-jsonschema
currently generates pointers for any property that is not marked asrequired
fileexporter
, note the pointer fields for Compression and FlushIntervalWhile this is arguably more correct, it goes against the convention used by component authors in the otel-collector (there is almost no presence of pointers in the
Config
in the vast majority of components). The builtin config unmarshaling logic actually explicitly converts any nil pointers to their equivalent zero valuesThis makes it easy to run into segmentation issues due to nil pointer dereferencing and also makes writing tests very verbose)
Recommendation: modify
go-jsonschema
so that the default is to not create pointers of non-required fields. Add a custom property,canBeNil
, that can be set totrue
in the yaml if the component author wants to explicitly make a field a pointer. Arequired
property can not havecanBeNil
set totrue
on unmarshaling and validation
go-jsonschema combines validation & unmarshaling code by generating a json unmarshaling function with the following signature:
func (j *Config) UnmarshalJSON(b []byte) error
for each field that needs a validation. example hereValidation
call. Example herego-jsonschem
currently doesn't support all validations by jsonschemaValidateHelper
function insteadValidation
(andUnmarshaling
) logic is written in the fileconfig_custom.go
Validation
will call the autogeneratedValidateHelper
functionValidateHelper
function is autogenerated whencustomValidation: true
Recommendation: Move forward with this design. The alternative at this point is to either implement a non-json marshal/unmarshal based validation or not do validation at all. Since this is done once at startup and relatively efficient, proposing to keep current implementation
on go-jsonschema fork
The
go-jsonschema
library currently lacks many of the features that we require. Currently, I have forked some of the subpackages inside of an internal thirdparty package. The fork has the following changesdate
format that resolves totime.Duration
typego-jsonschema
does not supportI also plan on making the following changes
canBeNil
property is set to truecustomValidation
flagSince some of these changes are not jsonschema compatible, it is unlikely to be accepted upstream.
In terms of the fork, I can either fork the package in a separate repo or continue as I have currently done, copying over the relevant files into
mdatagen
Recommendation: Since the fork is 3 files, recommend just keeping it inside the
otel-collector-contrib
repo.on default values
go-jsonschem
has the ability to generate default values but these are currently only realized in theUnmarshalJSON
logic. Example hereThis means that the defaults only get set in the
Validate
code. i'm currently ignoring the generated default values sinceUnmarshalJSON
is only execute inside ofValidate
Some choices:
Config
so that if no value is set, we can set a default inValidate
- not a fan of this asValidate
should not mutate the configuration. plus, since the default behavior is to replace pointers with zero values during unmarshaling, it will be hard to determine whether a default needs to be setUnmarshal
function if default values need to be setRecommendation: Do nothing right now to limit the scope of the upcoming changes. In the future, implement
b
(generating a custom unmarhsal function to set default values). At that point, we'll also have a better sense of the ergonomics of this process