| 
					
				 | 
			
			
				@@ -0,0 +1,275 @@ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+#!/usr/bin/env python 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+# Copyright 2015 gRPC authors. 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+# 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+# Licensed 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. 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+# This file is auto-generated 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import argparse 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import sys 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import subprocess 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import tempfile 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import os 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import time 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+import signal 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp = argparse.ArgumentParser(description='Run c-ares resolver tests') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp.add_argument('--test_bin_path', default=None, type=str, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  help='Path to gtest test binary to invoke.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp.add_argument('--dns_server_bin_path', default=None, type=str, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  help='Path to local DNS server python script.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp.add_argument('--records_config_path', default=None, type=str, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  help=('Path to DNS records yaml file that ' 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                        'specifies records for the DNS sever. ')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp.add_argument('--dns_server_port', default=None, type=int, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  help=('Port that local DNS server is listening on.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp.add_argument('--dns_resolver_bin_path', default=None, type=str, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  help=('Path to the DNS health check utility.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+argp.add_argument('--tcp_connect_bin_path', default=None, type=str, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  help=('Path to the TCP health check utility.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+args = argp.parse_args() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+def test_runner_log(msg): 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  sys.stderr.write('%s: %s\n' % (__file__, msg)) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+cur_resolver = os.environ.get('GRPC_DNS_RESOLVER') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if cur_resolver and cur_resolver != 'ares': 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  test_runner_log(('WARNING: cur resolver set to %s. This set of tests ' 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      'needs to use GRPC_DNS_RESOLVER=ares.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  test_runner_log('Exit 1 without running tests.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  sys.exit(1) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+os.environ.update({'GRPC_DNS_RESOLVER': 'ares'}) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+def wait_until_dns_server_is_up(args, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                                dns_server_subprocess, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                                dns_server_subprocess_output): 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  for i in range(0, 30): 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+    test_runner_log('Health check: attempt to connect to DNS server over TCP.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+    tcp_connect_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        args.tcp_connect_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        '--server_host', '127.0.0.1', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        '--server_port', str(args.dns_server_port), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        '--timeout', str(1)]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+    tcp_connect_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+    if tcp_connect_subprocess.returncode == 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      test_runner_log(('Health check: attempt to make an A-record ' 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                       'query to DNS server.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      dns_resolver_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          args.dns_resolver_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          '--qname', 'health-check-local-dns-server-is-alive.resolver-tests.grpctestingexp', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          '--server_host', '127.0.0.1', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          '--server_port', str(args.dns_server_port)], 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          stdout=subprocess.PIPE) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      dns_resolver_stdout, _ = dns_resolver_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      if dns_resolver_subprocess.returncode == 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        if '123.123.123.123' in dns_resolver_stdout: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+          test_runner_log(('DNS server is up! ' 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                           'Successfully reached it over UDP and TCP.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        return 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+    time.sleep(0.1) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  dns_server_subprocess.kill() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  dns_server_subprocess.wait() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  test_runner_log(('Failed to reach DNS server over TCP and/or UDP. ' 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                   'Exitting without running tests.')) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  test_runner_log('======= DNS server stdout ' 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                  '(merged stdout and stderr) =============') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  with open(dns_server_subprocess_output, 'r') as l: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+    test_runner_log(l.read()) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  test_runner_log('======= end DNS server output=========') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  sys.exit(1) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+dns_server_subprocess_output = tempfile.mktemp() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+with open(dns_server_subprocess_output, 'w') as l: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  dns_server_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      args.dns_server_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      '--port', str(args.dns_server_port), 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      '--records_config_path', args.records_config_path], 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      stdin=subprocess.PIPE, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      stdout=l, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+      stderr=l) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+def _quit_on_signal(signum, _frame): 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  test_runner_log('Received signal: %d' % signum) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  dns_server_subprocess.kill() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  dns_server_subprocess.wait() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  sys.exit(1) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+signal.signal(signal.SIGINT, _quit_on_signal) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+signal.signal(signal.SIGTERM, _quit_on_signal) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+wait_until_dns_server_is_up(args, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                            dns_server_subprocess, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                            dns_server_subprocess_output) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+num_test_failures = 0 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv4-single-target.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv4-single-target.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:1234,True', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv4-multi-target.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv4-multi-target.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.5:1234,True;1.2.3.6:1234,True;1.2.3.7:1234,True', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv6-single-target.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv6-single-target.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '[2607:f8b0:400a:801::1001]:1234,True', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv6-multi-target.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv6-multi-target.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '[2607:f8b0:400a:801::1002]:1234,True;[2607:f8b0:400a:801::1003]:1234,True;[2607:f8b0:400a:801::1004]:1234,True', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv4-simple-service-config.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv4-simple-service-config.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:1234,True', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '{"loadBalancingPolicy":"round_robin","methodConfig":[{"name":[{"method":"Foo","service":"SimpleService","waitForReady":true}]}]}', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', 'round_robin', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'ipv4-no-srv-simple-service-config.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'ipv4-no-srv-simple-service-config.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '{"loadBalancingPolicy":"round_robin","methodConfig":[{"name":[{"method":"Foo","service":"NoSrvSimpleService","waitForReady":true}]}]}', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', 'round_robin', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'ipv4-no-config-for-cpp.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'ipv4-no-config-for-cpp.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'ipv4-cpp-config-has-zero-percentage.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'ipv4-cpp-config-has-zero-percentage.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'ipv4-second-language-is-cpp.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'ipv4-second-language-is-cpp.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '{"loadBalancingPolicy":"round_robin","methodConfig":[{"name":[{"method":"Foo","service":"CppService","waitForReady":true}]}]}', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', 'round_robin', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'ipv4-config-with-percentages.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'ipv4-config-with-percentages.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '{"loadBalancingPolicy":"round_robin","methodConfig":[{"name":[{"method":"Foo","service":"AlwaysPickedService","waitForReady":true}]}]}', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', 'round_robin', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv4-target-has-backend-and-balancer.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv4-target-has-backend-and-balancer.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:1234,True;1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'srv-ipv6-target-has-backend-and-balancer.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'srv-ipv6-target-has-backend-and-balancer.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '[2607:f8b0:400a:801::1002]:1234,True;[2607:f8b0:400a:801::1002]:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('Run test with target: %s' % 'ipv4-config-causing-fallback-to-tcp.resolver-tests-version-4.grpctestingexp.') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess = subprocess.Popen([ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  args.test_bin_path, 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--target_name', 'ipv4-config-causing-fallback-to-tcp.resolver-tests-version-4.grpctestingexp.', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_addrs', '1.2.3.4:443,False', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_chosen_service_config', '{"loadBalancingPolicy":"round_robin","methodConfig":[{"name":[{"method":"Foo","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooTwo","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooThree","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooFour","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooFive","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooSix","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooSeven","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooEight","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooNine","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooTen","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooEleven","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooTwelve","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooTwelve","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooTwelve","service":"SimpleService","waitForReady":true}]},{"name":[{"method":"FooTwelve","service":"SimpleService","waitForReady":true}]}]}', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--expected_lb_policy', '', 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  '--local_dns_server_address', '127.0.0.1:%d' % args.dns_server_port]) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+current_test_subprocess.communicate() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+if current_test_subprocess.returncode != 0: 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+  num_test_failures += 1 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+ 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('now kill DNS server') 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+dns_server_subprocess.kill() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+dns_server_subprocess.wait() 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+test_runner_log('%d tests failed.' % num_test_failures) 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+sys.exit(num_test_failures) 
			 |