Commit graph

8 commits

Author SHA1 Message Date
Augustin Husson 29b62762db
adapt the lezer grammar and codemirror autocompletion with duration and number that are equivalent (#14417)
Signed-off-by: Augustin Husson <[email protected]>
2024-07-31 15:31:42 +02:00
JuanJo Ciarlante c94c5b64c3
feat: add limitk() and limit_ratio() operators (#12503)
* rebase 2024-07-01, picks previous renaming to `limitk()` and `limit_ratio()`

Signed-off-by: JuanJo Ciarlante <[email protected]>

* gofumpt -d -extra

Signed-off-by: JuanJo Ciarlante <[email protected]>

* more lint fixes

Signed-off-by: JuanJo Ciarlante <[email protected]>

* more lint fixes+

Signed-off-by: JuanJo Ciarlante <[email protected]>

* put limitk() and limit_ratio() behind --enable-feature=promql-experimental-functions

Signed-off-by: JuanJo Ciarlante <[email protected]>

* EnableExperimentalFunctions for TestConcurrentRangeQueries() also

Signed-off-by: JuanJo Ciarlante <[email protected]>

* use testutil.RequireEqual to fix tests, WIP equivalent thingie for require.Contains

Signed-off-by: JuanJo Ciarlante <[email protected]>

* lint fix

Signed-off-by: JuanJo Ciarlante <[email protected]>

* moar linting

Signed-off-by: JuanJo Ciarlante <[email protected]>

* rebase 2024-06-19

Signed-off-by: JuanJo Ciarlante <[email protected]>

* re-add limit(2, metric) testing for N=2 common series subset

Signed-off-by: JuanJo Ciarlante <[email protected]>

* move `ratio = param` to default switch case, for better readability

Signed-off-by: JuanJo Ciarlante <[email protected]>

* gofumpt -d -extra util/testutil/cmp.go

Signed-off-by: JuanJo Ciarlante <[email protected]>

* early break when reaching k elems in limitk(), should have always been so (!)

Signed-off-by: JuanJo Ciarlante <[email protected]>

* small typo fix

Signed-off-by: JuanJo Ciarlante <[email protected]>

* no-change small break-loop rearrange for readability

Signed-off-by: JuanJo Ciarlante <[email protected]>

* remove IsNan(ratio) condition in switch-case, already handled as input validation

Signed-off-by: JuanJo Ciarlante <[email protected]>

* no-change adding some comments

Signed-off-by: JuanJo Ciarlante <[email protected]>

* no-change simplify fullMatrix() helper functions used for tests

Signed-off-by: JuanJo Ciarlante <[email protected]>

* add `limitk(-1, metric)` testcase, which is handled as any k < 1 case

Signed-off-by: JuanJo Ciarlante <[email protected]>

* engine_test.go: no-change create `requireCommonSeries() helper func (moving code into it) for readability

Signed-off-by: JuanJo Ciarlante <[email protected]>

* rebase 2024-06-21

Signed-off-by: JuanJo Ciarlante <[email protected]>

* engine_test.go: HAPPY NOW about its code -> reorg, create and use simpleRangeQuery() function, less lines and more readable ftW \o/

Signed-off-by: JuanJo Ciarlante <[email protected]>

* move limitk(), limit_ratio() testing to promql/promqltest/testdata/limit.test

Signed-off-by: JuanJo Ciarlante <[email protected]>

* remove stale leftover after moving tests from engine_test.go to testdata/

Signed-off-by: JuanJo Ciarlante <[email protected]>

* fix flaky `limit_ratio(0.5, ...)` test case

Signed-off-by: JuanJo Ciarlante <[email protected]>

* Update promql/engine.go

Co-authored-by: Julius Volz <[email protected]>
Signed-off-by: JuanJo Ciarlante <[email protected]>

* Update promql/engine.go

Co-authored-by: Julius Volz <[email protected]>
Signed-off-by: JuanJo Ciarlante <[email protected]>

* Update promql/engine.go

Co-authored-by: Julius Volz <[email protected]>
Signed-off-by: JuanJo Ciarlante <[email protected]>

* fix AddRatioSample() implementation to use a single conditional (instead of switch/case + fallback return)

Signed-off-by: JuanJo Ciarlante <[email protected]>

* docs/querying/operators.md: document r < 0

Signed-off-by: JuanJo Ciarlante <[email protected]>

* add negative limit_ratio() example to docs/querying/examples.md

Signed-off-by: JuanJo Ciarlante <[email protected]>

* move more extensive docu examples to docs/querying/operators.md

Signed-off-by: JuanJo Ciarlante <[email protected]>

* typo

Signed-off-by: JuanJo Ciarlante <[email protected]>

* small docu fix for poor-mans-normality-check, add it to limit.test ;)

Signed-off-by: JuanJo Ciarlante <[email protected]>

* limit.test: expand "Poor man's normality check" to whole eval range

Signed-off-by: JuanJo Ciarlante <[email protected]>

* restore mistakenly removed existing small comment

Signed-off-by: JuanJo Ciarlante <[email protected]>

* expand poors-man-normality-check case(s)

Signed-off-by: JuanJo Ciarlante <[email protected]>

* Revert "expand poors-man-normality-check case(s)"

This reverts commit f69e1603b2ebe69c0a100197cfbcf6f81644b564, indeed too
flaky 0:)

Signed-off-by: JuanJo Ciarlante <[email protected]>

* remove humor from docs/querying/operators.md

Signed-off-by: JuanJo Ciarlante <[email protected]>

* fix signoff

Signed-off-by: JuanJo Ciarlante <[email protected]>

* add web/ui missing changes

Signed-off-by: JuanJo Ciarlante <[email protected]>

* expand limit_ratio test cases, cross-fingering they'll not be flaky

Signed-off-by: JuanJo Ciarlante <[email protected]>

* remove flaky test

Signed-off-by: JuanJo Ciarlante <[email protected]>

* add missing warnings.Merge(ws) in instant-query return shortcut

Signed-off-by: JuanJo Ciarlante <[email protected]>

* add missing LimitK||LimitRatio case to codemirror-promql/src/parser/parser.ts

Signed-off-by: JuanJo Ciarlante <[email protected]>

* fix ui-lint

Signed-off-by: JuanJo Ciarlante <[email protected]>

* actually fix returned warnings :]

Signed-off-by: JuanJo Ciarlante <[email protected]>

---------

Signed-off-by: JuanJo Ciarlante <[email protected]>
Co-authored-by: Julius Volz <[email protected]>
2024-07-03 22:18:57 +02:00
Faustas Butkus 6feffeb92e
promql: add histogram_avg function (#13467)
Add histogram_avg function

---------

Signed-off-by: Faustas Butkus <[email protected]>
Signed-off-by: Björn Rabenstein <[email protected]>
Co-authored-by: Björn Rabenstein <[email protected]>
2024-02-01 18:28:42 +01:00
Alexander Trost 5051a993ab promql: add sort_by_label and sort_by_label_desc functions
This adds functions to sort a vector by its label value.

Based on https://github.com/prometheus/prometheus/pull/1533

Signed-off-by: Alexander Trost <[email protected]>
2023-11-28 14:40:07 +01:00
Jesus Vazquez e934d0f011 Merge 'main' into sparsehistogram
Signed-off-by: Jesus Vazquez <[email protected]>
2022-10-05 22:14:49 +02:00
Marijn Haverbeke 8dbb2eaf0b
Clean up the Lezer grammar output tree (#11333)
Signed-off-by: Marijn Haverbeke <[email protected]>
2022-09-29 22:26:46 +02:00
beorn7 cf474c1116 web: Add new histogram functions to highlight.js
Signed-off-by: beorn7 <[email protected]>
2022-06-29 17:31:00 +02:00
Augustin Husson 5d1756c822
Upgrade codemirror and lezer to the latest version (#10841)
* bump codemirror to v0.20.x and lezer to v.0.16.x

Signed-off-by: Augustin Husson <[email protected]>

* bump codemirror to v6 and lezer to v1

Signed-off-by: Augustin Husson <[email protected]>

* stop treating warning as error for UI

Signed-off-by: Augustin Husson <[email protected]>
2022-06-13 17:55:06 +02:00