2022-08-31 12:38:31 +02:00
|
|
|
package daos_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2023-12-02 12:43:22 +02:00
|
|
|
"github.com/pocketbase/dbx"
|
2022-08-31 12:38:31 +02:00
|
|
|
"github.com/pocketbase/pocketbase/models"
|
|
|
|
"github.com/pocketbase/pocketbase/tests"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestExternalAuthQuery(t *testing.T) {
|
2024-01-03 04:30:20 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
app, _ := tests.NewTestApp()
|
|
|
|
defer app.Cleanup()
|
|
|
|
|
|
|
|
expected := "SELECT {{_externalAuths}}.* FROM `_externalAuths`"
|
|
|
|
|
|
|
|
sql := app.Dao().ExternalAuthQuery().Build().SQL()
|
|
|
|
if sql != expected {
|
|
|
|
t.Errorf("Expected sql %s, got %s", expected, sql)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-30 10:28:14 +02:00
|
|
|
func TestFindAllExternalAuthsByRecord(t *testing.T) {
|
2024-01-03 04:30:20 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
app, _ := tests.NewTestApp()
|
|
|
|
defer app.Cleanup()
|
|
|
|
|
|
|
|
scenarios := []struct {
|
|
|
|
userId string
|
|
|
|
expectedCount int
|
|
|
|
}{
|
2022-10-30 10:28:14 +02:00
|
|
|
{"oap640cot4yru2s", 0},
|
|
|
|
{"4q1xlclmfloku33", 2},
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for i, s := range scenarios {
|
2022-10-30 10:28:14 +02:00
|
|
|
record, err := app.Dao().FindRecordById("users", s.userId)
|
2022-08-31 12:38:31 +02:00
|
|
|
if err != nil {
|
2022-10-30 10:28:14 +02:00
|
|
|
t.Errorf("(%d) Unexpected record fetch error %v", i, err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
auths, err := app.Dao().FindAllExternalAuthsByRecord(record)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("(%d) Unexpected auths fetch error %v", i, err)
|
2022-08-31 12:38:31 +02:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(auths) != s.expectedCount {
|
|
|
|
t.Errorf("(%d) Expected %d auths, got %d", i, s.expectedCount, len(auths))
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, auth := range auths {
|
2022-10-30 10:28:14 +02:00
|
|
|
if auth.RecordId != record.Id {
|
|
|
|
t.Errorf("(%d) Expected all auths to be linked to record id %s, got %v", i, record.Id, auth)
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-02 12:43:22 +02:00
|
|
|
func TestFindFirstExternalAuthByExpr(t *testing.T) {
|
2024-01-03 04:30:20 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
app, _ := tests.NewTestApp()
|
|
|
|
defer app.Cleanup()
|
|
|
|
|
|
|
|
scenarios := []struct {
|
2023-12-02 12:43:22 +02:00
|
|
|
expr dbx.Expression
|
2022-08-31 12:38:31 +02:00
|
|
|
expectedId string
|
|
|
|
}{
|
2023-12-02 12:43:22 +02:00
|
|
|
{dbx.HashExp{"provider": "github", "providerId": ""}, ""},
|
|
|
|
{dbx.HashExp{"provider": "github", "providerId": "id1"}, ""},
|
|
|
|
{dbx.HashExp{"provider": "github", "providerId": "id2"}, ""},
|
|
|
|
{dbx.HashExp{"provider": "google", "providerId": "test123"}, "clmflokuq1xl341"},
|
|
|
|
{dbx.HashExp{"provider": "gitlab", "providerId": "test123"}, "dlmflokuq1xl342"},
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for i, s := range scenarios {
|
2023-12-02 12:43:22 +02:00
|
|
|
auth, err := app.Dao().FindFirstExternalAuthByExpr(s.expr)
|
2022-08-31 12:38:31 +02:00
|
|
|
|
|
|
|
hasErr := err != nil
|
|
|
|
expectErr := s.expectedId == ""
|
|
|
|
if hasErr != expectErr {
|
|
|
|
t.Errorf("(%d) Expected hasErr %v, got %v", i, expectErr, err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if auth != nil && auth.Id != s.expectedId {
|
|
|
|
t.Errorf("(%d) Expected external auth with ID %s, got \n%v", i, s.expectedId, auth)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-30 10:28:14 +02:00
|
|
|
func TestFindExternalAuthByRecordAndProvider(t *testing.T) {
|
2024-01-03 04:30:20 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
app, _ := tests.NewTestApp()
|
|
|
|
defer app.Cleanup()
|
|
|
|
|
|
|
|
scenarios := []struct {
|
|
|
|
userId string
|
|
|
|
provider string
|
|
|
|
expectedId string
|
|
|
|
}{
|
2022-10-30 10:28:14 +02:00
|
|
|
{"bgs820n361vj1qd", "google", ""},
|
|
|
|
{"4q1xlclmfloku33", "google", "clmflokuq1xl341"},
|
|
|
|
{"4q1xlclmfloku33", "gitlab", "dlmflokuq1xl342"},
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for i, s := range scenarios {
|
2022-10-30 10:28:14 +02:00
|
|
|
record, err := app.Dao().FindRecordById("users", s.userId)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("(%d) Unexpected record fetch error %v", i, err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
auth, err := app.Dao().FindExternalAuthByRecordAndProvider(record, s.provider)
|
2022-08-31 12:38:31 +02:00
|
|
|
|
|
|
|
hasErr := err != nil
|
|
|
|
expectErr := s.expectedId == ""
|
|
|
|
if hasErr != expectErr {
|
|
|
|
t.Errorf("(%d) Expected hasErr %v, got %v", i, expectErr, err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if auth != nil && auth.Id != s.expectedId {
|
|
|
|
t.Errorf("(%d) Expected external auth with ID %s, got \n%v", i, s.expectedId, auth)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSaveExternalAuth(t *testing.T) {
|
2024-01-03 04:30:20 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
app, _ := tests.NewTestApp()
|
|
|
|
defer app.Cleanup()
|
|
|
|
|
2022-09-02 11:05:00 +02:00
|
|
|
// save with empty provider data
|
|
|
|
emptyAuth := &models.ExternalAuth{}
|
|
|
|
if err := app.Dao().SaveExternalAuth(emptyAuth); err == nil {
|
|
|
|
t.Fatal("Expected error, got nil")
|
|
|
|
}
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
auth := &models.ExternalAuth{
|
2022-10-30 10:28:14 +02:00
|
|
|
RecordId: "o1y0dd0spd786md",
|
|
|
|
CollectionId: "v851q4r790rhknl",
|
|
|
|
Provider: "test",
|
|
|
|
ProviderId: "test_id",
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := app.Dao().SaveExternalAuth(auth); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// check if it was really saved
|
2023-12-02 12:43:22 +02:00
|
|
|
foundAuth, err := app.Dao().FindFirstExternalAuthByExpr(dbx.HashExp{
|
|
|
|
"collectionId": "v851q4r790rhknl",
|
|
|
|
"provider": "test",
|
|
|
|
"providerId": "test_id",
|
|
|
|
})
|
2022-08-31 12:38:31 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if auth.Id != foundAuth.Id {
|
|
|
|
t.Fatalf("Expected ExternalAuth with id %s, got \n%v", auth.Id, foundAuth)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDeleteExternalAuth(t *testing.T) {
|
2024-01-03 04:30:20 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2022-08-31 12:38:31 +02:00
|
|
|
app, _ := tests.NewTestApp()
|
|
|
|
defer app.Cleanup()
|
|
|
|
|
2022-10-30 10:28:14 +02:00
|
|
|
record, err := app.Dao().FindRecordById("users", "4q1xlclmfloku33")
|
2022-08-31 12:38:31 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2022-10-30 10:28:14 +02:00
|
|
|
auths, err := app.Dao().FindAllExternalAuthsByRecord(record)
|
2022-08-31 12:38:31 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2022-10-30 10:28:14 +02:00
|
|
|
for _, auth := range auths {
|
|
|
|
if err := app.Dao().DeleteExternalAuth(auth); err != nil {
|
|
|
|
t.Fatalf("Failed to delete the ExternalAuth relation, got \n%v", err)
|
|
|
|
}
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// check if the relations were really deleted
|
2022-10-30 10:28:14 +02:00
|
|
|
newAuths, err := app.Dao().FindAllExternalAuthsByRecord(record)
|
2022-08-31 12:38:31 +02:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(newAuths) != 0 {
|
2022-10-30 10:28:14 +02:00
|
|
|
t.Fatalf("Expected all record %s ExternalAuth relations to be deleted, got \n%v", record.Id, newAuths)
|
2022-08-31 12:38:31 +02:00
|
|
|
}
|
|
|
|
}
|