2024-01-15 07:00:08 +00:00
|
|
|
package domain_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"slices"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"gitea.dwysokinski.me/twhelp/corev3/internal/domain"
|
|
|
|
"gitea.dwysokinski.me/twhelp/corev3/internal/domain/domaintest"
|
2024-03-16 07:19:30 +00:00
|
|
|
"github.com/brianvoe/gofakeit/v7"
|
2024-01-15 07:00:08 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewCreateTribeSnapshotParams(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
tribes := domain.Tribes{
|
|
|
|
domaintest.NewTribe(t),
|
|
|
|
domaintest.NewTribe(t),
|
|
|
|
domaintest.NewTribe(t),
|
|
|
|
}
|
|
|
|
date := time.Now()
|
|
|
|
|
|
|
|
res, err := domain.NewCreateTribeSnapshotParams(tribes, date)
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Len(t, res, len(tribes))
|
|
|
|
for i, tr := range tribes {
|
|
|
|
idx := slices.IndexFunc(res, func(params domain.CreateTribeSnapshotParams) bool {
|
|
|
|
return params.TribeID() == tr.ID() && params.ServerKey() == tr.ServerKey()
|
|
|
|
})
|
|
|
|
require.GreaterOrEqualf(t, idx, 0, "tribes[%d] not found", i)
|
|
|
|
|
|
|
|
params := res[i]
|
|
|
|
|
|
|
|
assert.Equalf(t, tr.ID(), params.TribeID(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.ServerKey(), params.ServerKey(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.NumMembers(), params.NumMembers(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.NumVillages(), params.NumVillages(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.Points(), params.Points(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.AllPoints(), params.AllPoints(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.Rank(), params.Rank(), "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, tr.OD(), params.OD(), "tribes[%d]", i)
|
|
|
|
assert.InDeltaf(t, tr.Dominance(), params.Dominance(), 0.001, "tribes[%d]", i)
|
|
|
|
assert.Equalf(t, date, params.Date(), "tribes[%d]", i)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-02 08:49:42 +00:00
|
|
|
func TestTribeSnapshotSort_IsInConflict(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
type args struct {
|
|
|
|
sorts [2]domain.TribeSnapshotSort
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedRes bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "OK: id:ASC serverKey:ASC",
|
|
|
|
args: args{
|
|
|
|
sorts: [2]domain.TribeSnapshotSort{domain.TribeSnapshotSortIDASC, domain.TribeSnapshotSortServerKeyASC},
|
|
|
|
},
|
|
|
|
expectedRes: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "OK: id:DESC serverKey:ASC",
|
|
|
|
args: args{
|
|
|
|
sorts: [2]domain.TribeSnapshotSort{domain.TribeSnapshotSortIDDESC, domain.TribeSnapshotSortServerKeyASC},
|
|
|
|
},
|
|
|
|
expectedRes: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "OK: id:ASC id:ASC",
|
|
|
|
args: args{
|
|
|
|
sorts: [2]domain.TribeSnapshotSort{domain.TribeSnapshotSortIDASC, domain.TribeSnapshotSortIDASC},
|
|
|
|
},
|
|
|
|
expectedRes: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "OK: id:ASC id:DESC",
|
|
|
|
args: args{
|
|
|
|
sorts: [2]domain.TribeSnapshotSort{domain.TribeSnapshotSortIDASC, domain.TribeSnapshotSortIDDESC},
|
|
|
|
},
|
|
|
|
expectedRes: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "OK: date:ASC date:DESC",
|
|
|
|
args: args{
|
|
|
|
sorts: [2]domain.TribeSnapshotSort{domain.TribeSnapshotSortDateASC, domain.TribeSnapshotSortDateDESC},
|
|
|
|
},
|
|
|
|
expectedRes: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "OK: serverKey:DESC serverKey:ASC",
|
|
|
|
args: args{
|
|
|
|
sorts: [2]domain.TribeSnapshotSort{domain.TribeSnapshotSortServerKeyDESC, domain.TribeSnapshotSortServerKeyASC},
|
|
|
|
},
|
|
|
|
expectedRes: true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
assert.Equal(t, tt.expectedRes, tt.args.sorts[0].IsInConflict(tt.args.sorts[1]))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
func TestNewTribeSnapshotCursor(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
validTribeSnapshotCursor := domaintest.NewTribeSnapshotCursor(t)
|
|
|
|
|
|
|
|
type args struct {
|
|
|
|
id int
|
|
|
|
serverKey string
|
|
|
|
date time.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
type test struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedErr error
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []test{
|
|
|
|
{
|
|
|
|
name: "OK",
|
|
|
|
args: args{
|
|
|
|
id: validTribeSnapshotCursor.ID(),
|
|
|
|
serverKey: validTribeSnapshotCursor.ServerKey(),
|
|
|
|
date: validTribeSnapshotCursor.Date(),
|
|
|
|
},
|
|
|
|
expectedErr: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: id < 1",
|
|
|
|
args: args{
|
|
|
|
id: 0,
|
|
|
|
serverKey: validTribeSnapshotCursor.ServerKey(),
|
|
|
|
date: validTribeSnapshotCursor.Date(),
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "TribeSnapshotCursor",
|
|
|
|
Field: "id",
|
|
|
|
Err: domain.MinGreaterEqualError{
|
|
|
|
Min: 1,
|
|
|
|
Current: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, serverKeyTest := range newServerKeyValidationTests() {
|
|
|
|
tests = append(tests, test{
|
|
|
|
name: serverKeyTest.name,
|
|
|
|
args: args{
|
|
|
|
id: validTribeSnapshotCursor.ID(),
|
|
|
|
serverKey: serverKeyTest.key,
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "TribeSnapshotCursor",
|
|
|
|
Field: "serverKey",
|
|
|
|
Err: serverKeyTest.expectedErr,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
psc, err := domain.NewTribeSnapshotCursor(
|
|
|
|
tt.args.id,
|
|
|
|
tt.args.serverKey,
|
|
|
|
tt.args.date,
|
|
|
|
)
|
|
|
|
require.ErrorIs(t, err, tt.expectedErr)
|
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.Equal(t, tt.args.id, psc.ID())
|
|
|
|
assert.Equal(t, tt.args.serverKey, psc.ServerKey())
|
|
|
|
assert.Equal(t, tt.args.date, psc.Date())
|
|
|
|
assert.NotEmpty(t, psc.Encode())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-03 06:23:46 +00:00
|
|
|
func TestListTribeSnapshotsParams_SetServerKeys(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
type args struct {
|
|
|
|
serverKeys []string
|
|
|
|
}
|
|
|
|
|
|
|
|
type test struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedErr error
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []test{
|
|
|
|
{
|
|
|
|
name: "OK",
|
|
|
|
args: args{
|
|
|
|
serverKeys: []string{
|
|
|
|
domaintest.RandServerKey(),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, serverKeyTest := range newServerKeyValidationTests() {
|
|
|
|
tests = append(tests, test{
|
|
|
|
name: serverKeyTest.name,
|
|
|
|
args: args{
|
|
|
|
serverKeys: []string{serverKeyTest.key},
|
|
|
|
},
|
|
|
|
expectedErr: domain.SliceElementValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "serverKeys",
|
|
|
|
Index: 0,
|
|
|
|
Err: serverKeyTest.expectedErr,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
params := domain.NewListTribeSnapshotsParams()
|
|
|
|
|
|
|
|
require.ErrorIs(t, params.SetServerKeys(tt.args.serverKeys), tt.expectedErr)
|
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.Equal(t, tt.args.serverKeys, params.ServerKeys())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
func TestListTribeSnapshotsParams_SetTribeIDs(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
type args struct {
|
|
|
|
tribeIDs []int
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedErr error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "OK",
|
|
|
|
args: args{
|
|
|
|
tribeIDs: []int{
|
|
|
|
domaintest.RandID(),
|
|
|
|
domaintest.RandID(),
|
|
|
|
domaintest.RandID(),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: value < 1",
|
|
|
|
args: args{
|
|
|
|
tribeIDs: []int{
|
|
|
|
domaintest.RandID(),
|
|
|
|
domaintest.RandID(),
|
|
|
|
domaintest.RandID(),
|
|
|
|
0,
|
|
|
|
domaintest.RandID(),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedErr: domain.SliceElementValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "tribeIDs",
|
|
|
|
Index: 3,
|
|
|
|
Err: domain.MinGreaterEqualError{
|
|
|
|
Min: 1,
|
|
|
|
Current: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
params := domain.NewListTribeSnapshotsParams()
|
|
|
|
|
|
|
|
require.ErrorIs(t, params.SetTribeIDs(tt.args.tribeIDs), tt.expectedErr)
|
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.Equal(t, tt.args.tribeIDs, params.TribeIDs())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 07:00:08 +00:00
|
|
|
func TestListTribeSnapshotsParams_SetSort(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
type args struct {
|
|
|
|
sort []domain.TribeSnapshotSort
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedErr error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "OK",
|
|
|
|
args: args{
|
|
|
|
sort: []domain.TribeSnapshotSort{
|
|
|
|
domain.TribeSnapshotSortDateASC,
|
|
|
|
domain.TribeSnapshotSortServerKeyASC,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: len(sort) < 1",
|
|
|
|
args: args{
|
|
|
|
sort: nil,
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Err: domain.LenOutOfRangeError{
|
|
|
|
Min: 1,
|
|
|
|
Max: 3,
|
|
|
|
Current: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: len(sort) > 3",
|
|
|
|
args: args{
|
|
|
|
sort: []domain.TribeSnapshotSort{
|
|
|
|
domain.TribeSnapshotSortDateASC,
|
|
|
|
domain.TribeSnapshotSortServerKeyASC,
|
|
|
|
domain.TribeSnapshotSortIDASC,
|
|
|
|
domain.TribeSnapshotSortIDDESC,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Err: domain.LenOutOfRangeError{
|
|
|
|
Min: 1,
|
|
|
|
Max: 3,
|
|
|
|
Current: 4,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-03-02 08:49:42 +00:00
|
|
|
{
|
|
|
|
name: "ERR: conflict",
|
|
|
|
args: args{
|
|
|
|
sort: []domain.TribeSnapshotSort{
|
|
|
|
domain.TribeSnapshotSortIDASC,
|
|
|
|
domain.TribeSnapshotSortIDDESC,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Err: domain.SortConflictError{
|
|
|
|
Sort: [2]string{domain.TribeSnapshotSortIDASC.String(), domain.TribeSnapshotSortIDDESC.String()},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-01-15 07:00:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
params := domain.NewListTribeSnapshotsParams()
|
|
|
|
|
|
|
|
require.ErrorIs(t, params.SetSort(tt.args.sort), tt.expectedErr)
|
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.Equal(t, tt.args.sort, params.Sort())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-19 06:10:28 +00:00
|
|
|
func TestListTribeSnapshotsParams_PrependSortString(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
defaultNewParams := func(t *testing.T) domain.ListTribeSnapshotsParams {
|
|
|
|
t.Helper()
|
|
|
|
return domain.ListTribeSnapshotsParams{}
|
|
|
|
}
|
|
|
|
|
|
|
|
type args struct {
|
|
|
|
sort []string
|
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
newParams func(t *testing.T) domain.ListTribeSnapshotsParams
|
|
|
|
args args
|
|
|
|
expectedSort []domain.TribeSnapshotSort
|
|
|
|
expectedErr error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "OK: [date:ASC]",
|
|
|
|
args: args{
|
|
|
|
sort: []string{
|
|
|
|
"date:ASC",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedSort: []domain.TribeSnapshotSort{
|
|
|
|
domain.TribeSnapshotSortDateASC,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "OK: [date:DESC]",
|
|
|
|
args: args{
|
|
|
|
sort: []string{
|
|
|
|
"date:DESC",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedSort: []domain.TribeSnapshotSort{
|
|
|
|
domain.TribeSnapshotSortDateDESC,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: len(sort) < 1",
|
|
|
|
args: args{
|
|
|
|
sort: nil,
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Err: domain.LenOutOfRangeError{
|
|
|
|
Min: 1,
|
|
|
|
Max: 3,
|
|
|
|
Current: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: custom params + len(sort) > 1",
|
|
|
|
newParams: func(t *testing.T) domain.ListTribeSnapshotsParams {
|
|
|
|
t.Helper()
|
|
|
|
params := domain.NewListTribeSnapshotsParams()
|
|
|
|
require.NoError(t, params.SetSort([]domain.TribeSnapshotSort{
|
|
|
|
domain.TribeSnapshotSortServerKeyASC,
|
|
|
|
domain.TribeSnapshotSortIDASC,
|
|
|
|
}))
|
|
|
|
return params
|
|
|
|
},
|
|
|
|
args: args{
|
|
|
|
sort: []string{
|
|
|
|
"date:ASC",
|
|
|
|
"date:DESC",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Err: domain.LenOutOfRangeError{
|
|
|
|
Min: 1,
|
|
|
|
Max: 1,
|
|
|
|
Current: 2,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: unsupported sort string",
|
|
|
|
newParams: defaultNewParams,
|
|
|
|
args: args{
|
|
|
|
sort: []string{
|
|
|
|
"date:",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedErr: domain.SliceElementValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Index: 0,
|
|
|
|
Err: domain.UnsupportedSortStringError{
|
|
|
|
Sort: "date:",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "ERR: conflict",
|
|
|
|
args: args{
|
|
|
|
sort: []string{
|
|
|
|
"date:ASC",
|
|
|
|
"date:DESC",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "sort",
|
|
|
|
Err: domain.SortConflictError{
|
|
|
|
Sort: [2]string{domain.TribeSnapshotSortDateASC.String(), domain.TribeSnapshotSortDateDESC.String()},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
newParams := defaultNewParams
|
|
|
|
if tt.newParams != nil {
|
|
|
|
newParams = tt.newParams
|
|
|
|
}
|
|
|
|
params := newParams(t)
|
|
|
|
|
|
|
|
require.ErrorIs(t, params.PrependSortString(tt.args.sort), tt.expectedErr)
|
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
assert.Equal(t, tt.expectedSort, params.Sort())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
func TestListTribeSnapshotsParams_SetEncodedCursor(t *testing.T) {
|
2024-01-15 07:00:08 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
validCursor := domaintest.NewTribeSnapshotCursor(t)
|
|
|
|
|
2024-01-15 07:00:08 +00:00
|
|
|
type args struct {
|
2024-03-16 07:19:30 +00:00
|
|
|
cursor string
|
2024-01-15 07:00:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
2024-03-16 07:19:30 +00:00
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedCursor domain.TribeSnapshotCursor
|
|
|
|
expectedErr error
|
2024-01-15 07:00:08 +00:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "OK",
|
|
|
|
args: args{
|
2024-03-16 07:19:30 +00:00
|
|
|
cursor: validCursor.Encode(),
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
2024-03-16 07:19:30 +00:00
|
|
|
expectedCursor: validCursor,
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
{
|
2024-03-16 07:19:30 +00:00
|
|
|
name: "ERR: len(cursor) < 1",
|
2024-01-15 07:00:08 +00:00
|
|
|
args: args{
|
2024-03-16 07:19:30 +00:00
|
|
|
cursor: "",
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
2024-03-16 07:19:30 +00:00
|
|
|
Field: "cursor",
|
|
|
|
Err: domain.LenOutOfRangeError{
|
2024-01-15 07:00:08 +00:00
|
|
|
Min: 1,
|
2024-03-16 07:19:30 +00:00
|
|
|
Max: 1000,
|
2024-01-15 07:00:08 +00:00
|
|
|
Current: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2024-03-16 07:19:30 +00:00
|
|
|
name: "ERR: len(cursor) > 1000",
|
2024-01-15 07:00:08 +00:00
|
|
|
args: args{
|
2024-03-16 07:19:30 +00:00
|
|
|
cursor: gofakeit.LetterN(1001),
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
2024-03-16 07:19:30 +00:00
|
|
|
Field: "cursor",
|
|
|
|
Err: domain.LenOutOfRangeError{
|
|
|
|
Min: 1,
|
|
|
|
Max: 1000,
|
|
|
|
Current: 1001,
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-03-16 07:19:30 +00:00
|
|
|
{
|
|
|
|
name: "ERR: malformed base64",
|
|
|
|
args: args{
|
|
|
|
cursor: "112345",
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "cursor",
|
|
|
|
Err: domain.ErrInvalidCursor,
|
|
|
|
},
|
|
|
|
},
|
2024-01-15 07:00:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
params := domain.NewListTribeSnapshotsParams()
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
require.ErrorIs(t, params.SetEncodedCursor(tt.args.cursor), tt.expectedErr)
|
2024-01-15 07:00:08 +00:00
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
2024-03-16 07:19:30 +00:00
|
|
|
assert.Equal(t, tt.args.cursor, params.Cursor().Encode())
|
2024-01-15 07:00:08 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
func TestListTribeSnapshotsParams_SetLimit(t *testing.T) {
|
2024-01-15 07:00:08 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
type args struct {
|
2024-03-16 07:19:30 +00:00
|
|
|
limit int
|
2024-01-15 07:00:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
expectedErr error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "OK",
|
|
|
|
args: args{
|
2024-03-16 07:19:30 +00:00
|
|
|
limit: domain.TribeSnapshotListMaxLimit,
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2024-03-16 07:19:30 +00:00
|
|
|
name: "ERR: limit < 1",
|
2024-01-15 07:00:08 +00:00
|
|
|
args: args{
|
2024-03-16 07:19:30 +00:00
|
|
|
limit: 0,
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
2024-03-16 07:19:30 +00:00
|
|
|
Field: "limit",
|
2024-01-15 07:00:08 +00:00
|
|
|
Err: domain.MinGreaterEqualError{
|
2024-03-16 07:19:30 +00:00
|
|
|
Min: 1,
|
|
|
|
Current: 0,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: fmt.Sprintf("ERR: limit > %d", domain.TribeSnapshotListMaxLimit),
|
|
|
|
args: args{
|
|
|
|
limit: domain.TribeSnapshotListMaxLimit + 1,
|
|
|
|
},
|
|
|
|
expectedErr: domain.ValidationError{
|
|
|
|
Model: "ListTribeSnapshotsParams",
|
|
|
|
Field: "limit",
|
|
|
|
Err: domain.MaxLessEqualError{
|
|
|
|
Max: domain.TribeSnapshotListMaxLimit,
|
|
|
|
Current: domain.TribeSnapshotListMaxLimit + 1,
|
2024-01-15 07:00:08 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
params := domain.NewListTribeSnapshotsParams()
|
|
|
|
|
2024-03-16 07:19:30 +00:00
|
|
|
require.ErrorIs(t, params.SetLimit(tt.args.limit), tt.expectedErr)
|
2024-01-15 07:00:08 +00:00
|
|
|
if tt.expectedErr != nil {
|
|
|
|
return
|
|
|
|
}
|
2024-03-16 07:19:30 +00:00
|
|
|
assert.Equal(t, tt.args.limit, params.Limit())
|
2024-01-15 07:00:08 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2024-03-16 07:19:30 +00:00
|
|
|
|
|
|
|
func TestNewListTribeSnapshotsResult(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
snapshots := domain.TribeSnapshots{
|
|
|
|
domaintest.NewTribeSnapshot(t),
|
|
|
|
domaintest.NewTribeSnapshot(t),
|
|
|
|
domaintest.NewTribeSnapshot(t),
|
|
|
|
}
|
|
|
|
next := domaintest.NewTribeSnapshot(t)
|
|
|
|
|
|
|
|
t.Run("OK: with next", func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
res, err := domain.NewListTribeSnapshotsResult(snapshots, next)
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, snapshots, res.TribeSnapshots())
|
|
|
|
assert.Equal(t, snapshots[0].ID(), res.Self().ID())
|
|
|
|
assert.Equal(t, snapshots[0].ServerKey(), res.Self().ServerKey())
|
|
|
|
assert.Equal(t, snapshots[0].Date(), res.Self().Date())
|
|
|
|
assert.Equal(t, next.ID(), res.Next().ID())
|
|
|
|
assert.Equal(t, next.ServerKey(), res.Next().ServerKey())
|
|
|
|
assert.Equal(t, next.Date(), res.Next().Date())
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("OK: without next", func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
res, err := domain.NewListTribeSnapshotsResult(snapshots, domain.TribeSnapshot{})
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, snapshots, res.TribeSnapshots())
|
|
|
|
assert.Equal(t, snapshots[0].ID(), res.Self().ID())
|
|
|
|
assert.Equal(t, snapshots[0].ServerKey(), res.Self().ServerKey())
|
|
|
|
assert.Equal(t, snapshots[0].Date(), res.Self().Date())
|
|
|
|
assert.True(t, res.Next().IsZero())
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("OK: 0 snapshots", func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
res, err := domain.NewListTribeSnapshotsResult(nil, domain.TribeSnapshot{})
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Zero(t, res.TribeSnapshots())
|
|
|
|
assert.True(t, res.Self().IsZero())
|
|
|
|
assert.True(t, res.Next().IsZero())
|
|
|
|
})
|
|
|
|
}
|
2024-03-19 06:01:38 +00:00
|
|
|
|
|
|
|
func TestNewListTribeSnapshotsWithRelationsResult(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
snapshots := domain.TribeSnapshotsWithRelations{
|
|
|
|
domaintest.NewTribeSnapshotWithRelations(t),
|
|
|
|
domaintest.NewTribeSnapshotWithRelations(t),
|
|
|
|
domaintest.NewTribeSnapshotWithRelations(t),
|
|
|
|
}
|
|
|
|
next := domaintest.NewTribeSnapshotWithRelations(t)
|
|
|
|
|
|
|
|
t.Run("OK: with next", func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
res, err := domain.NewListTribeSnapshotsWithRelationsResult(snapshots, next)
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, snapshots, res.TribeSnapshots())
|
|
|
|
assert.Equal(t, snapshots[0].TribeSnapshot().ID(), res.Self().ID())
|
|
|
|
assert.Equal(t, snapshots[0].TribeSnapshot().ServerKey(), res.Self().ServerKey())
|
|
|
|
assert.Equal(t, snapshots[0].TribeSnapshot().Date(), res.Self().Date())
|
|
|
|
assert.Equal(t, next.TribeSnapshot().ID(), res.Next().ID())
|
|
|
|
assert.Equal(t, next.TribeSnapshot().ServerKey(), res.Next().ServerKey())
|
|
|
|
assert.Equal(t, next.TribeSnapshot().Date(), res.Next().Date())
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("OK: without next", func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
res, err := domain.NewListTribeSnapshotsWithRelationsResult(snapshots, domain.TribeSnapshotWithRelations{})
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, snapshots, res.TribeSnapshots())
|
|
|
|
assert.Equal(t, snapshots[0].TribeSnapshot().ID(), res.Self().ID())
|
|
|
|
assert.Equal(t, snapshots[0].TribeSnapshot().ServerKey(), res.Self().ServerKey())
|
|
|
|
assert.Equal(t, snapshots[0].TribeSnapshot().Date(), res.Self().Date())
|
|
|
|
assert.True(t, res.Next().IsZero())
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("OK: 0 snapshots", func(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
res, err := domain.NewListTribeSnapshotsWithRelationsResult(nil, domain.TribeSnapshotWithRelations{})
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Zero(t, res.TribeSnapshots())
|
|
|
|
assert.True(t, res.Self().IsZero())
|
|
|
|
assert.True(t, res.Next().IsZero())
|
|
|
|
})
|
|
|
|
}
|