forked from mystiq/dex
9796a1e648
The "redirectURLs" field in the client metadata has been updated to the correct "redirect_uris". To allow backwards compatibility use Postgres' JSON features to update the actual JSON in the text field. json_build_object was introduced in Postgres 9.4. So update the documentations to require at least this version.
121 lines
2.7 KiB
Go
121 lines
2.7 KiB
Go
package db
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"strconv"
|
|
"testing"
|
|
|
|
"github.com/go-gorp/gorp"
|
|
)
|
|
|
|
func initDB(dsn string) *gorp.DbMap {
|
|
c, err := NewConnection(Config{DSN: dsn})
|
|
if err != nil {
|
|
panic(fmt.Sprintf("error making db connection: %q", err))
|
|
}
|
|
if err = c.DropTablesIfExists(); err != nil {
|
|
panic(fmt.Sprintf("Unable to drop database tables: %v", err))
|
|
}
|
|
|
|
return c
|
|
}
|
|
|
|
// TestGetPlannedMigrations is a sanity check, ensuring that at least one
|
|
// migration can be found.
|
|
func TestGetPlannedMigrations(t *testing.T) {
|
|
dsn := os.Getenv("DEX_TEST_DSN")
|
|
if dsn == "" {
|
|
t.Skip("Test will not run without DEX_TEST_DSN environment variable.")
|
|
return
|
|
}
|
|
dbMap := initDB(dsn)
|
|
ms, err := GetPlannedMigrations(dbMap)
|
|
if err != nil {
|
|
pwd, err := os.Getwd()
|
|
t.Logf("pwd: %v", pwd)
|
|
t.Fatalf("unexpected err: %q", err)
|
|
}
|
|
|
|
if len(ms) == 0 {
|
|
t.Fatalf("expected non-empty migrations")
|
|
}
|
|
}
|
|
|
|
func TestMigrateClientMetadata(t *testing.T) {
|
|
dsn := os.Getenv("DEX_TEST_DSN")
|
|
if dsn == "" {
|
|
t.Skip("Test will not run without DEX_TEST_DSN environment variable.")
|
|
return
|
|
}
|
|
dbMap := initDB(dsn)
|
|
|
|
nMigrations := 9
|
|
n, err := MigrateMaxMigrations(dbMap, nMigrations)
|
|
if err != nil {
|
|
t.Fatalf("failed to perform initial migration: %v", err)
|
|
}
|
|
if n != nMigrations {
|
|
t.Fatalf("expected to perform %d migrations, got %d", nMigrations, n)
|
|
}
|
|
|
|
tests := []struct {
|
|
before string
|
|
after string
|
|
}{
|
|
// only update rows without a "redirect_uris" key
|
|
{
|
|
`{"redirectURLs":["foo"]}`,
|
|
`{"redirectURLs" : ["foo"], "redirect_uris" : ["foo"]}`,
|
|
},
|
|
{
|
|
`{"redirectURLs":["foo","bar"]}`,
|
|
`{"redirectURLs" : ["foo","bar"], "redirect_uris" : ["foo","bar"]}`,
|
|
},
|
|
{
|
|
`{"redirect_uris":["foo"],"another_field":8}`,
|
|
`{"redirect_uris":["foo"],"another_field":8}`,
|
|
},
|
|
{
|
|
`{"redirectURLs" : ["foo"], "redirect_uris" : ["foo"]}`,
|
|
`{"redirectURLs" : ["foo"], "redirect_uris" : ["foo"]}`,
|
|
},
|
|
}
|
|
|
|
for i, tt := range tests {
|
|
model := &clientIdentityModel{
|
|
ID: strconv.Itoa(i),
|
|
Secret: []byte("verysecret"),
|
|
Metadata: tt.before,
|
|
}
|
|
if err := dbMap.Insert(model); err != nil {
|
|
t.Fatalf("could not insert model: %v", err)
|
|
}
|
|
}
|
|
|
|
n, err = MigrateMaxMigrations(dbMap, 1)
|
|
if err != nil {
|
|
t.Fatalf("failed to perform initial migration: %v", err)
|
|
}
|
|
if n != 1 {
|
|
t.Fatalf("expected to perform 1 migration, got %d", n)
|
|
}
|
|
|
|
for i, tt := range tests {
|
|
id := strconv.Itoa(i)
|
|
m, err := dbMap.Get(clientIdentityModel{}, id)
|
|
if err != nil {
|
|
t.Errorf("case %d: failed to get model: %err", i, err)
|
|
continue
|
|
}
|
|
cim, ok := m.(*clientIdentityModel)
|
|
if !ok {
|
|
t.Errorf("case %d: unrecognized model type: %T", i, m)
|
|
continue
|
|
}
|
|
|
|
if cim.Metadata != tt.after {
|
|
t.Errorf("case %d: want=%q, got=%q", i, tt.after, cim.Metadata)
|
|
}
|
|
}
|
|
}
|