2018-08-02 06:44:10 +08:00
|
|
|
package pgbouncer
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
2021-01-27 02:06:12 +08:00
|
|
|
"testing"
|
|
|
|
|
|
2022-05-28 00:24:31 +08:00
|
|
|
"github.com/docker/go-connections/nat"
|
2021-11-15 23:14:09 +08:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-05-26 00:45:55 +08:00
|
|
|
"github.com/testcontainers/testcontainers-go/wait"
|
2021-11-15 23:14:09 +08:00
|
|
|
|
2023-01-10 00:17:23 +08:00
|
|
|
"github.com/influxdata/telegraf/config"
|
2018-08-02 06:44:10 +08:00
|
|
|
"github.com/influxdata/telegraf/plugins/inputs/postgresql"
|
|
|
|
|
"github.com/influxdata/telegraf/testutil"
|
|
|
|
|
)
|
|
|
|
|
|
2021-01-27 02:06:12 +08:00
|
|
|
func TestPgBouncerGeneratesMetricsIntegration(t *testing.T) {
|
2022-05-26 00:45:55 +08:00
|
|
|
if testing.Short() {
|
|
|
|
|
t.Skip("Skipping integration test in short mode")
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-28 00:24:31 +08:00
|
|
|
postgresServicePort := "5432"
|
|
|
|
|
pgBouncerServicePort := "6432"
|
|
|
|
|
|
2022-05-26 00:45:55 +08:00
|
|
|
backend := testutil.Container{
|
|
|
|
|
Image: "postgres:alpine",
|
2022-05-28 00:24:31 +08:00
|
|
|
ExposedPorts: []string{postgresServicePort},
|
2022-05-26 00:45:55 +08:00
|
|
|
Env: map[string]string{
|
|
|
|
|
"POSTGRES_HOST_AUTH_METHOD": "trust",
|
|
|
|
|
},
|
2022-10-22 04:18:15 +08:00
|
|
|
WaitingFor: wait.ForLog("database system is ready to accept connections").WithOccurrence(2),
|
2022-05-26 00:45:55 +08:00
|
|
|
}
|
|
|
|
|
err := backend.Start()
|
|
|
|
|
require.NoError(t, err, "failed to start container")
|
2022-11-09 03:04:12 +08:00
|
|
|
defer backend.Terminate()
|
2022-05-26 00:45:55 +08:00
|
|
|
|
|
|
|
|
container := testutil.Container{
|
2023-07-05 22:11:11 +08:00
|
|
|
Image: "z9pascal/pgbouncer-container:1.18.0-latest",
|
2022-05-28 00:24:31 +08:00
|
|
|
ExposedPorts: []string{pgBouncerServicePort},
|
2022-05-26 00:45:55 +08:00
|
|
|
Env: map[string]string{
|
|
|
|
|
"PG_ENV_POSTGRESQL_USER": "pgbouncer",
|
|
|
|
|
"PG_ENV_POSTGRESQL_PASS": "pgbouncer",
|
|
|
|
|
},
|
2022-06-04 00:29:08 +08:00
|
|
|
WaitingFor: wait.ForAll(
|
|
|
|
|
wait.ForListeningPort(nat.Port(pgBouncerServicePort)),
|
|
|
|
|
wait.ForLog("LOG process up"),
|
|
|
|
|
),
|
2022-05-26 00:45:55 +08:00
|
|
|
}
|
|
|
|
|
err = container.Start()
|
|
|
|
|
require.NoError(t, err, "failed to start container")
|
2022-11-09 03:04:12 +08:00
|
|
|
defer container.Terminate()
|
2018-08-02 06:44:10 +08:00
|
|
|
|
2023-01-10 00:17:23 +08:00
|
|
|
addr := fmt.Sprintf(
|
|
|
|
|
"host=%s user=pgbouncer password=pgbouncer dbname=pgbouncer port=%s sslmode=disable",
|
|
|
|
|
container.Address,
|
|
|
|
|
container.Ports[pgBouncerServicePort],
|
|
|
|
|
)
|
|
|
|
|
|
2018-08-02 06:44:10 +08:00
|
|
|
p := &PgBouncer{
|
|
|
|
|
Service: postgresql.Service{
|
2023-01-10 00:17:23 +08:00
|
|
|
Address: config.NewSecret([]byte(addr)),
|
2018-08-02 06:44:10 +08:00
|
|
|
IsPgBouncer: true,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var acc testutil.Accumulator
|
|
|
|
|
require.NoError(t, p.Start(&acc))
|
|
|
|
|
require.NoError(t, p.Gather(&acc))
|
|
|
|
|
|
2021-06-03 11:28:16 +08:00
|
|
|
intMetricsPgBouncer := []string{
|
2018-08-02 06:44:10 +08:00
|
|
|
"total_received",
|
|
|
|
|
"total_sent",
|
|
|
|
|
"total_query_time",
|
2021-06-03 11:28:16 +08:00
|
|
|
"avg_query_count",
|
|
|
|
|
"avg_query_time",
|
|
|
|
|
"avg_wait_time",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
intMetricsPgBouncerPools := []string{
|
2018-08-02 06:44:10 +08:00
|
|
|
"cl_active",
|
|
|
|
|
"cl_waiting",
|
|
|
|
|
"sv_active",
|
|
|
|
|
"sv_idle",
|
|
|
|
|
"sv_used",
|
|
|
|
|
"sv_tested",
|
|
|
|
|
"sv_login",
|
|
|
|
|
"maxwait",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
metricsCounted := 0
|
|
|
|
|
|
2021-06-03 11:28:16 +08:00
|
|
|
for _, metric := range intMetricsPgBouncer {
|
2021-11-15 23:14:09 +08:00
|
|
|
require.True(t, acc.HasInt64Field("pgbouncer", metric))
|
2018-08-02 06:44:10 +08:00
|
|
|
metricsCounted++
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-03 11:28:16 +08:00
|
|
|
for _, metric := range intMetricsPgBouncerPools {
|
2021-11-15 23:14:09 +08:00
|
|
|
require.True(t, acc.HasInt64Field("pgbouncer_pools", metric))
|
2021-06-03 11:28:16 +08:00
|
|
|
metricsCounted++
|
|
|
|
|
}
|
|
|
|
|
|
2023-10-25 05:02:26 +08:00
|
|
|
require.Greater(t, metricsCounted, 0)
|
2023-07-05 22:11:11 +08:00
|
|
|
require.Equal(t, len(intMetricsPgBouncer)+len(intMetricsPgBouncerPools), metricsCounted)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestPgBouncerGeneratesMetricsIntegrationShowCommands(t *testing.T) {
|
|
|
|
|
if testing.Short() {
|
|
|
|
|
t.Skip("Skipping integration test in short mode")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
postgresServicePort := "5432"
|
|
|
|
|
pgBouncerServicePort := "6432"
|
|
|
|
|
|
|
|
|
|
backend := testutil.Container{
|
|
|
|
|
Image: "postgres:alpine",
|
|
|
|
|
ExposedPorts: []string{postgresServicePort},
|
|
|
|
|
Env: map[string]string{
|
|
|
|
|
"POSTGRES_HOST_AUTH_METHOD": "trust",
|
|
|
|
|
},
|
|
|
|
|
WaitingFor: wait.ForLog("database system is ready to accept connections").WithOccurrence(2),
|
|
|
|
|
}
|
|
|
|
|
err := backend.Start()
|
|
|
|
|
require.NoError(t, err, "failed to start container")
|
|
|
|
|
defer backend.Terminate()
|
|
|
|
|
|
|
|
|
|
container := testutil.Container{
|
|
|
|
|
Image: "z9pascal/pgbouncer-container:1.18.0-latest",
|
|
|
|
|
ExposedPorts: []string{pgBouncerServicePort},
|
|
|
|
|
Env: map[string]string{
|
|
|
|
|
"PG_ENV_POSTGRESQL_USER": "pgbouncer",
|
|
|
|
|
"PG_ENV_POSTGRESQL_PASS": "pgbouncer",
|
|
|
|
|
},
|
|
|
|
|
WaitingFor: wait.ForAll(
|
|
|
|
|
wait.ForListeningPort(nat.Port(pgBouncerServicePort)),
|
|
|
|
|
wait.ForLog("LOG process up"),
|
|
|
|
|
),
|
|
|
|
|
}
|
|
|
|
|
err = container.Start()
|
|
|
|
|
require.NoError(t, err, "failed to start container")
|
|
|
|
|
defer container.Terminate()
|
|
|
|
|
|
|
|
|
|
addr := fmt.Sprintf(
|
|
|
|
|
"host=%s user=pgbouncer password=pgbouncer dbname=pgbouncer port=%s sslmode=disable",
|
|
|
|
|
container.Address,
|
|
|
|
|
container.Ports[pgBouncerServicePort],
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
p := &PgBouncer{
|
|
|
|
|
Service: postgresql.Service{
|
|
|
|
|
Address: config.NewSecret([]byte(addr)),
|
|
|
|
|
IsPgBouncer: true,
|
|
|
|
|
},
|
|
|
|
|
ShowCommands: []string{"pools", "lists", "databases"},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var acc testutil.Accumulator
|
|
|
|
|
require.NoError(t, p.Start(&acc))
|
|
|
|
|
require.NoError(t, p.Gather(&acc))
|
|
|
|
|
|
|
|
|
|
intMetricsPgBouncerPools := []string{
|
|
|
|
|
"cl_active",
|
|
|
|
|
"cl_waiting",
|
|
|
|
|
"sv_active",
|
|
|
|
|
"sv_idle",
|
|
|
|
|
"sv_used",
|
|
|
|
|
"sv_tested",
|
|
|
|
|
"sv_login",
|
|
|
|
|
"maxwait",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
intMetricsPgBouncerLists := []string{
|
|
|
|
|
"databases",
|
|
|
|
|
"users",
|
|
|
|
|
"pools",
|
|
|
|
|
"free_clients",
|
|
|
|
|
"used_clients",
|
|
|
|
|
"login_clients",
|
|
|
|
|
"free_servers",
|
|
|
|
|
"used_servers",
|
|
|
|
|
"dns_names",
|
|
|
|
|
"dns_zones",
|
|
|
|
|
"dns_queries",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
intMetricsPgBouncerDatabases := []string{
|
|
|
|
|
"pool_size",
|
|
|
|
|
"min_pool_size",
|
|
|
|
|
"reserve_pool",
|
|
|
|
|
"max_connections",
|
|
|
|
|
"current_connections",
|
|
|
|
|
"paused",
|
|
|
|
|
"disabled",
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
metricsCounted := 0
|
|
|
|
|
|
|
|
|
|
for _, metric := range intMetricsPgBouncerPools {
|
|
|
|
|
require.True(t, acc.HasInt64Field("pgbouncer_pools", metric))
|
|
|
|
|
metricsCounted++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, metric := range intMetricsPgBouncerLists {
|
|
|
|
|
require.True(t, acc.HasInt64Field("pgbouncer_lists", metric))
|
|
|
|
|
metricsCounted++
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, metric := range intMetricsPgBouncerDatabases {
|
|
|
|
|
require.True(t, acc.HasInt64Field("pgbouncer_databases", metric))
|
2018-08-02 06:44:10 +08:00
|
|
|
metricsCounted++
|
|
|
|
|
}
|
|
|
|
|
|
2023-10-25 05:02:26 +08:00
|
|
|
require.Greater(t, metricsCounted, 0)
|
2023-07-05 22:11:11 +08:00
|
|
|
require.Equal(t, len(intMetricsPgBouncerPools)+len(intMetricsPgBouncerLists)+len(intMetricsPgBouncerDatabases), metricsCounted)
|
2018-08-02 06:44:10 +08:00
|
|
|
}
|