blob: 5e373e212f3de2670361068c85c925049c8ed299 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package datasource_test
import (
"context"
"strconv"
"strings"
"testing"
"time"
quotasvc "github.com/apache/servicecomb-service-center/server/service/quota"
"github.com/go-chassis/cari/pkg/errsvc"
"github.com/apache/servicecomb-service-center/datasource"
"github.com/apache/servicecomb-service-center/pkg/log"
"github.com/apache/servicecomb-service-center/pkg/util"
pb "github.com/go-chassis/cari/discovery"
"github.com/stretchr/testify/assert"
)
func TestService_Register(t *testing.T) {
ctx := getContext()
t.Run("Register service after init & install, should pass", func(t *testing.T) {
size := int(quotasvc.SchemaQuota()) + 1
paths := make([]*pb.ServicePath, 0, size)
properties := make(map[string]string, size)
for i := 0; i < size; i++ {
s := strconv.Itoa(i) + strings.Repeat("x", 253)
paths = append(paths, &pb.ServicePath{Path: s, Property: map[string]string{s: s}})
properties[s] = s
}
request := &pb.CreateServiceRequest{
Service: &pb.MicroService{
AppId: "service-ms-appID",
ServiceName: "service-ms-serviceName",
Version: "32767.32767.32767.32767",
Alias: "service-ms-alias",
Level: "BACK",
Status: "UP",
Schemas: []string{"service-ms-schema"},
Paths: paths,
Properties: properties,
Framework: &pb.FrameWork{
Name: "service-ms-frameworkName",
Version: "service-ms-frameworkVersion",
},
RegisterBy: "SDK",
Timestamp: strconv.FormatInt(time.Now().Unix(), 10),
},
}
request.Service.ModTimestamp = request.Service.Timestamp
resp, err := datasource.GetMetadataManager().RegisterService(ctx, request)
assert.NotNil(t, resp)
assert.NoError(t, err)
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: resp.ServiceId, Force: true})
})
t.Run("register service with same key", func(t *testing.T) {
resp, err := datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceName: "some-relay-ms-service-name",
Alias: "sr-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: resp.ServiceId, Force: true})
sameId := resp.ServiceId
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceName: "some-relay-ms-service-name",
Alias: "sr1-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
assert.Equal(t, sameId, resp.ServiceId)
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceName: "some-relay1-ms-service-name",
Alias: "sr-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
assert.Equal(t, sameId, resp.ServiceId)
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: sameId,
ServiceName: "some-relay1-ms-service-name",
Alias: "sr-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
assert.Equal(t, sameId, resp.ServiceId)
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: sameId,
ServiceName: "some-relay-ms-service-name",
Alias: "sr1-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
assert.Equal(t, sameId, resp.ServiceId)
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: "custom-id-ms-service-id",
ServiceName: "some-relay1-ms-service-name",
Alias: "sr1-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
assert.NotEqual(t, sameId, resp.ServiceId)
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: "custom-id-ms-service-id", Force: true})
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: "custom-id-ms-service-id",
ServiceName: "some-relay-ms-service-name",
Alias: "sr-ms-service-name",
AppId: "default",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
testErr := err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceAlreadyExists, testErr.Code)
})
t.Run("same serviceId,different service, can not register again, error is same as the service register twice", func(t *testing.T) {
resp, err := datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: "same-serviceId-service-ms",
ServiceName: "serviceA-service-ms",
AppId: "default-service-ms",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
assert.NotNil(t, resp)
assert.NoError(t, err)
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: resp.ServiceId, Force: true})
// same serviceId with different service name
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: "same-serviceId-service-ms",
ServiceName: "serviceB-service-ms",
AppId: "default-service-ms",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"xxxxxxxx",
},
Status: "UP",
},
})
testErr := err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceAlreadyExists, testErr.Code)
})
}
func TestService_Get(t *testing.T) {
ctx := getContext()
// get service test
t.Run("query all services, should pass", func(t *testing.T) {
resp, err := datasource.GetMetadataManager().ListService(ctx, &pb.GetServicesRequest{})
assert.NoError(t, err)
assert.Greater(t, len(resp.Services), 0)
})
t.Run("get a exist service, should pass", func(t *testing.T) {
request := &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceId: "ms-service-query-id",
ServiceName: "ms-service-query",
AppId: "default",
Version: "1.0.4",
Level: "BACK",
Properties: make(map[string]string),
},
}
resp, err := datasource.GetMetadataManager().RegisterService(ctx, request)
assert.NoError(t, err)
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: resp.ServiceId, Force: true})
// search service by serviceID
_, err = datasource.GetMetadataManager().GetService(ctx, &pb.GetServiceRequest{
ServiceId: "ms-service-query-id",
})
assert.NoError(t, err)
})
t.Run("query a service by a not existed serviceId, should not pass", func(t *testing.T) {
// not exist service
_, err := datasource.GetMetadataManager().GetService(ctx, &pb.GetServiceRequest{
ServiceId: "no-exist-service",
})
assert.NotNil(t, err)
assert.Equal(t, pb.ErrServiceNotExists, err.(*errsvc.Error).Code)
})
}
func TestService_Exist(t *testing.T) {
var (
serviceId1 string
serviceId2 string
)
ctx := getContext()
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: serviceId1, Force: true})
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: serviceId2, Force: true})
t.Run("create service", func(t *testing.T) {
svc := &pb.MicroService{
Alias: "es_service_ms",
ServiceName: "exist_service_service_ms",
AppId: "exist_appId_service_ms",
Version: "1.0.0",
Level: "FRONT",
Schemas: []string{
"first_schemaId_service_ms",
},
Status: "UP",
}
resp, err := datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: svc,
})
assert.NoError(t, err)
assert.NotEqual(t, "", resp.ServiceId)
serviceId1 = resp.ServiceId
svc.ServiceId = ""
svc.Environment = pb.ENV_PROD
resp, err = datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: svc,
})
assert.NoError(t, err)
assert.NotEqual(t, "", resp.ServiceId)
serviceId2 = resp.ServiceId
})
t.Run("check exist when service does not exist", func(t *testing.T) {
log.Info("check by querying a not exist serviceName")
_, err := datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
AppId: "exist_appId",
ServiceName: "notExistService_service_ms",
Version: "1.0.0",
})
testErr := err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceNotExists, testErr.Code)
log.Info("check by querying a not exist env")
_, err = datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
Environment: pb.ENV_TEST,
AppId: "exist_appId_service_ms",
ServiceName: "exist_service_service_ms",
Version: "1.0.0",
})
testErr = err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceNotExists, testErr.Code)
log.Info("check by querying a not exist env with alias")
_, err = datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
Environment: pb.ENV_TEST,
AppId: "exist_appId_service_ms",
ServiceName: "es_service_ms",
Version: "1.0.0",
})
testErr = err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceNotExists, testErr.Code)
log.Info("check by querying with a mismatching version")
_, err = datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
AppId: "exist_appId_service_ms",
ServiceName: "exist_service_service_ms",
Version: "2.0.0",
})
testErr = err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceVersionNotExists, testErr.Code)
})
t.Run("check exist when service exists", func(t *testing.T) {
log.Info("search with serviceName")
serviceID, err := datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
AppId: "exist_appId_service_ms",
ServiceName: "exist_service_service_ms",
Version: "1.0.0",
})
assert.NoError(t, err)
assert.Equal(t, serviceId1, serviceID)
log.Info("check with serviceName and env")
serviceID, err = datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
Environment: pb.ENV_PROD,
AppId: "exist_appId_service_ms",
ServiceName: "exist_service_service_ms",
Version: "1.0.0",
})
assert.NoError(t, err)
assert.Equal(t, serviceId2, serviceID)
log.Info("check with alias")
serviceID, err = datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
AppId: "exist_appId_service_ms",
ServiceName: "es_service_ms",
Version: "1.0.0",
})
assert.NoError(t, err)
assert.Equal(t, serviceId1, serviceID)
log.Info("check with alias and env")
serviceID, err = datasource.GetMetadataManager().ExistService(ctx, &pb.GetExistenceRequest{
Type: datasource.ExistTypeMicroservice,
Environment: pb.ENV_PROD,
AppId: "exist_appId_service_ms",
ServiceName: "es_service_ms",
Version: "1.0.0",
})
assert.NoError(t, err)
assert.Equal(t, serviceId2, serviceID)
})
}
func TestService_Update(t *testing.T) {
var serviceId string
ctx := getContext()
defer datasource.GetMetadataManager().UnregisterService(ctx, &pb.DeleteServiceRequest{ServiceId: serviceId, Force: true})
t.Run("create service", func(t *testing.T) {
resp, err := datasource.GetMetadataManager().RegisterService(ctx, &pb.CreateServiceRequest{
Service: &pb.MicroService{
Alias: "es_service_ms",
ServiceName: "update_prop_service_service_ms",
AppId: "update_prop_appId_service_ms",
Version: "1.0.0",
Level: "FRONT",
Status: "UP",
},
})
assert.NoError(t, err)
assert.NotNil(t, resp)
assert.NotEqual(t, "", resp.ServiceId)
serviceId = resp.ServiceId
})
t.Run("update properties while properties not nil", func(t *testing.T) {
log.Info("shuold pass")
request := &pb.UpdateServicePropsRequest{
ServiceId: serviceId,
Properties: make(map[string]string),
}
request2 := &pb.UpdateServicePropsRequest{
ServiceId: serviceId,
Properties: make(map[string]string),
}
request.Properties["test"] = "1"
request2.Properties["k"] = "v"
err := datasource.GetMetadataManager().PutServiceProperties(ctx, request)
assert.NoError(t, err)
err = datasource.GetMetadataManager().PutServiceProperties(ctx, request2)
assert.NoError(t, err)
service, err := datasource.GetMetadataManager().GetService(ctx, &pb.GetServiceRequest{
ServiceId: serviceId,
})
assert.NoError(t, err)
assert.Equal(t, serviceId, service.ServiceId)
assert.Equal(t, "", service.Properties["test"])
assert.Equal(t, "v", service.Properties["k"])
})
t.Run("update service that does not exist", func(t *testing.T) {
log.Info("it should be failed")
r := &pb.UpdateServicePropsRequest{
ServiceId: "not_exist_service_service_ms",
Properties: make(map[string]string),
}
err := datasource.GetMetadataManager().PutServiceProperties(ctx, r)
testErr := err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceNotExists, testErr.Code)
})
t.Run("update service by removing the properties", func(t *testing.T) {
log.Info("it should pass")
r := &pb.UpdateServicePropsRequest{
ServiceId: serviceId,
Properties: nil,
}
err := datasource.GetMetadataManager().PutServiceProperties(ctx, r)
assert.NoError(t, err)
log.Info("remove properties for service with empty serviceId")
r = &pb.UpdateServicePropsRequest{
ServiceId: "",
Properties: map[string]string{},
}
err = datasource.GetMetadataManager().PutServiceProperties(ctx, r)
testErr := err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrServiceNotExists, testErr.Code)
})
}
func TestService_Delete(t *testing.T) {
var (
serviceContainInstId string
serviceNoInstId string
)
t.Run("create service & instance", func(t *testing.T) {
respCreate, err := datasource.GetMetadataManager().RegisterService(getContext(), &pb.CreateServiceRequest{
Service: &pb.MicroService{
ServiceName: "delete_service_with_inst_ms",
AppId: "delete_service_ms",
Version: "1.0.0",
Level: "FRONT",
Status: "UP",
},
})
assert.NoError(t, err)
serviceContainInstId = respCreate.ServiceId
log.Info("attach instance")
instance := &pb.MicroServiceInstance{
ServiceId: serviceContainInstId,
Endpoints: []string{
"deleteService:127.0.0.1:8080",
},
HostName: "delete-host-ms",
Status: pb.MSI_UP,
}
_, err = datasource.GetMetadataManager().RegisterInstance(getContext(), &pb.RegisterInstanceRequest{
Instance: instance,
})
assert.NoError(t, err)
log.Info("create service without instance")
provider := &pb.MicroService{
ServiceName: "delete_service_no_inst_ms",
AppId: "delete_service_ms",
Version: "1.0.0",
Level: "FRONT",
Status: "UP",
}
respCreate, err = datasource.GetMetadataManager().RegisterService(getContext(), &pb.CreateServiceRequest{
Service: provider,
})
assert.NoError(t, err)
serviceNoInstId = respCreate.ServiceId
})
t.Run("delete a service which contains instances with no force flag", func(t *testing.T) {
err := datasource.GetMetadataManager().UnregisterService(getContext(), &pb.DeleteServiceRequest{
ServiceId: serviceContainInstId,
Force: false,
})
testErr := err.(*errsvc.Error)
assert.Error(t, testErr)
assert.Equal(t, pb.ErrDeployedInstance, testErr.Code)
})
t.Run("delete a service which contains instances with force flag", func(t *testing.T) {
log.Info("should pass")
err := datasource.GetMetadataManager().UnregisterService(getContext(), &pb.DeleteServiceRequest{
ServiceId: serviceContainInstId,
Force: true,
})
assert.NoError(t, err)
})
t.Run("delete a service which depended by consumer with force flag", func(t *testing.T) {
err := datasource.GetMetadataManager().UnregisterService(getContext(), &pb.DeleteServiceRequest{
ServiceId: serviceNoInstId,
Force: true,
})
assert.NoError(t, err)
})
}
func TestApplication_Get(t *testing.T) {
t.Run("execute 'get apps' operation", func(t *testing.T) {
log.Info("when request is valid, should be passed")
resp, err := datasource.GetMetadataManager().ListApp(getContext(), &pb.GetAppsRequest{})
assert.NoError(t, err)
assert.NotNil(t, resp)
resp, err = datasource.GetMetadataManager().ListApp(getContext(), &pb.GetAppsRequest{
Environment: pb.ENV_ACCEPT,
})
assert.NoError(t, err)
assert.NotNil(t, resp)
})
}
func getContext() context.Context {
return util.WithNoCache(util.SetDomainProject(context.Background(), "default", "default"))
}