Skip to content
Snippets Groups Projects
Select Git revision
  • 5f90f484aa1a95304101b48f5716183b9e2ae574
  • master default protected
  • 3.0
  • develop
  • revert-2069-tripleVersion
  • 3.1
  • rest-protocol
  • feat/remoting_rocketmq
  • dapr-support
  • 1.5
  • 1.4
  • 1.3
  • 1.2
  • 1.1
  • v3.0.3-rc2
  • v3.0.3-rc1
  • v3.0.2
  • v1.5.8
  • v1.5.9-rc1
  • v3.0.1
  • v1.5.8-rc1
  • v3.0.0
  • v3.0.0-rc4-1
  • v3.0.0-rc4
  • v3.0.0-rc3
  • v1.5.7
  • v1.5.7-rc2
  • v3.0.0-rc2
  • remove
  • v1.5.7-rc1
  • v3.0.0-rc1
  • v1.5.7-rc1-tmp
  • 1.5.6
  • v1.5.6
34 results

registry_aware_cluster_test.go

Blame
  • registry_aware_cluster_test.go 2.27 KiB
    /*
     * 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 cluster_impl
    
    import (
    	"context"
    	"fmt"
    	"testing"
    )
    import (
    	"github.com/stretchr/testify/assert"
    )
    
    import (
    	"github.com/apache/dubbo-go/cluster/directory"
    	"github.com/apache/dubbo-go/common"
    	"github.com/apache/dubbo-go/protocol"
    	"github.com/apache/dubbo-go/protocol/invocation"
    )
    
    func Test_RegAwareInvokeSuccess(t *testing.T) {
    
    	regAwareCluster := NewRegistryAwareCluster()
    
    	invokers := []protocol.Invoker{}
    	for i := 0; i < 10; i++ {
    		url, _ := common.NewURL(fmt.Sprintf("dubbo://192.168.1.%v:20000/com.ikurento.user.UserProvider", i))
    		invokers = append(invokers, NewMockInvoker(url, 1))
    	}
    
    	staticDir := directory.NewStaticDirectory(invokers)
    	clusterInvoker := regAwareCluster.Join(staticDir)
    	result := clusterInvoker.Invoke(context.Background(), &invocation.RPCInvocation{})
    	assert.NoError(t, result.Error())
    	count = 0
    }
    
    func TestDestroy(t *testing.T) {
    	regAwareCluster := NewRegistryAwareCluster()
    
    	invokers := []protocol.Invoker{}
    	for i := 0; i < 10; i++ {
    		url, _ := common.NewURL(fmt.Sprintf("dubbo://192.168.1.%v:20000/com.ikurento.user.UserProvider", i))
    		invokers = append(invokers, NewMockInvoker(url, 1))
    	}
    
    	staticDir := directory.NewStaticDirectory(invokers)
    	clusterInvoker := regAwareCluster.Join(staticDir)
    	assert.Equal(t, true, clusterInvoker.IsAvailable())
    	result := clusterInvoker.Invoke(context.Background(), &invocation.RPCInvocation{})
    	assert.NoError(t, result.Error())
    	count = 0
    	clusterInvoker.Destroy()
    	assert.Equal(t, false, clusterInvoker.IsAvailable())
    
    }