pangolin_exporter

Форк
0
/
pg_database_test.go 
103 строки · 3.2 Кб
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 TestPGDatabaseCollector(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
	mock.ExpectQuery(sanitizeQuery(pgDatabaseQuery)).WillReturnRows(sqlmock.NewRows([]string{"datname", "datconnlimit"}).
35
		AddRow("postgres", 15))
36

37
	mock.ExpectQuery(sanitizeQuery(pgDatabaseSizeQuery)).WithArgs("postgres").WillReturnRows(sqlmock.NewRows([]string{"pg_database_size"}).
38
		AddRow(1024))
39

40
	ch := make(chan prometheus.Metric)
41
	go func() {
42
		defer close(ch)
43
		c := PGDatabaseCollector{}
44
		if err := c.Update(context.Background(), inst, ch); err != nil {
45
			t.Errorf("Error calling PGDatabaseCollector.Update: %s", err)
46
		}
47
	}()
48

49
	expected := []MetricResult{
50
		{labels: labelMap{"datname": "postgres"}, value: 15, metricType: dto.MetricType_GAUGE},
51
		{labels: labelMap{"datname": "postgres"}, value: 1024, metricType: dto.MetricType_GAUGE},
52
	}
53
	convey.Convey("Metrics comparison", t, func() {
54
		for _, expect := range expected {
55
			m := readMetric(<-ch)
56
			convey.So(expect, convey.ShouldResemble, m)
57
		}
58
	})
59
	if err := mock.ExpectationsWereMet(); err != nil {
60
		t.Errorf("there were unfulfilled exceptions: %s", err)
61
	}
62
}
63

64
// TODO add a null db test
65

66
func TestPGDatabaseCollectorNullMetric(t *testing.T) {
67
	db, mock, err := sqlmock.New()
68
	if err != nil {
69
		t.Fatalf("Error opening a stub db connection: %s", err)
70
	}
71
	defer db.Close()
72

73
	inst := &instance{db: db}
74

75
	mock.ExpectQuery(sanitizeQuery(pgDatabaseQuery)).WillReturnRows(sqlmock.NewRows([]string{"datname", "datconnlimit"}).
76
		AddRow("postgres", nil))
77

78
	mock.ExpectQuery(sanitizeQuery(pgDatabaseSizeQuery)).WithArgs("postgres").WillReturnRows(sqlmock.NewRows([]string{"pg_database_size"}).
79
		AddRow(nil))
80

81
	ch := make(chan prometheus.Metric)
82
	go func() {
83
		defer close(ch)
84
		c := PGDatabaseCollector{}
85
		if err := c.Update(context.Background(), inst, ch); err != nil {
86
			t.Errorf("Error calling PGDatabaseCollector.Update: %s", err)
87
		}
88
	}()
89

90
	expected := []MetricResult{
91
		{labels: labelMap{"datname": "postgres"}, value: 0, metricType: dto.MetricType_GAUGE},
92
		{labels: labelMap{"datname": "postgres"}, value: 0, metricType: dto.MetricType_GAUGE},
93
	}
94
	convey.Convey("Metrics comparison", t, func() {
95
		for _, expect := range expected {
96
			m := readMetric(<-ch)
97
			convey.So(expect, convey.ShouldResemble, m)
98
		}
99
	})
100
	if err := mock.ExpectationsWereMet(); err != nil {
101
		t.Errorf("there were unfulfilled exceptions: %s", err)
102
	}
103
}
104

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

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

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

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