From 37384c758dffcff2a585c393b498dfacc7a5aa8f Mon Sep 17 00:00:00 2001 From: "nikolay.deryugin" Date: Mon, 25 Sep 2023 11:12:14 +0300 Subject: [PATCH 1/4] Append new query label Signed-off-by: nikolay.deryugin Signed-off-by: Deryugin, Nikolay --- collector/pg_stat_statements.go | 34 ++++++++++++---------- collector/pg_stat_statements_test.go | 42 ++++++++++++++-------------- 2 files changed, 41 insertions(+), 35 deletions(-) diff --git a/collector/pg_stat_statements.go b/collector/pg_stat_statements.go index c03e78b92..ed5705ea1 100644 --- a/collector/pg_stat_statements.go +++ b/collector/pg_stat_statements.go @@ -40,34 +40,34 @@ func NewPGStatStatementsCollector(config collectorConfig) (Collector, error) { } var ( - statSTatementsCallsTotal = prometheus.NewDesc( + statStatementsCallsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "calls_total"), "Number of times executed", - []string{"user", "datname", "queryid"}, + []string{"user", "datname", "queryid", "query"}, prometheus.Labels{}, ) statStatementsSecondsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "seconds_total"), "Total time spent in the statement, in seconds", - []string{"user", "datname", "queryid"}, + []string{"user", "datname", "queryid", "query"}, prometheus.Labels{}, ) statStatementsRowsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "rows_total"), "Total number of rows retrieved or affected by the statement", - []string{"user", "datname", "queryid"}, + []string{"user", "datname", "queryid", "query"}, prometheus.Labels{}, ) statStatementsBlockReadSecondsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "block_read_seconds_total"), "Total time the statement spent reading blocks, in seconds", - []string{"user", "datname", "queryid"}, + []string{"user", "datname", "queryid", "query"}, prometheus.Labels{}, ) statStatementsBlockWriteSecondsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "block_write_seconds_total"), "Total time the statement spent writing blocks, in seconds", - []string{"user", "datname", "queryid"}, + []string{"user", "datname", "queryid", "query"}, prometheus.Labels{}, ) @@ -75,6 +75,7 @@ var ( pg_get_userbyid(userid) as user, pg_database.datname, pg_stat_statements.queryid, + pg_stat_statements.query as query, pg_stat_statements.calls as calls_total, pg_stat_statements.total_time / 1000.0 as seconds_total, pg_stat_statements.rows as rows_total, @@ -96,6 +97,7 @@ var ( pg_get_userbyid(userid) as user, pg_database.datname, pg_stat_statements.queryid, + pg_stat_statements.query as query, pg_stat_statements.calls as calls_total, pg_stat_statements.total_exec_time / 1000.0 as seconds_total, pg_stat_statements.rows as rows_total, @@ -128,11 +130,11 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, } defer rows.Close() for rows.Next() { - var user, datname, queryid sql.NullString + var user, datname, queryid, query sql.NullString var callsTotal, rowsTotal sql.NullInt64 var secondsTotal, blockReadSecondsTotal, blockWriteSecondsTotal sql.NullFloat64 - if err := rows.Scan(&user, &datname, &queryid, &callsTotal, &secondsTotal, &rowsTotal, &blockReadSecondsTotal, &blockWriteSecondsTotal); err != nil { + if err := rows.Scan(&user, &datname, &queryid, &query, &callsTotal, &secondsTotal, &rowsTotal, &blockReadSecondsTotal, &blockWriteSecondsTotal); err != nil { return err } @@ -148,16 +150,20 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, if queryid.Valid { queryidLabel = queryid.String } + queryLabel := "unknown" + if query.Valid { + queryLabel = query.String + } callsTotalMetric := 0.0 if callsTotal.Valid { callsTotalMetric = float64(callsTotal.Int64) } ch <- prometheus.MustNewConstMetric( - statSTatementsCallsTotal, + statStatementsCallsTotal, prometheus.CounterValue, callsTotalMetric, - userLabel, datnameLabel, queryidLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, ) secondsTotalMetric := 0.0 @@ -168,7 +174,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsSecondsTotal, prometheus.CounterValue, secondsTotalMetric, - userLabel, datnameLabel, queryidLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, ) rowsTotalMetric := 0.0 @@ -179,7 +185,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsRowsTotal, prometheus.CounterValue, rowsTotalMetric, - userLabel, datnameLabel, queryidLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, ) blockReadSecondsTotalMetric := 0.0 @@ -190,7 +196,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsBlockReadSecondsTotal, prometheus.CounterValue, blockReadSecondsTotalMetric, - userLabel, datnameLabel, queryidLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, ) blockWriteSecondsTotalMetric := 0.0 @@ -201,7 +207,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsBlockWriteSecondsTotal, prometheus.CounterValue, blockWriteSecondsTotalMetric, - userLabel, datnameLabel, queryidLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, ) } if err := rows.Err(); err != nil { diff --git a/collector/pg_stat_statements_test.go b/collector/pg_stat_statements_test.go index 08aba34c2..bc2897d45 100644 --- a/collector/pg_stat_statements_test.go +++ b/collector/pg_stat_statements_test.go @@ -32,9 +32,9 @@ func TestPGStateStatementsCollector(t *testing.T) { inst := &instance{db: db, version: semver.MustParse("12.0.0")} - columns := []string{"user", "datname", "queryid", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} + columns := []string{"user", "datname", "queryid", "query", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} rows := sqlmock.NewRows(columns). - AddRow("postgres", "postgres", 1500, 5, 0.4, 100, 0.1, 0.2) + AddRow("postgres", "postgres", 1500, "SELECT", 5, 0.4, 100, 0.1, 0.2) mock.ExpectQuery(sanitizeQuery(pgStatStatementsQuery)).WillReturnRows(rows) ch := make(chan prometheus.Metric) @@ -48,11 +48,11 @@ func TestPGStateStatementsCollector(t *testing.T) { }() expected := []MetricResult{ - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, } convey.Convey("Metrics comparison", t, func() { @@ -75,9 +75,9 @@ func TestPGStateStatementsCollectorNull(t *testing.T) { inst := &instance{db: db, version: semver.MustParse("13.3.7")} - columns := []string{"user", "datname", "queryid", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} + columns := []string{"user", "datname", "queryid", "query", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} rows := sqlmock.NewRows(columns). - AddRow(nil, nil, nil, nil, nil, nil, nil, nil) + AddRow(nil, nil, nil, nil, nil, nil, nil, nil, nil) mock.ExpectQuery(sanitizeQuery(pgStatStatementsNewQuery)).WillReturnRows(rows) ch := make(chan prometheus.Metric) @@ -91,11 +91,11 @@ func TestPGStateStatementsCollectorNull(t *testing.T) { }() expected := []MetricResult{ - {labels: labelMap{"user": "unknown", "datname": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, } convey.Convey("Metrics comparison", t, func() { @@ -118,9 +118,9 @@ func TestPGStateStatementsCollectorNewPG(t *testing.T) { inst := &instance{db: db, version: semver.MustParse("13.3.7")} - columns := []string{"user", "datname", "queryid", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} + columns := []string{"user", "datname", "queryid", "query", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} rows := sqlmock.NewRows(columns). - AddRow("postgres", "postgres", 1500, 5, 0.4, 100, 0.1, 0.2) + AddRow("postgres", "postgres", 1500, "SELECT", 5, 0.4, 100, 0.1, 0.2) mock.ExpectQuery(sanitizeQuery(pgStatStatementsNewQuery)).WillReturnRows(rows) ch := make(chan prometheus.Metric) @@ -134,11 +134,11 @@ func TestPGStateStatementsCollectorNewPG(t *testing.T) { }() expected := []MetricResult{ - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, } convey.Convey("Metrics comparison", t, func() { From 22418d0275a495b96d3d0201e8d1b76cff1b7320 Mon Sep 17 00:00:00 2001 From: fireflg <96112649+fireflg@users.noreply.github.com> Date: Mon, 25 Sep 2023 15:20:17 +0300 Subject: [PATCH 2/4] Add limit Co-authored-by: Ben Kochie Signed-off-by: fireflg <96112649+fireflg@users.noreply.github.com> Signed-off-by: nikolay.deryugin Signed-off-by: Deryugin, Nikolay --- collector/pg_stat_statements.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/collector/pg_stat_statements.go b/collector/pg_stat_statements.go index ed5705ea1..92c6b509b 100644 --- a/collector/pg_stat_statements.go +++ b/collector/pg_stat_statements.go @@ -75,7 +75,7 @@ var ( pg_get_userbyid(userid) as user, pg_database.datname, pg_stat_statements.queryid, - pg_stat_statements.query as query, + LEFT(pg_stat_statements.query, %d) as query, pg_stat_statements.calls as calls_total, pg_stat_statements.total_time / 1000.0 as seconds_total, pg_stat_statements.rows as rows_total, From d6229af4c4f74065edcc4141655fcb3be5fd3b3a Mon Sep 17 00:00:00 2001 From: "nikolay.deryugin" Date: Fri, 29 Sep 2023 17:29:13 +0300 Subject: [PATCH 3/4] add left in new query Signed-off-by: nikolay.deryugin Signed-off-by: Deryugin, Nikolay --- collector/pg_stat_statements.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/collector/pg_stat_statements.go b/collector/pg_stat_statements.go index 92c6b509b..716dc5934 100644 --- a/collector/pg_stat_statements.go +++ b/collector/pg_stat_statements.go @@ -97,7 +97,7 @@ var ( pg_get_userbyid(userid) as user, pg_database.datname, pg_stat_statements.queryid, - pg_stat_statements.query as query, + LEFT(pg_stat_statements.query, %d) as query, pg_stat_statements.calls as calls_total, pg_stat_statements.total_exec_time / 1000.0 as seconds_total, pg_stat_statements.rows as rows_total, From 693bd7d08dd26cffdece4382497b282954ee6fe0 Mon Sep 17 00:00:00 2001 From: "Deryugin, Nikolay" Date: Mon, 27 Nov 2023 20:21:31 +0300 Subject: [PATCH 4/4] Add labels SELECT|INSERT|UPDATE|DELETE|OTHER Signed-off-by: Deryugin, Nikolay --- collector/pg_stat_statements.go | 47 +++++++++++++++++++--------- collector/pg_stat_statements_test.go | 42 ++++++++++++------------- 2 files changed, 53 insertions(+), 36 deletions(-) diff --git a/collector/pg_stat_statements.go b/collector/pg_stat_statements.go index 716dc5934..f3df22cae 100644 --- a/collector/pg_stat_statements.go +++ b/collector/pg_stat_statements.go @@ -43,31 +43,31 @@ var ( statStatementsCallsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "calls_total"), "Number of times executed", - []string{"user", "datname", "queryid", "query"}, + []string{"user", "datname", "queryid", "query", "stmt_type"}, prometheus.Labels{}, ) statStatementsSecondsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "seconds_total"), "Total time spent in the statement, in seconds", - []string{"user", "datname", "queryid", "query"}, + []string{"user", "datname", "queryid", "query", "stmt_type"}, prometheus.Labels{}, ) statStatementsRowsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "rows_total"), "Total number of rows retrieved or affected by the statement", - []string{"user", "datname", "queryid", "query"}, + []string{"user", "datname", "queryid", "query", "stmt_type"}, prometheus.Labels{}, ) statStatementsBlockReadSecondsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "block_read_seconds_total"), "Total time the statement spent reading blocks, in seconds", - []string{"user", "datname", "queryid", "query"}, + []string{"user", "datname", "queryid", "query", "stmt_type"}, prometheus.Labels{}, ) statStatementsBlockWriteSecondsTotal = prometheus.NewDesc( prometheus.BuildFQName(namespace, statStatementsSubsystem, "block_write_seconds_total"), "Total time the statement spent writing blocks, in seconds", - []string{"user", "datname", "queryid", "query"}, + []string{"user", "datname", "queryid", "query", "stmt_type"}, prometheus.Labels{}, ) @@ -75,7 +75,14 @@ var ( pg_get_userbyid(userid) as user, pg_database.datname, pg_stat_statements.queryid, - LEFT(pg_stat_statements.query, %d) as query, + LEFT(pg_stat_statements.query, 120) as query, + CASE + WHEN pg_stat_statements.query ILIKE 'SELECT%' THEN 'SELECT' + WHEN pg_stat_statements.query ILIKE 'INSERT%' THEN 'INSERT' + WHEN pg_stat_statements.query ILIKE 'UPDATE%' THEN 'UPDATE' + WHEN pg_stat_statements.query ILIKE 'DELETE%' THEN 'DELETE' + ELSE 'OTHER' + END AS stmt_type, pg_stat_statements.calls as calls_total, pg_stat_statements.total_time / 1000.0 as seconds_total, pg_stat_statements.rows as rows_total, @@ -97,7 +104,14 @@ var ( pg_get_userbyid(userid) as user, pg_database.datname, pg_stat_statements.queryid, - LEFT(pg_stat_statements.query, %d) as query, + LEFT(pg_stat_statements.query, 120) as query, + CASE + WHEN pg_stat_statements.query ILIKE 'SELECT%' THEN 'SELECT' + WHEN pg_stat_statements.query ILIKE 'INSERT%' THEN 'INSERT' + WHEN pg_stat_statements.query ILIKE 'UPDATE%' THEN 'UPDATE' + WHEN pg_stat_statements.query ILIKE 'DELETE%' THEN 'DELETE' + ELSE 'OTHER' + END AS stmt_type, pg_stat_statements.calls as calls_total, pg_stat_statements.total_exec_time / 1000.0 as seconds_total, pg_stat_statements.rows as rows_total, @@ -130,11 +144,11 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, } defer rows.Close() for rows.Next() { - var user, datname, queryid, query sql.NullString + var user, datname, queryid, query, stmt_type sql.NullString var callsTotal, rowsTotal sql.NullInt64 var secondsTotal, blockReadSecondsTotal, blockWriteSecondsTotal sql.NullFloat64 - if err := rows.Scan(&user, &datname, &queryid, &query, &callsTotal, &secondsTotal, &rowsTotal, &blockReadSecondsTotal, &blockWriteSecondsTotal); err != nil { + if err := rows.Scan(&user, &datname, &queryid, &query, &stmt_type, &callsTotal, &secondsTotal, &rowsTotal, &blockReadSecondsTotal, &blockWriteSecondsTotal); err != nil { return err } @@ -154,7 +168,10 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, if query.Valid { queryLabel = query.String } - + stmt_typeLabel := "unknown" + if stmt_type.Valid { + stmt_typeLabel = stmt_type.String + } callsTotalMetric := 0.0 if callsTotal.Valid { callsTotalMetric = float64(callsTotal.Int64) @@ -163,7 +180,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsCallsTotal, prometheus.CounterValue, callsTotalMetric, - userLabel, datnameLabel, queryidLabel, queryLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, stmt_typeLabel, ) secondsTotalMetric := 0.0 @@ -174,7 +191,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsSecondsTotal, prometheus.CounterValue, secondsTotalMetric, - userLabel, datnameLabel, queryidLabel, queryLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, stmt_typeLabel, ) rowsTotalMetric := 0.0 @@ -185,7 +202,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsRowsTotal, prometheus.CounterValue, rowsTotalMetric, - userLabel, datnameLabel, queryidLabel, queryLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, stmt_typeLabel, ) blockReadSecondsTotalMetric := 0.0 @@ -196,7 +213,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsBlockReadSecondsTotal, prometheus.CounterValue, blockReadSecondsTotalMetric, - userLabel, datnameLabel, queryidLabel, queryLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, stmt_typeLabel, ) blockWriteSecondsTotalMetric := 0.0 @@ -207,7 +224,7 @@ func (PGStatStatementsCollector) Update(ctx context.Context, instance *instance, statStatementsBlockWriteSecondsTotal, prometheus.CounterValue, blockWriteSecondsTotalMetric, - userLabel, datnameLabel, queryidLabel, queryLabel, + userLabel, datnameLabel, queryidLabel, queryLabel, stmt_typeLabel, ) } if err := rows.Err(); err != nil { diff --git a/collector/pg_stat_statements_test.go b/collector/pg_stat_statements_test.go index bc2897d45..b7b9cd628 100644 --- a/collector/pg_stat_statements_test.go +++ b/collector/pg_stat_statements_test.go @@ -32,9 +32,9 @@ func TestPGStateStatementsCollector(t *testing.T) { inst := &instance{db: db, version: semver.MustParse("12.0.0")} - columns := []string{"user", "datname", "queryid", "query", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} + columns := []string{"user", "datname", "queryid", "query", "stmt_type", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} rows := sqlmock.NewRows(columns). - AddRow("postgres", "postgres", 1500, "SELECT", 5, 0.4, 100, 0.1, 0.2) + AddRow("postgres", "postgres", 1500, "SELECT", "SELECT", 5, 0.4, 100, 0.1, 0.2) mock.ExpectQuery(sanitizeQuery(pgStatStatementsQuery)).WillReturnRows(rows) ch := make(chan prometheus.Metric) @@ -48,11 +48,11 @@ func TestPGStateStatementsCollector(t *testing.T) { }() expected := []MetricResult{ - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, } convey.Convey("Metrics comparison", t, func() { @@ -75,9 +75,9 @@ func TestPGStateStatementsCollectorNull(t *testing.T) { inst := &instance{db: db, version: semver.MustParse("13.3.7")} - columns := []string{"user", "datname", "queryid", "query", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} + columns := []string{"user", "datname", "queryid", "query", "stmt_type", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} rows := sqlmock.NewRows(columns). - AddRow(nil, nil, nil, nil, nil, nil, nil, nil, nil) + AddRow(nil, nil, nil, nil, nil, nil, nil, nil, nil, nil) mock.ExpectQuery(sanitizeQuery(pgStatStatementsNewQuery)).WillReturnRows(rows) ch := make(chan prometheus.Metric) @@ -91,11 +91,11 @@ func TestPGStateStatementsCollectorNull(t *testing.T) { }() expected := []MetricResult{ - {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, - {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "stmt_type": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "stmt_type": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "stmt_type": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "stmt_type": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, + {labels: labelMap{"user": "unknown", "datname": "unknown", "query": "unknown", "stmt_type": "unknown", "queryid": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0}, } convey.Convey("Metrics comparison", t, func() { @@ -118,9 +118,9 @@ func TestPGStateStatementsCollectorNewPG(t *testing.T) { inst := &instance{db: db, version: semver.MustParse("13.3.7")} - columns := []string{"user", "datname", "queryid", "query", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} + columns := []string{"user", "datname", "queryid", "query", "stmt_type", "calls_total", "seconds_total", "rows_total", "block_read_seconds_total", "block_write_seconds_total"} rows := sqlmock.NewRows(columns). - AddRow("postgres", "postgres", 1500, "SELECT", 5, 0.4, 100, 0.1, 0.2) + AddRow("postgres", "postgres", 1500, "SELECT", "SELECT", 5, 0.4, 100, 0.1, 0.2) mock.ExpectQuery(sanitizeQuery(pgStatStatementsNewQuery)).WillReturnRows(rows) ch := make(chan prometheus.Metric) @@ -134,11 +134,11 @@ func TestPGStateStatementsCollectorNewPG(t *testing.T) { }() expected := []MetricResult{ - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, - {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 5}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.4}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 100}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.1}, + {labels: labelMap{"user": "postgres", "datname": "postgres", "query": "SELECT", "stmt_type": "SELECT", "queryid": "1500"}, metricType: dto.MetricType_COUNTER, value: 0.2}, } convey.Convey("Metrics comparison", t, func() {