You've already forked testing-go-code-with-postgres
mirror of
https://github.com/xorcare/testing-go-code-with-postgres.git
synced 2025-06-30 23:23:40 +02:00
Add example of tests with isolated schema
This commit is contained in:
@ -94,6 +94,86 @@ func TestNewPostgres(t *testing.T) {
|
||||
})
|
||||
}
|
||||
|
||||
func TestNewWithIsolatedSchema(t *testing.T) {
|
||||
if testing.Short() {
|
||||
t.Skip("skipping test in short mode")
|
||||
}
|
||||
|
||||
t.Parallel()
|
||||
|
||||
t.Run("Successfully connect by URL and get version", func(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
// Arrange
|
||||
postgres := testingpg.NewWithIsolatedSchema(t)
|
||||
|
||||
ctx := context.Background()
|
||||
dbPool, err := pgxpool.New(ctx, postgres.URL())
|
||||
require.NoError(t, err)
|
||||
|
||||
// Act
|
||||
var version string
|
||||
err = dbPool.QueryRow(ctx, "SHOW search_path;").Scan(&version)
|
||||
|
||||
// Assert
|
||||
require.NoError(t, err)
|
||||
require.NotEmpty(t, version)
|
||||
t.Log(version)
|
||||
})
|
||||
|
||||
t.Run("Successfully obtained a version using a pre-configured conn", func(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
// Arrange
|
||||
postgres := testingpg.NewWithIsolatedSchema(t)
|
||||
ctx := context.Background()
|
||||
|
||||
// Act
|
||||
var version string
|
||||
err := postgres.DB().QueryRowContext(ctx, "SHOW search_path;").Scan(&version)
|
||||
|
||||
// Assert
|
||||
require.NoError(t, err)
|
||||
require.NotEmpty(t, version)
|
||||
|
||||
t.Log(version)
|
||||
})
|
||||
|
||||
t.Run("Changes are not visible in different instances", func(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
// Arrange
|
||||
postgres1 := testingpg.NewWithIsolatedSchema(t)
|
||||
postgres2 := testingpg.NewWithIsolatedSchema(t)
|
||||
|
||||
ctx := context.Background()
|
||||
|
||||
// Act
|
||||
const sqlStr = `CREATE TABLE "no_conflict" (id integer PRIMARY KEY)`
|
||||
_, err1 := postgres1.DB().ExecContext(ctx, sqlStr)
|
||||
_, err2 := postgres2.DB().ExecContext(ctx, sqlStr)
|
||||
|
||||
// Assert
|
||||
require.NoError(t, err1)
|
||||
require.NoError(t, err2, "databases must be isolated for each instance")
|
||||
})
|
||||
|
||||
t.Run("URL is different at different instances", func(t *testing.T) {
|
||||
t.Parallel()
|
||||
|
||||
// Arrange
|
||||
postgres1 := testingpg.NewWithIsolatedSchema(t)
|
||||
postgres2 := testingpg.NewWithIsolatedSchema(t)
|
||||
|
||||
// Act
|
||||
url1 := postgres1.URL()
|
||||
url2 := postgres2.URL()
|
||||
|
||||
// Assert
|
||||
require.NotEqual(t, url1, url2)
|
||||
})
|
||||
}
|
||||
|
||||
func TestNewWithTransactionalCleanup(t *testing.T) {
|
||||
if testing.Short() {
|
||||
t.Skip("skipping test in short mode")
|
||||
|
Reference in New Issue
Block a user