-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtesting.go
69 lines (54 loc) · 1.98 KB
/
testing.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package pgutil
import (
"context"
"database/sql"
"fmt"
"net/url"
"os"
"testing"
"github.com/go-nacelle/log/v2"
"github.com/lib/pq"
"github.com/stretchr/testify/require"
)
func NewTestDB(t testing.TB) DB {
return NewTestDBWithLogger(t, log.NewNilLogger())
}
func NewTestDBWithLogger(t testing.TB, logger log.Logger) DB {
t.Helper()
id, err := randomHexString(16)
require.NoError(t, err)
var (
testDatabaseName = fmt.Sprintf("pgutil-test-%s", id)
quotedTestDatabaseName = pq.QuoteIdentifier(testDatabaseName)
quotedTemplateDatabaseName = pq.QuoteIdentifier(os.Getenv("TEMPLATEDB"))
// NOTE: Must interpolate identifiers here as placeholders aren't valid in this position.
createDatabaseQuery = queryf("CREATE DATABASE %s TEMPLATE %s", quotedTestDatabaseName, quotedTemplateDatabaseName)
dropDatabaseQuery = queryf("DROP DATABASE %s", quotedTestDatabaseName)
terminateConnectionsQuery = Query("SELECT pg_terminate_backend(pid) FROM pg_stat_activity WHERE datname = {:name}", Args{"name": testDatabaseName})
)
// Resolve "control" database URL
baseURL := BuildDatabaseURL()
parsedURL, err := url.Parse(baseURL)
require.NoError(t, err)
// Resolve "test" database URL
testDBURL := parsedURL.ResolveReference(&url.URL{
Path: "/" + testDatabaseName,
RawQuery: parsedURL.RawQuery,
})
// Open "control" database
rawDB, err := sql.Open("postgres", baseURL)
require.NoError(t, err)
rawLoggingDB := newLoggingDB(rawDB, log.NewNilLogger())
// Create "test" database
require.NoError(t, rawLoggingDB.Exec(context.Background(), createDatabaseQuery))
// Open "test" database
testDB, err := sql.Open("postgres", testDBURL.String())
require.NoError(t, err)
t.Cleanup(func() {
defer rawDB.Close()
require.NoError(t, testDB.Close())
require.NoError(t, rawLoggingDB.Exec(context.Background(), terminateConnectionsQuery))
require.NoError(t, rawLoggingDB.Exec(context.Background(), dropDatabaseQuery))
})
return newLoggingDB(testDB, logger)
}