Add TestOneConnectionRemoval
This commit is contained in:
		| @ -321,7 +321,7 @@ func TestGetOnWaitChannel(t *testing.T) { | |||||||
| 	servers[0].stop() | 	servers[0].stop() | ||||||
| } | } | ||||||
|  |  | ||||||
| func TestOneConnectionDown(t *testing.T) { | func TestOneServerDown(t *testing.T) { | ||||||
| 	// Start 2 servers. | 	// Start 2 servers. | ||||||
| 	numServers := 2 | 	numServers := 2 | ||||||
| 	servers, r := startServers(t, numServers, math.MaxUint32) | 	servers, r := startServers(t, numServers, math.MaxUint32) | ||||||
| @ -363,7 +363,7 @@ func TestOneConnectionDown(t *testing.T) { | |||||||
| 		go func() { | 		go func() { | ||||||
| 			time.Sleep(sleepDuration) | 			time.Sleep(sleepDuration) | ||||||
| 			// After sleepDuration, invoke RPC. | 			// After sleepDuration, invoke RPC. | ||||||
| 			// server[0] is killed around the same time to make it racey between balancer and gRPC internals. | 			// server[0] is killed around the same time to make it racy between balancer and gRPC internals. | ||||||
| 			Invoke(context.Background(), "/foo/bar", &req, &reply, cc, FailFast(false)) | 			Invoke(context.Background(), "/foo/bar", &req, &reply, cc, FailFast(false)) | ||||||
| 			wg.Done() | 			wg.Done() | ||||||
| 		}() | 		}() | ||||||
| @ -374,3 +374,65 @@ func TestOneConnectionDown(t *testing.T) { | |||||||
| 		servers[i].stop() | 		servers[i].stop() | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func TestOneAddressRemoval(t *testing.T) { | ||||||
|  | 	// Start 2 servers. | ||||||
|  | 	numServers := 2 | ||||||
|  | 	servers, r := startServers(t, numServers, math.MaxUint32) | ||||||
|  | 	cc, err := Dial("foo.bar.com", WithBalancer(RoundRobin(r)), WithBlock(), WithInsecure(), WithCodec(testCodec{})) | ||||||
|  | 	if err != nil { | ||||||
|  | 		t.Fatalf("Failed to create ClientConn: %v", err) | ||||||
|  | 	} | ||||||
|  | 	// Add servers[1] to the service discovery. | ||||||
|  | 	var updates []*naming.Update | ||||||
|  | 	updates = append(updates, &naming.Update{ | ||||||
|  | 		Op:   naming.Add, | ||||||
|  | 		Addr: "127.0.0.1:" + servers[1].port, | ||||||
|  | 	}) | ||||||
|  | 	r.w.inject(updates) | ||||||
|  | 	req := "port" | ||||||
|  | 	var reply string | ||||||
|  | 	// Loop until servers[1] is up | ||||||
|  | 	for { | ||||||
|  | 		if err := Invoke(context.Background(), "/foo/bar", &req, &reply, cc); err != nil && ErrorDesc(err) == servers[1].port { | ||||||
|  | 			break | ||||||
|  | 		} | ||||||
|  | 		time.Sleep(10 * time.Millisecond) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	var wg sync.WaitGroup | ||||||
|  | 	numRPC := 100 | ||||||
|  | 	sleepDuration := 10 * time.Millisecond | ||||||
|  | 	wg.Add(1) | ||||||
|  | 	go func() { | ||||||
|  | 		time.Sleep(sleepDuration) | ||||||
|  | 		// After sleepDuration, delete server[0]. | ||||||
|  | 		var updates []*naming.Update | ||||||
|  | 		updates = append(updates, &naming.Update{ | ||||||
|  | 			Op:   naming.Delete, | ||||||
|  | 			Addr: "127.0.0.1:" + servers[0].port, | ||||||
|  | 		}) | ||||||
|  | 		r.w.inject(updates) | ||||||
|  | 		wg.Done() | ||||||
|  | 	}() | ||||||
|  |  | ||||||
|  | 	// All non-failfast RPCs should not fail because there's at least one connection available. | ||||||
|  | 	for i := 0; i < numRPC; i++ { | ||||||
|  | 		wg.Add(1) | ||||||
|  | 		go func() { | ||||||
|  | 			var reply string | ||||||
|  | 			time.Sleep(sleepDuration) | ||||||
|  | 			// After sleepDuration, invoke RPC. | ||||||
|  | 			// server[0] is removed around the same time to make it racy between balancer and gRPC internals. | ||||||
|  | 			if err := Invoke(context.Background(), "/foo/bar", &expectedRequest, &reply, cc, FailFast(false)); err != nil { | ||||||
|  | 				t.Errorf("grpc.Invoke(_, _, _, _, _) = %v, want not nil", err) | ||||||
|  | 			} | ||||||
|  | 			wg.Done() | ||||||
|  | 		}() | ||||||
|  | 	} | ||||||
|  | 	wg.Wait() | ||||||
|  | 	cc.Close() | ||||||
|  | 	for i := 0; i < numServers; i++ { | ||||||
|  | 		servers[i].stop() | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Menghan Li
					Menghan Li