whatcanGOwrong

This commit is contained in:
2024-09-19 21:38:24 -04:00
commit d0ae4d841d
17908 changed files with 4096831 additions and 0 deletions
@@ -0,0 +1,34 @@
// Package testing has the database tests.
// All database drivers must pass the Test function.
// This lives in it's own package so it stays a test dependency.
package testing
import (
"testing"
)
import (
"github.com/golang-migrate/migrate/v4"
)
// TestMigrate runs integration-tests between the Migrate layer and database implementations.
func TestMigrate(t *testing.T, m *migrate.Migrate) {
TestMigrateUp(t, m)
TestMigrateDrop(t, m)
}
// Regression test for preventing a regression for #164 https://github.com/golang-migrate/migrate/pull/173
// Similar to TestDrop(), but tests the dropping mechanism through the Migrate logic instead, to check for
// double-locking during the Drop logic.
func TestMigrateDrop(t *testing.T, m *migrate.Migrate) {
if err := m.Drop(); err != nil {
t.Fatal(err)
}
}
func TestMigrateUp(t *testing.T, m *migrate.Migrate) {
t.Log("UP")
if err := m.Up(); err != nil {
t.Fatal(err)
}
}
@@ -0,0 +1,155 @@
// Package testing has the database tests.
// All database drivers must pass the Test function.
// This lives in it's own package so it stays a test dependency.
package testing
import (
"bytes"
"errors"
"fmt"
"io"
"testing"
"time"
"github.com/golang-migrate/migrate/v4/database"
)
// Test runs tests against database implementations.
func Test(t *testing.T, d database.Driver, migration []byte) {
if migration == nil {
t.Fatal("test must provide migration reader")
}
TestNilVersion(t, d) // test first
TestLockAndUnlock(t, d)
TestRun(t, d, bytes.NewReader(migration))
TestSetVersion(t, d) // also tests Version()
// Drop breaks the driver, so test it last.
TestDrop(t, d)
}
func TestNilVersion(t *testing.T, d database.Driver) {
v, _, err := d.Version()
if err != nil {
t.Fatal(err)
}
if v != database.NilVersion {
t.Fatalf("Version: expected version to be NilVersion (-1), got %v", v)
}
}
func TestLockAndUnlock(t *testing.T, d database.Driver) {
// add a timeout, in case there is a deadlock
done := make(chan struct{})
errs := make(chan error)
go func() {
timeout := time.After(15 * time.Second)
for {
select {
case <-done:
return
case <-timeout:
errs <- fmt.Errorf("Timeout after 15 seconds. Looks like a deadlock in Lock/UnLock.\n%#v", d)
return
}
}
}()
// run the locking test ...
go func() {
if err := d.Lock(); err != nil {
errs <- err
return
}
// try to acquire lock again
if err := d.Lock(); err == nil {
errs <- errors.New("lock: expected err not to be nil")
return
}
// unlock
if err := d.Unlock(); err != nil {
errs <- err
return
}
// try to lock
if err := d.Lock(); err != nil {
errs <- err
return
}
if err := d.Unlock(); err != nil {
errs <- err
return
}
// notify everyone
close(done)
}()
// wait for done or any error
for {
select {
case <-done:
return
case err := <-errs:
t.Fatal(err)
}
}
}
func TestRun(t *testing.T, d database.Driver, migration io.Reader) {
if migration == nil {
t.Fatal("migration can't be nil")
}
if err := d.Run(migration); err != nil {
t.Fatal(err)
}
}
func TestDrop(t *testing.T, d database.Driver) {
if err := d.Drop(); err != nil {
t.Fatal(err)
}
}
func TestSetVersion(t *testing.T, d database.Driver) {
// nolint:maligned
testCases := []struct {
name string
version int
dirty bool
expectedErr error
expectedReadErr error
expectedVersion int
expectedDirty bool
}{
{name: "set 1 dirty", version: 1, dirty: true, expectedErr: nil, expectedReadErr: nil, expectedVersion: 1, expectedDirty: true},
{name: "re-set 1 dirty", version: 1, dirty: true, expectedErr: nil, expectedReadErr: nil, expectedVersion: 1, expectedDirty: true},
{name: "set 2 clean", version: 2, dirty: false, expectedErr: nil, expectedReadErr: nil, expectedVersion: 2, expectedDirty: false},
{name: "re-set 2 clean", version: 2, dirty: false, expectedErr: nil, expectedReadErr: nil, expectedVersion: 2, expectedDirty: false},
{name: "last migration dirty", version: database.NilVersion, dirty: true, expectedErr: nil, expectedReadErr: nil, expectedVersion: database.NilVersion, expectedDirty: true},
{name: "last migration clean", version: database.NilVersion, dirty: false, expectedErr: nil, expectedReadErr: nil, expectedVersion: database.NilVersion, expectedDirty: false},
}
for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
err := d.SetVersion(tc.version, tc.dirty)
if err != tc.expectedErr {
t.Fatal("Got unexpected error:", err, "!=", tc.expectedErr)
}
v, dirty, readErr := d.Version()
if readErr != tc.expectedReadErr {
t.Fatal("Got unexpected error:", readErr, "!=", tc.expectedReadErr)
}
if v != tc.expectedVersion {
t.Error("Got unexpected version:", v, "!=", tc.expectedVersion)
}
if dirty != tc.expectedDirty {
t.Error("Got unexpected dirty value:", dirty, "!=", tc.dirty)
}
})
}
}