mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-07 12:37:41 +00:00
8d97363642
Improve integration tests: - spliting the tests in TokenExchange to isolated instances and in parallel - corrected some test structure so that the check for Details is no done anymore if the test already failed - replace required-calls with assert-calls to not stop the testing - add gofakeit for application, project and usernames(emails) - add eventually checks for testing in actions v2, so the request only get called when the execution is defined - check for length of results in list/search endpoints to avoid index errors
114 lines
2.4 KiB
Go
114 lines
2.4 KiB
Go
//go:build integration
|
|
|
|
package system_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/zitadel/zitadel/internal/integration"
|
|
"github.com/zitadel/zitadel/pkg/grpc/instance"
|
|
"github.com/zitadel/zitadel/pkg/grpc/object"
|
|
system_pb "github.com/zitadel/zitadel/pkg/grpc/system"
|
|
)
|
|
|
|
func TestServer_ListInstances(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
isoInstance := integration.NewInstance(CTX)
|
|
|
|
tests := []struct {
|
|
name string
|
|
req *system_pb.ListInstancesRequest
|
|
want []*instance.Instance
|
|
wantErr bool
|
|
}{
|
|
{
|
|
name: "empty query error",
|
|
req: &system_pb.ListInstancesRequest{
|
|
Queries: []*instance.Query{{}},
|
|
},
|
|
wantErr: true,
|
|
},
|
|
{
|
|
name: "non-existing id",
|
|
req: &system_pb.ListInstancesRequest{
|
|
Queries: []*instance.Query{{
|
|
Query: &instance.Query_IdQuery{
|
|
IdQuery: &instance.IdsQuery{
|
|
Ids: []string{"foo"},
|
|
},
|
|
},
|
|
}},
|
|
},
|
|
want: []*instance.Instance{},
|
|
},
|
|
{
|
|
name: "get 1 by id",
|
|
req: &system_pb.ListInstancesRequest{
|
|
Query: &object.ListQuery{
|
|
Limit: 1,
|
|
},
|
|
Queries: []*instance.Query{{
|
|
Query: &instance.Query_IdQuery{
|
|
IdQuery: &instance.IdsQuery{
|
|
Ids: []string{isoInstance.ID()},
|
|
},
|
|
},
|
|
}},
|
|
},
|
|
want: []*instance.Instance{{
|
|
Id: isoInstance.ID(),
|
|
}},
|
|
},
|
|
{
|
|
name: "non-existing domain",
|
|
req: &system_pb.ListInstancesRequest{
|
|
Queries: []*instance.Query{{
|
|
Query: &instance.Query_DomainQuery{
|
|
DomainQuery: &instance.DomainsQuery{
|
|
Domains: []string{"foo"},
|
|
},
|
|
},
|
|
}},
|
|
},
|
|
want: []*instance.Instance{},
|
|
},
|
|
{
|
|
name: "get 1 by domain",
|
|
req: &system_pb.ListInstancesRequest{
|
|
Query: &object.ListQuery{
|
|
Limit: 1,
|
|
},
|
|
Queries: []*instance.Query{{
|
|
Query: &instance.Query_DomainQuery{
|
|
DomainQuery: &instance.DomainsQuery{
|
|
Domains: []string{isoInstance.Domain},
|
|
},
|
|
},
|
|
}},
|
|
},
|
|
want: []*instance.Instance{{
|
|
Id: isoInstance.ID(),
|
|
}},
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
resp, err := integration.SystemClient().ListInstances(CTX, tt.req)
|
|
if tt.wantErr {
|
|
require.Error(t, err)
|
|
return
|
|
}
|
|
require.NoError(t, err)
|
|
got := resp.GetResult()
|
|
require.Len(t, got, len(tt.want))
|
|
for i := 0; i < len(tt.want); i++ {
|
|
assert.Equalf(t, tt.want[i].GetId(), got[i].GetId(), "instance[%d] id", i)
|
|
}
|
|
})
|
|
}
|
|
}
|