mirror of
https://github.com/grafana/grafana.git
synced 2025-01-18 12:33:37 -06:00
117 lines
2.9 KiB
Go
117 lines
2.9 KiB
Go
//go:build integration
|
|
// +build integration
|
|
|
|
package sqlstore
|
|
|
|
import (
|
|
"errors"
|
|
"net/url"
|
|
"testing"
|
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
type sqlStoreTest struct {
|
|
name string
|
|
dbType string
|
|
dbHost string
|
|
dbURL string
|
|
connStrValues []string
|
|
err error
|
|
}
|
|
|
|
var sqlStoreTestCases = []sqlStoreTest{
|
|
{
|
|
name: "MySQL IPv4",
|
|
dbType: "mysql",
|
|
dbHost: "1.2.3.4:5678",
|
|
connStrValues: []string{"tcp(1.2.3.4:5678)"},
|
|
},
|
|
{
|
|
name: "Postgres IPv4",
|
|
dbType: "postgres",
|
|
dbHost: "1.2.3.4:5678",
|
|
connStrValues: []string{"host=1.2.3.4", "port=5678"},
|
|
},
|
|
{
|
|
name: "Postgres IPv4 (Default Port)",
|
|
dbType: "postgres",
|
|
dbHost: "1.2.3.4",
|
|
connStrValues: []string{"host=1.2.3.4", "port=5432"},
|
|
},
|
|
{
|
|
name: "MySQL IPv4 (Default Port)",
|
|
dbType: "mysql",
|
|
dbHost: "1.2.3.4",
|
|
connStrValues: []string{"tcp(1.2.3.4)"},
|
|
},
|
|
{
|
|
name: "MySQL IPv6",
|
|
dbType: "mysql",
|
|
dbHost: "[fe80::24e8:31b2:91df:b177]:1234",
|
|
connStrValues: []string{"tcp([fe80::24e8:31b2:91df:b177]:1234)"},
|
|
},
|
|
{
|
|
name: "Postgres IPv6",
|
|
dbType: "postgres",
|
|
dbHost: "[fe80::24e8:31b2:91df:b177]:1234",
|
|
connStrValues: []string{"host=fe80::24e8:31b2:91df:b177", "port=1234"},
|
|
},
|
|
{
|
|
name: "MySQL IPv6 (Default Port)",
|
|
dbType: "mysql",
|
|
dbHost: "[::1]",
|
|
connStrValues: []string{"tcp([::1])"},
|
|
},
|
|
{
|
|
name: "Postgres IPv6 (Default Port)",
|
|
dbType: "postgres",
|
|
dbHost: "[::1]",
|
|
connStrValues: []string{"host=::1", "port=5432"},
|
|
},
|
|
{
|
|
name: "Invalid database URL",
|
|
dbURL: "://invalid.com/",
|
|
err: &url.Error{Op: "parse", URL: "://invalid.com/", Err: errors.New("missing protocol scheme")},
|
|
},
|
|
}
|
|
|
|
func TestSQLConnectionString(t *testing.T) {
|
|
for _, testCase := range sqlStoreTestCases {
|
|
t.Run(testCase.name, func(t *testing.T) {
|
|
sqlstore := &SQLStore{}
|
|
sqlstore.Cfg = makeSQLStoreTestConfig(t, testCase.dbType, testCase.dbHost, testCase.dbURL)
|
|
connStr, err := sqlstore.buildConnectionString()
|
|
require.Equal(t, testCase.err, err)
|
|
|
|
for _, connSubStr := range testCase.connStrValues {
|
|
require.Contains(t, connStr, connSubStr)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func makeSQLStoreTestConfig(t *testing.T, dbType, host, dbURL string) *setting.Cfg {
|
|
t.Helper()
|
|
|
|
cfg := setting.NewCfg()
|
|
|
|
sec, err := cfg.Raw.NewSection("database")
|
|
require.NoError(t, err)
|
|
_, err = sec.NewKey("type", dbType)
|
|
require.NoError(t, err)
|
|
_, err = sec.NewKey("host", host)
|
|
require.NoError(t, err)
|
|
_, err = sec.NewKey("url", dbURL)
|
|
require.NoError(t, err)
|
|
_, err = sec.NewKey("user", "user")
|
|
require.NoError(t, err)
|
|
_, err = sec.NewKey("name", "test_db")
|
|
require.NoError(t, err)
|
|
_, err = sec.NewKey("password", "pass")
|
|
require.NoError(t, err)
|
|
|
|
return cfg
|
|
}
|