mirror of https://github.com/v2ray/v2ray-core
				
				
				
			
		
			
				
	
	
		
			198 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
| package router_test
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/golang/mock/gomock"
 | |
| 	. "v2ray.com/core/app/router"
 | |
| 	"v2ray.com/core/common"
 | |
| 	"v2ray.com/core/common/net"
 | |
| 	"v2ray.com/core/common/session"
 | |
| 	"v2ray.com/core/features/outbound"
 | |
| 	"v2ray.com/core/testing/mocks"
 | |
| )
 | |
| 
 | |
| type mockOutboundManager struct {
 | |
| 	outbound.Manager
 | |
| 	outbound.HandlerSelector
 | |
| }
 | |
| 
 | |
| func TestSimpleRouter(t *testing.T) {
 | |
| 	config := &Config{
 | |
| 		Rule: []*RoutingRule{
 | |
| 			{
 | |
| 				TargetTag: &RoutingRule_Tag{
 | |
| 					Tag: "test",
 | |
| 				},
 | |
| 				Networks: []net.Network{net.Network_TCP},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	mockCtl := gomock.NewController(t)
 | |
| 	defer mockCtl.Finish()
 | |
| 
 | |
| 	mockDns := mocks.NewDNSClient(mockCtl)
 | |
| 	mockOhm := mocks.NewOutboundManager(mockCtl)
 | |
| 	mockHs := mocks.NewOutboundHandlerSelector(mockCtl)
 | |
| 
 | |
| 	r := new(Router)
 | |
| 	common.Must(r.Init(config, mockDns, &mockOutboundManager{
 | |
| 		Manager:         mockOhm,
 | |
| 		HandlerSelector: mockHs,
 | |
| 	}))
 | |
| 
 | |
| 	ctx := session.ContextWithOutbound(context.Background(), &session.Outbound{Target: net.TCPDestination(net.DomainAddress("v2ray.com"), 80)})
 | |
| 	tag, err := r.PickRoute(ctx)
 | |
| 	common.Must(err)
 | |
| 	if tag != "test" {
 | |
| 		t.Error("expect tag 'test', bug actually ", tag)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestSimpleBalancer(t *testing.T) {
 | |
| 	config := &Config{
 | |
| 		Rule: []*RoutingRule{
 | |
| 			{
 | |
| 				TargetTag: &RoutingRule_BalancingTag{
 | |
| 					BalancingTag: "balance",
 | |
| 				},
 | |
| 				Networks: []net.Network{net.Network_TCP},
 | |
| 			},
 | |
| 		},
 | |
| 		BalancingRule: []*BalancingRule{
 | |
| 			{
 | |
| 				Tag:              "balance",
 | |
| 				OutboundSelector: []string{"test-"},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	mockCtl := gomock.NewController(t)
 | |
| 	defer mockCtl.Finish()
 | |
| 
 | |
| 	mockDns := mocks.NewDNSClient(mockCtl)
 | |
| 	mockOhm := mocks.NewOutboundManager(mockCtl)
 | |
| 	mockHs := mocks.NewOutboundHandlerSelector(mockCtl)
 | |
| 
 | |
| 	mockHs.EXPECT().Select(gomock.Eq([]string{"test-"})).Return([]string{"test"})
 | |
| 
 | |
| 	r := new(Router)
 | |
| 	common.Must(r.Init(config, mockDns, &mockOutboundManager{
 | |
| 		Manager:         mockOhm,
 | |
| 		HandlerSelector: mockHs,
 | |
| 	}))
 | |
| 
 | |
| 	ctx := session.ContextWithOutbound(context.Background(), &session.Outbound{Target: net.TCPDestination(net.DomainAddress("v2ray.com"), 80)})
 | |
| 	tag, err := r.PickRoute(ctx)
 | |
| 	common.Must(err)
 | |
| 	if tag != "test" {
 | |
| 		t.Error("expect tag 'test', bug actually ", tag)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestIPOnDemand(t *testing.T) {
 | |
| 	config := &Config{
 | |
| 		DomainStrategy: Config_IpOnDemand,
 | |
| 		Rule: []*RoutingRule{
 | |
| 			{
 | |
| 				TargetTag: &RoutingRule_Tag{
 | |
| 					Tag: "test",
 | |
| 				},
 | |
| 				Cidr: []*CIDR{
 | |
| 					{
 | |
| 						Ip:     []byte{192, 168, 0, 0},
 | |
| 						Prefix: 16,
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	mockCtl := gomock.NewController(t)
 | |
| 	defer mockCtl.Finish()
 | |
| 
 | |
| 	mockDns := mocks.NewDNSClient(mockCtl)
 | |
| 	mockDns.EXPECT().LookupIP(gomock.Eq("v2ray.com")).Return([]net.IP{{192, 168, 0, 1}}, nil).AnyTimes()
 | |
| 
 | |
| 	r := new(Router)
 | |
| 	common.Must(r.Init(config, mockDns, nil))
 | |
| 
 | |
| 	ctx := session.ContextWithOutbound(context.Background(), &session.Outbound{Target: net.TCPDestination(net.DomainAddress("v2ray.com"), 80)})
 | |
| 	tag, err := r.PickRoute(ctx)
 | |
| 	common.Must(err)
 | |
| 	if tag != "test" {
 | |
| 		t.Error("expect tag 'test', bug actually ", tag)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestIPIfNonMatchDomain(t *testing.T) {
 | |
| 	config := &Config{
 | |
| 		DomainStrategy: Config_IpIfNonMatch,
 | |
| 		Rule: []*RoutingRule{
 | |
| 			{
 | |
| 				TargetTag: &RoutingRule_Tag{
 | |
| 					Tag: "test",
 | |
| 				},
 | |
| 				Cidr: []*CIDR{
 | |
| 					{
 | |
| 						Ip:     []byte{192, 168, 0, 0},
 | |
| 						Prefix: 16,
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	mockCtl := gomock.NewController(t)
 | |
| 	defer mockCtl.Finish()
 | |
| 
 | |
| 	mockDns := mocks.NewDNSClient(mockCtl)
 | |
| 	mockDns.EXPECT().LookupIP(gomock.Eq("v2ray.com")).Return([]net.IP{{192, 168, 0, 1}}, nil).AnyTimes()
 | |
| 
 | |
| 	r := new(Router)
 | |
| 	common.Must(r.Init(config, mockDns, nil))
 | |
| 
 | |
| 	ctx := session.ContextWithOutbound(context.Background(), &session.Outbound{Target: net.TCPDestination(net.DomainAddress("v2ray.com"), 80)})
 | |
| 	tag, err := r.PickRoute(ctx)
 | |
| 	common.Must(err)
 | |
| 	if tag != "test" {
 | |
| 		t.Error("expect tag 'test', bug actually ", tag)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func TestIPIfNonMatchIP(t *testing.T) {
 | |
| 	config := &Config{
 | |
| 		DomainStrategy: Config_IpIfNonMatch,
 | |
| 		Rule: []*RoutingRule{
 | |
| 			{
 | |
| 				TargetTag: &RoutingRule_Tag{
 | |
| 					Tag: "test",
 | |
| 				},
 | |
| 				Cidr: []*CIDR{
 | |
| 					{
 | |
| 						Ip:     []byte{127, 0, 0, 0},
 | |
| 						Prefix: 8,
 | |
| 					},
 | |
| 				},
 | |
| 			},
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	mockCtl := gomock.NewController(t)
 | |
| 	defer mockCtl.Finish()
 | |
| 
 | |
| 	mockDns := mocks.NewDNSClient(mockCtl)
 | |
| 
 | |
| 	r := new(Router)
 | |
| 	common.Must(r.Init(config, mockDns, nil))
 | |
| 
 | |
| 	ctx := session.ContextWithOutbound(context.Background(), &session.Outbound{Target: net.TCPDestination(net.LocalHostIP, 80)})
 | |
| 	tag, err := r.PickRoute(ctx)
 | |
| 	common.Must(err)
 | |
| 	if tag != "test" {
 | |
| 		t.Error("expect tag 'test', bug actually ", tag)
 | |
| 	}
 | |
| }
 |