failover_test.py
Go to the documentation of this file.
1 # Copyright 2021 gRPC authors.
2 #
3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
6 #
7 # http://www.apache.org/licenses/LICENSE-2.0
8 #
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
14 import logging
15 from typing import List
16 
17 from absl import flags
18 from absl.testing import absltest
19 
20 from framework import xds_k8s_testcase
21 from framework.infrastructure import k8s
22 from framework.test_app import server_app
23 
24 logger = logging.getLogger(__name__)
25 flags.adopt_module_key_flags(xds_k8s_testcase)
26 
27 # Type aliases
28 _XdsTestServer = xds_k8s_testcase.XdsTestServer
29 _XdsTestClient = xds_k8s_testcase.XdsTestClient
30 
31 
32 class FailoverTest(xds_k8s_testcase.RegularXdsKubernetesTestCase):
33  REPLICA_COUNT = 3
34  MAX_RATE_PER_ENDPOINT = 100
35 
36  def setUp(self):
37  super().setUp()
38  self.secondary_server_runner = server_app.KubernetesServerRunner(
39  k8s.KubernetesNamespace(self.secondary_k8s_api_manager,
40  self.server_namespace),
41  deployment_name=self.server_name + '-alt',
42  image_name=self.server_image,
43  gcp_service_account=self.gcp_service_account,
44  td_bootstrap_image=self.td_bootstrap_image,
45  gcp_project=self.project,
46  gcp_api_manager=self.gcp_api_manager,
47  xds_server_uri=self.xds_server_uri,
48  network=self.network,
49  debug_use_port_forwarding=self.debug_use_port_forwarding,
50  reuse_namespace=True)
51 
52  def tearDown(self):
53  if hasattr(self, 'secondary_server_runner'):
55  super().tearDown()
56 
57  def test_failover(self) -> None:
58  with self.subTest('00_create_health_check'):
59  self.td.create_health_check()
60 
61  with self.subTest('01_create_backend_services'):
62  self.td.create_backend_service()
63 
64  with self.subTest('02_create_url_map'):
65  self.td.create_url_map(self.server_xds_host, self.server_xds_port)
66 
67  with self.subTest('03_create_target_proxy'):
68  self.td.create_target_proxy()
69 
70  with self.subTest('04_create_forwarding_rule'):
71  self.td.create_forwarding_rule(self.server_xds_port)
72 
73  default_test_servers: List[_XdsTestServer]
74  alternate_test_servers: List[_XdsTestServer]
75  with self.subTest('05_start_test_servers'):
76  default_test_servers = self.startTestServers(
77  replica_count=self.REPLICA_COUNT)
78 
79  alternate_test_servers = self.startTestServers(
80  server_runner=self.secondary_server_runner)
81 
82  with self.subTest('06_add_server_backends_to_backend_services'):
83  self.setupServerBackends(
84  max_rate_per_endpoint=self.MAX_RATE_PER_ENDPOINT)
85  self.setupServerBackends(
86  server_runner=self.secondary_server_runner,
87  max_rate_per_endpoint=self.MAX_RATE_PER_ENDPOINT)
88 
89  test_client: _XdsTestClient
90  with self.subTest('07_start_test_client'):
91  test_client = self.startTestClient(default_test_servers[0])
92 
93  with self.subTest('08_test_client_xds_config_exists'):
94  self.assertXdsConfigExists(test_client)
95 
96  with self.subTest('09_primary_locality_receives_requests'):
97  self.assertRpcsEventuallyGoToGivenServers(test_client,
98  default_test_servers)
99 
100  with self.subTest(
101  '10_secondary_locality_receives_no_requests_on_partial_primary_failure'
102  ):
103  default_test_servers[0].set_not_serving()
104  self.assertRpcsEventuallyGoToGivenServers(test_client,
105  default_test_servers[1:])
106 
107  with self.subTest('11_gentle_failover'):
108  default_test_servers[1].set_not_serving()
109  self.assertRpcsEventuallyGoToGivenServers(
110  test_client, default_test_servers[2:] + alternate_test_servers)
111 
112  with self.subTest(
113  '12_secondary_locality_receives_requests_on_primary_failure'):
114  default_test_servers[2].set_not_serving()
115  self.assertRpcsEventuallyGoToGivenServers(test_client,
116  alternate_test_servers)
117 
118  with self.subTest('13_traffic_resumes_to_healthy_backends'):
119  for i in range(self.REPLICA_COUNT):
120  default_test_servers[i].set_serving()
121  self.assertRpcsEventuallyGoToGivenServers(test_client,
122  default_test_servers)
123 
124 
125 if __name__ == '__main__':
126  absltest.main(failfast=True)
capstone.range
range
Definition: third_party/bloaty/third_party/capstone/bindings/python/capstone/__init__.py:6
tests.failover_test.FailoverTest
Definition: failover_test.py:32
tests.failover_test.FailoverTest.test_failover
None test_failover(self)
Definition: failover_test.py:57
run_xds_tests.create_target_proxy
def create_target_proxy(gcp, name, validate_for_proxyless=True, url_map=None)
Definition: run_xds_tests.py:2618
run_xds_tests.create_url_map
def create_url_map(gcp, name, backend_service, host_name)
Definition: run_xds_tests.py:2582
framework.test_app
Definition: tools/run_tests/xds_k8s_test_driver/framework/test_app/__init__.py:1
framework.infrastructure
Definition: tools/run_tests/xds_k8s_test_driver/framework/infrastructure/__init__.py:1
tests.failover_test.FailoverTest.secondary_server_runner
secondary_server_runner
Definition: failover_test.py:38
tests.failover_test.FailoverTest.tearDown
def tearDown(self)
Definition: failover_test.py:52
tests.failover_test.FailoverTest.MAX_RATE_PER_ENDPOINT
int MAX_RATE_PER_ENDPOINT
Definition: failover_test.py:34
cleanup
Definition: cleanup.py:1
tests.failover_test.FailoverTest.REPLICA_COUNT
int REPLICA_COUNT
Definition: failover_test.py:33
run_xds_tests.create_health_check
def create_health_check(gcp, name)
Definition: run_xds_tests.py:2515
tests.failover_test.FailoverTest.setUp
def setUp(self)
Definition: failover_test.py:36


grpc
Author(s):
autogenerated on Thu Mar 13 2025 02:59:18