diff --git a/migrations/000002_create_metadata_table.down.sql b/migrations/000002_create_metadata_table.down.sql new file mode 100644 index 00000000..8c8d67cb --- /dev/null +++ b/migrations/000002_create_metadata_table.down.sql @@ -0,0 +1 @@ +DROP TABLE IF EXISTS metadata; diff --git a/migrations/000002_create_metadata_table.up.sql b/migrations/000002_create_metadata_table.up.sql new file mode 100644 index 00000000..69ee69d0 --- /dev/null +++ b/migrations/000002_create_metadata_table.up.sql @@ -0,0 +1,7 @@ +CREATE TABLE IF NOT EXISTS metadata ( + id uuid PRIMARY KEY, + created_at timestamp without time zone, + updated_at timestamp without time zone, + version VARCHAR(50), + description TEXT +); diff --git a/tests/integration_test.go b/tests/integration_test.go index 073f596b..6121938c 100644 --- a/tests/integration_test.go +++ b/tests/integration_test.go @@ -4,6 +4,7 @@ import ( "fmt" "strings" "testing" + "time" "github.com/stretchr/testify/assert" ) @@ -105,6 +106,84 @@ func TestInsertSubjectWithLongTypeFails(t *testing.T) { // nolint:paralleltest / } } +func TestMetadataMigration(t *testing.T) { // nolint:paralleltest // database tests should run serially + m := getMigrationHelper(t) + gormDB := getGormHelper() + tableName := "metadata" + + if err := m.Migrate(1); err != nil { + t.Fatalf("Unable to upgrade database: %s", err) + } + + // Ensure the metadata table doesn't exist before the upgrade + result := gormDB.Migrator().HasTable(tableName) + assert.False(t, result, "Table exists prior to migration: %s", tableName) + + // Ensure the table exists after running the migration + if err := m.Migrate(2); err != nil { + t.Fatalf("Unable to upgrade database: %s", err) + } + + result = gormDB.Migrator().HasTable(tableName) + assert.True(t, result, "Table doesn't exist: %s", tableName) + + // Check to make sure it has the expected columns + type metadata struct{} + for _, s := range []string{"id", "created_at", "updated_at", "version", "description"} { + result = gormDB.Migrator().HasColumn(&metadata{}, s) + assert.True(t, result, "Column doesn't exist: %s", s) + } + + // Ensure the table is removed on downgrade + if err := m.Migrate(1); err != nil { + t.Fatalf("Unable to upgrade database: %s", err) + } + result = gormDB.Migrator().HasTable(tableName) + assert.False(t, result, "Table exists after downgrade: %s", tableName) + + if err := m.Drop(); err != nil { + t.Fatalf("Unable to drop database: %s", err) + } +} + +func TestInsertMetadataSucceeds(t *testing.T) { // nolint:paralleltest // database tests should run serially + m := getMigrationHelper(t) + gormDB := getGormHelper() + + if err := m.Migrate(2); err != nil { + t.Fatalf("Unable to upgrade database: %s", err) + } + + id := getUUIDString() + // time.Now().UTC() will return a time.Time struct with microsecond + // precision, but the timestamp type in PostgreSQL is not microsecond + // precise. Round off the microsecond precision to model what the + // database actually gives us. + createdAt := time.Now().UTC().Round(time.Microsecond) + updatedAt := time.Now().UTC().Round(time.Microsecond) + version := getUUIDString() + description := getUUIDString() + + md := Metadata{ID: id, CreatedAt: createdAt, UpdatedAt: updatedAt, Version: version, Description: description} + err := gormDB.Create(&md).Error + assert.Nil(t, err) + + a := Metadata{} + gormDB.First(&a, "id = ?", id) + fmt.Println(a.UpdatedAt) + + e := Metadata{ID: id, CreatedAt: createdAt, UpdatedAt: updatedAt, Version: version, Description: description} + assert.Equal(t, e.ID, a.ID, "expected %s got %s", e.ID, a.ID) + assert.Equal(t, e.CreatedAt, a.CreatedAt, "expected %s got %s", e.CreatedAt, a.CreatedAt) + assert.Equal(t, e.UpdatedAt, a.UpdatedAt, "expected %s got %s", e.UpdatedAt, a.UpdatedAt) + assert.Equal(t, e.Version, a.Version, "expected %s got %s", e.Version, a.Version) + assert.Equal(t, e.Description, a.Description, "expected %s got %s", e.Description, a.Description) + + if err := m.Drop(); err != nil { + t.Fatalf("Unable to drop database: %s", err) + } +} + func TestMigration(t *testing.T) { // nolint:paralleltest // database tests should run serially m := getMigrationHelper(t) @@ -123,7 +202,7 @@ func TestMigration(t *testing.T) { // nolint:paralleltest // database tests shou // Upgrade the database and make sure all upgrades apply cleanly. err = m.Up() version, dirty, _ = m.Version() - expectedVersion = uint(1) + expectedVersion = uint(2) assert.Equal(t, expectedVersion, version, "Database version mismatch: want %d but got %d", expectedVersion, version) assert.Equal(t, false, dirty, "Database state mismatch: want %t but got %t", false, dirty) assert.Equal(t, err, nil, "Error upgrading the database: %s", err) diff --git a/tests/utils.go b/tests/utils.go index 71a68e67..04eddae8 100644 --- a/tests/utils.go +++ b/tests/utils.go @@ -16,6 +16,14 @@ import ( "gorm.io/gorm" ) +type Metadata struct { + ID string + CreatedAt time.Time + UpdatedAt time.Time + Version string + Description string +} + type Subject struct { ID string Name string