7422fe393b
This change modifies the projects.GetByUserID function to also fetch each project's member count. Change-Id: I5ef4aa3726566920ee9360f5a4f09a8cb490c67e
123 lines
3.4 KiB
Go
123 lines
3.4 KiB
Go
// Copyright (C) 2019 Storj Labs, Inc.
|
|
// See LICENSE for copying information.
|
|
|
|
package satellitedb_test
|
|
|
|
import (
|
|
"math/rand"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"storj.io/common/testcontext"
|
|
"storj.io/common/testrand"
|
|
"storj.io/common/uuid"
|
|
"storj.io/storj/satellite"
|
|
"storj.io/storj/satellite/console"
|
|
"storj.io/storj/satellite/satellitedb/satellitedbtest"
|
|
)
|
|
|
|
func TestProjectsGetByPublicID(t *testing.T) {
|
|
satellitedbtest.Run(t, func(ctx *testcontext.Context, t *testing.T, db satellite.DB) {
|
|
projects := db.Console().Projects()
|
|
|
|
prj, err := projects.Insert(ctx, &console.Project{
|
|
Name: "ProjectName",
|
|
Description: "projects description",
|
|
})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, prj)
|
|
|
|
pubID := prj.PublicID
|
|
require.NotNil(t, pubID)
|
|
require.False(t, pubID.IsZero())
|
|
|
|
prj, err = projects.GetByPublicID(ctx, pubID)
|
|
require.NoError(t, err)
|
|
require.Equal(t, pubID, prj.PublicID)
|
|
})
|
|
}
|
|
|
|
func TestProjectsGetSalt(t *testing.T) {
|
|
satellitedbtest.Run(t, func(ctx *testcontext.Context, t *testing.T, db satellite.DB) {
|
|
projects := db.Console().Projects()
|
|
|
|
prj, err := projects.Insert(ctx, &console.Project{
|
|
Name: "ProjectName",
|
|
Description: "projects description",
|
|
})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, prj)
|
|
|
|
salt, err := projects.GetSalt(ctx, prj.ID)
|
|
require.NoError(t, err)
|
|
|
|
_, err = uuid.FromBytes(salt)
|
|
require.NoError(t, err)
|
|
})
|
|
}
|
|
|
|
func TestUpdateProjectUsageLimits(t *testing.T) {
|
|
satellitedbtest.Run(t, func(ctx *testcontext.Context, t *testing.T, db satellite.DB) {
|
|
limits := console.UsageLimits{Storage: rand.Int63(), Bandwidth: rand.Int63(), Segment: rand.Int63()}
|
|
projectsRepo := db.Console().Projects()
|
|
|
|
proj, err := projectsRepo.Insert(ctx, &console.Project{})
|
|
require.NoError(t, err)
|
|
require.NotNil(t, proj)
|
|
|
|
err = projectsRepo.UpdateUsageLimits(ctx, proj.ID, limits)
|
|
require.NoError(t, err)
|
|
|
|
proj, err = projectsRepo.Get(ctx, proj.ID)
|
|
require.NoError(t, err)
|
|
require.Equal(t, limits.Bandwidth, proj.BandwidthLimit.Int64())
|
|
require.Equal(t, limits.Storage, proj.StorageLimit.Int64())
|
|
require.Equal(t, limits.Segment, *proj.SegmentLimit)
|
|
})
|
|
}
|
|
|
|
func TestGetProjectsByUserID(t *testing.T) {
|
|
satellitedbtest.Run(t, func(ctx *testcontext.Context, t *testing.T, db satellite.DB) {
|
|
projectsRepo := db.Console().Projects()
|
|
users := db.Console().Users()
|
|
projectMembers := db.Console().ProjectMembers()
|
|
|
|
user1, err := users.Insert(ctx, &console.User{
|
|
ID: testrand.UUID(),
|
|
Email: "user1@mail.test",
|
|
PasswordHash: []byte("password"),
|
|
})
|
|
require.NoError(t, err)
|
|
|
|
user2, err := users.Insert(ctx, &console.User{
|
|
ID: testrand.UUID(),
|
|
Email: "user2@mail.test",
|
|
PasswordHash: []byte("password"),
|
|
})
|
|
require.NoError(t, err)
|
|
|
|
proj, err := projectsRepo.Insert(ctx, &console.Project{
|
|
Name: "Project",
|
|
OwnerID: user1.ID,
|
|
})
|
|
require.NoError(t, err)
|
|
|
|
_, err = projectMembers.Insert(ctx, user1.ID, proj.ID)
|
|
require.NoError(t, err)
|
|
|
|
projects, err := projectsRepo.GetByUserID(ctx, user1.ID)
|
|
require.NoError(t, err)
|
|
require.Len(t, projects, 1)
|
|
require.Equal(t, 1, projects[0].MemberCount)
|
|
|
|
_, err = projectMembers.Insert(ctx, user2.ID, proj.ID)
|
|
require.NoError(t, err)
|
|
|
|
projects, err = projectsRepo.GetByUserID(ctx, user1.ID)
|
|
require.NoError(t, err)
|
|
require.Len(t, projects, 1)
|
|
require.Equal(t, 2, projects[0].MemberCount)
|
|
})
|
|
}
|