pangolin_exporter

Форк
0
/
pg_statio_user_tables_test.go 
157 строк · 5.3 Кб
1
// Copyright 2023 The Prometheus Authors
2
// Licensed under the Apache License, Version 2.0 (the "License");
3
// you may not use this file except in compliance with the License.
4
// You may obtain a copy of the License at
5
//
6
// http://www.apache.org/licenses/LICENSE-2.0
7
//
8
// Unless required by applicable law or agreed to in writing, software
9
// distributed under the License is distributed on an "AS IS" BASIS,
10
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11
// See the License for the specific language governing permissions and
12
// limitations under the License.
13
package collector
14

15
import (
16
	"context"
17
	"testing"
18

19
	"github.com/DATA-DOG/go-sqlmock"
20
	"github.com/prometheus/client_golang/prometheus"
21
	dto "github.com/prometheus/client_model/go"
22
	"github.com/smartystreets/goconvey/convey"
23
)
24

25
func TestPGStatIOUserTablesCollector(t *testing.T) {
26
	db, mock, err := sqlmock.New()
27
	if err != nil {
28
		t.Fatalf("Error opening a stub db connection: %s", err)
29
	}
30
	defer db.Close()
31

32
	inst := &instance{db: db}
33

34
	columns := []string{
35
		"datname",
36
		"schemaname",
37
		"relname",
38
		"heap_blks_read",
39
		"heap_blks_hit",
40
		"idx_blks_read",
41
		"idx_blks_hit",
42
		"toast_blks_read",
43
		"toast_blks_hit",
44
		"tidx_blks_read",
45
		"tidx_blks_hit",
46
	}
47
	rows := sqlmock.NewRows(columns).
48
		AddRow("postgres",
49
			"public",
50
			"a_table",
51
			1,
52
			2,
53
			3,
54
			4,
55
			5,
56
			6,
57
			7,
58
			8)
59
	mock.ExpectQuery(sanitizeQuery(statioUserTablesQuery)).WillReturnRows(rows)
60
	ch := make(chan prometheus.Metric)
61
	go func() {
62
		defer close(ch)
63
		c := PGStatIOUserTablesCollector{}
64

65
		if err := c.Update(context.Background(), inst, ch); err != nil {
66
			t.Errorf("Error calling PGStatIOUserTablesCollector.Update: %s", err)
67
		}
68
	}()
69

70
	expected := []MetricResult{
71
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 1},
72
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 2},
73
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 3},
74
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 4},
75
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 5},
76
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 6},
77
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 7},
78
		{labels: labelMap{"datname": "postgres", "schemaname": "public", "relname": "a_table"}, metricType: dto.MetricType_COUNTER, value: 8},
79
	}
80

81
	convey.Convey("Metrics comparison", t, func() {
82
		for _, expect := range expected {
83
			m := readMetric(<-ch)
84
			convey.So(expect, convey.ShouldResemble, m)
85
		}
86
	})
87
	if err := mock.ExpectationsWereMet(); err != nil {
88
		t.Errorf("there were unfulfilled exceptions: %s", err)
89
	}
90
}
91

92
func TestPGStatIOUserTablesCollectorNullValues(t *testing.T) {
93
	db, mock, err := sqlmock.New()
94
	if err != nil {
95
		t.Fatalf("Error opening a stub db connection: %s", err)
96
	}
97
	defer db.Close()
98

99
	inst := &instance{db: db}
100

101
	columns := []string{
102
		"datname",
103
		"schemaname",
104
		"relname",
105
		"heap_blks_read",
106
		"heap_blks_hit",
107
		"idx_blks_read",
108
		"idx_blks_hit",
109
		"toast_blks_read",
110
		"toast_blks_hit",
111
		"tidx_blks_read",
112
		"tidx_blks_hit",
113
	}
114
	rows := sqlmock.NewRows(columns).
115
		AddRow(nil,
116
			nil,
117
			nil,
118
			nil,
119
			nil,
120
			nil,
121
			nil,
122
			nil,
123
			nil,
124
			nil,
125
			nil)
126
	mock.ExpectQuery(sanitizeQuery(statioUserTablesQuery)).WillReturnRows(rows)
127
	ch := make(chan prometheus.Metric)
128
	go func() {
129
		defer close(ch)
130
		c := PGStatIOUserTablesCollector{}
131

132
		if err := c.Update(context.Background(), inst, ch); err != nil {
133
			t.Errorf("Error calling PGStatIOUserTablesCollector.Update: %s", err)
134
		}
135
	}()
136

137
	expected := []MetricResult{
138
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
139
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
140
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
141
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
142
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
143
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
144
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
145
		{labels: labelMap{"datname": "unknown", "schemaname": "unknown", "relname": "unknown"}, metricType: dto.MetricType_COUNTER, value: 0},
146
	}
147

148
	convey.Convey("Metrics comparison", t, func() {
149
		for _, expect := range expected {
150
			m := readMetric(<-ch)
151
			convey.So(expect, convey.ShouldResemble, m)
152
		}
153
	})
154
	if err := mock.ExpectationsWereMet(); err != nil {
155
		t.Errorf("there were unfulfilled exceptions: %s", err)
156
	}
157
}
158

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.