-
Notifications
You must be signed in to change notification settings - Fork 5
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
Add experimental promQL funcs #133
Add experimental promQL funcs #133
Conversation
opts.go
Outdated
enableOffset bool | ||
enableAtModifier bool | ||
enableVectorMatching bool | ||
enableExperimentalPromQL bool |
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.
Can we call it enableExperimentalPromQLFunctions
? Same as https://prometheus.io/docs/prometheus/latest/feature_flags/#experimental-promql-functions.
It is not just functions but I think it is more accurate to mention that
walk.go
Outdated
@@ -83,6 +83,10 @@ func (s *PromQLSmith) walkAggregateParam(op parser.ItemType) parser.Expr { | |||
return s.Walk(parser.ValueTypeScalar) | |||
case parser.COUNT_VALUES: | |||
return &parser.StringLiteral{Val: "value"} | |||
case parser.LIMITK, parser.LIMIT_RATIO: | |||
if s.enableExperimentalPromQL { |
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.
So we pick an aggregation type randomly from enabled aggregate operators. But for now I think default aggregate operators don't include limitk
and limit_ratio
.
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.
This might go wrong if users enable the feature flag but don't add the operators to enabled aggregate operators
expr.Args = append(expr.Args, &parser.StringLiteral{Val: name}) | ||
cnt++ | ||
} | ||
} |
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.
There are 2 issues here:
- there is no randomization since
s.labelNames
are always the same order - For refernece you can check
walkLabelJoin
. We try to get the underlying vector selector and infer what labels it might have and pick labels there. This increases the chance where the labels used in the query actually makes sense for the series
Signed-off-by: kade.lee <[email protected]>
782da6a
to
228f5f4
Compare
@yeya24
|
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.
Thanks for the contribution. Awesome work!
This PR adds experimental promQL funcs.