mirror of
https://github.com/paralus/paralus.git
synced 2026-02-14 17:49:51 +00:00
80 lines
5.1 KiB
Go
80 lines
5.1 KiB
Go
package service
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/DATA-DOG/go-sqlmock"
|
|
"github.com/google/uuid"
|
|
)
|
|
|
|
func TestGetProjectNamespaces(t *testing.T) {
|
|
db, mock := getDB(t)
|
|
defer db.Close()
|
|
|
|
puuid := uuid.New()
|
|
mock.ExpectQuery(`SELECT "projectaccountnamespacerole"."id", "projectaccountnamespacerole"."name", "projectaccountnamespacerole"."description", "projectaccountnamespacerole"."created_at", "projectaccountnamespacerole"."modified_at", "projectaccountnamespacerole"."trash", "projectaccountnamespacerole"."organization_id", "projectaccountnamespacerole"."partner_id", "projectaccountnamespacerole"."role_id", "projectaccountnamespacerole"."account_id", "projectaccountnamespacerole"."project_id", "projectaccountnamespacerole"."namespace", "projectaccountnamespacerole"."active" FROM "authsrv_projectaccountnamespacerole" AS "projectaccountnamespacerole" WHERE \(project_id = '` + puuid.String() + `'\) AND \(trash = FALSE\)`).
|
|
WithArgs().WillReturnRows(sqlmock.NewRows([]string{"namespace"}).AddRow("namespace1"))
|
|
mock.ExpectQuery(`SELECT "projectgroupnamespacerole"."id", "projectgroupnamespacerole"."name", "projectgroupnamespacerole"."description", "projectgroupnamespacerole"."created_at", "projectgroupnamespacerole"."modified_at", "projectgroupnamespacerole"."trash", "projectgroupnamespacerole"."organization_id", "projectgroupnamespacerole"."partner_id", "projectgroupnamespacerole"."role_id", "projectgroupnamespacerole"."group_id", "projectgroupnamespacerole"."project_id", "projectgroupnamespacerole"."namespace", "projectgroupnamespacerole"."active" FROM "authsrv_projectgroupnamespacerole" AS "projectgroupnamespacerole" WHERE \(project_id = '` + puuid.String() + `'\) AND \(trash = FALSE\)`).
|
|
WithArgs().WillReturnRows(sqlmock.NewRows([]string{"namespace"}).AddRow("namespace2"))
|
|
|
|
ns := NewNamespaceService(db)
|
|
nl, err := ns.GetProjectNamespaces(context.Background(), puuid)
|
|
if err != nil {
|
|
t.Fatal("unable to get namespaces", err)
|
|
}
|
|
if len(nl) != 2 {
|
|
t.Errorf("incorrect number of namespaces; expected '%v', got '%v'", 2, len(nl))
|
|
}
|
|
if nl[0] != "namespace1" {
|
|
t.Errorf("incorrect namespace name; expected '%v', got '%v'", "namespace1", nl[0])
|
|
}
|
|
if nl[1] != "namespace2" {
|
|
t.Errorf("incorrect namespace name; expected '%v', got '%v'", "namespace2", nl[1])
|
|
}
|
|
}
|
|
|
|
func TestGetAccountProjectNamespaces(t *testing.T) {
|
|
db, mock := getDB(t)
|
|
defer db.Close()
|
|
|
|
puuid := uuid.New()
|
|
uuuid := uuid.New()
|
|
mock.ExpectQuery(`SELECT "projectaccountnamespacerole"."id", "projectaccountnamespacerole"."name", "projectaccountnamespacerole"."description", "projectaccountnamespacerole"."created_at", "projectaccountnamespacerole"."modified_at", "projectaccountnamespacerole"."trash", "projectaccountnamespacerole"."organization_id", "projectaccountnamespacerole"."partner_id", "projectaccountnamespacerole"."role_id", "projectaccountnamespacerole"."account_id", "projectaccountnamespacerole"."project_id", "projectaccountnamespacerole"."namespace", "projectaccountnamespacerole"."active" FROM "authsrv_projectaccountnamespacerole" AS "projectaccountnamespacerole" WHERE \(project_id = '` + puuid.String() + `'\) AND \(account_id = '` + uuuid.String() + `'\)`).
|
|
WithArgs().WillReturnRows(sqlmock.NewRows([]string{"namespace"}).AddRow("namespace1"))
|
|
|
|
ns := NewNamespaceService(db)
|
|
nl, err := ns.GetAccountProjectNamespaces(context.Background(), puuid, uuuid)
|
|
if err != nil {
|
|
t.Fatal("unable to get namespaces", err)
|
|
}
|
|
if len(nl) != 1 {
|
|
t.Errorf("incorrect number of namespaces; expected '%v', got '%v'", 1, len(nl))
|
|
}
|
|
if nl[0] != "namespace1" {
|
|
t.Errorf("incorrect namespace name; expected '%v', got '%v'", "namespace1", nl[0])
|
|
}
|
|
}
|
|
|
|
func TestGetGroupProjectNamespaces(t *testing.T) {
|
|
db, mock := getDB(t)
|
|
defer db.Close()
|
|
|
|
puuid := uuid.New()
|
|
uuuid := uuid.New()
|
|
mock.ExpectQuery(`SELECT "projectgroupnamespacerole"."id", "projectgroupnamespacerole"."name", "projectgroupnamespacerole"."description", "projectgroupnamespacerole"."created_at", "projectgroupnamespacerole"."modified_at", "projectgroupnamespacerole"."trash", "projectgroupnamespacerole"."organization_id", "projectgroupnamespacerole"."partner_id", "projectgroupnamespacerole"."role_id", "projectgroupnamespacerole"."group_id", "projectgroupnamespacerole"."project_id", "projectgroupnamespacerole"."namespace", "projectgroupnamespacerole"."active" FROM "authsrv_projectgroupnamespacerole" AS "projectgroupnamespacerole" JOIN authsrv_groupaccount ON projectgroupnamespacerole.group_id=authsrv_groupaccount.group_id WHERE \(project_id = '+` + puuid.String() + `+'\) AND \(authsrv_groupaccount.account_id = '` + uuuid.String() + `'\) AND \(projectgroupnamespacerole.trash = FALSE\) AND \(authsrv_groupaccount.trash = FALSE\)`).
|
|
WithArgs().WillReturnRows(sqlmock.NewRows([]string{"namespace"}).AddRow("namespace1"))
|
|
|
|
ns := NewNamespaceService(db)
|
|
nl, err := ns.GetGroupProjectNamespaces(context.Background(), puuid, uuuid)
|
|
if err != nil {
|
|
t.Fatal("unable to get namespaces", err)
|
|
}
|
|
if len(nl) != 1 {
|
|
t.Errorf("incorrect number of namespaces; expected '%v', got '%v'", 1, len(nl))
|
|
}
|
|
if nl[0] != "namespace1" {
|
|
t.Errorf("incorrect namespace name; expected '%v', got '%v'", "namespace1", nl[0])
|
|
}
|
|
}
|