1*cc02d7e2SAndroid Build Coastguard Worker# Copyright 2016 gRPC authors. 2*cc02d7e2SAndroid Build Coastguard Worker# 3*cc02d7e2SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 4*cc02d7e2SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 5*cc02d7e2SAndroid Build Coastguard Worker# You may obtain a copy of the License at 6*cc02d7e2SAndroid Build Coastguard Worker# 7*cc02d7e2SAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 8*cc02d7e2SAndroid Build Coastguard Worker# 9*cc02d7e2SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*cc02d7e2SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 11*cc02d7e2SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*cc02d7e2SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 13*cc02d7e2SAndroid Build Coastguard Worker# limitations under the License. 14*cc02d7e2SAndroid Build Coastguard Worker 15*cc02d7e2SAndroid Build Coastguard Workerimport logging 16*cc02d7e2SAndroid Build Coastguard Workerimport time 17*cc02d7e2SAndroid Build Coastguard Worker 18*cc02d7e2SAndroid Build Coastguard Workerimport http2_base_server 19*cc02d7e2SAndroid Build Coastguard Worker 20*cc02d7e2SAndroid Build Coastguard Worker 21*cc02d7e2SAndroid Build Coastguard Workerclass TestcaseGoaway(object): 22*cc02d7e2SAndroid Build Coastguard Worker """ 23*cc02d7e2SAndroid Build Coastguard Worker This test does the following: 24*cc02d7e2SAndroid Build Coastguard Worker Process incoming request normally, i.e. send headers, data and trailers. 25*cc02d7e2SAndroid Build Coastguard Worker Then send a GOAWAY frame with the stream id of the processed request. 26*cc02d7e2SAndroid Build Coastguard Worker It checks that the next request is made on a different TCP connection. 27*cc02d7e2SAndroid Build Coastguard Worker """ 28*cc02d7e2SAndroid Build Coastguard Worker 29*cc02d7e2SAndroid Build Coastguard Worker def __init__(self, iteration): 30*cc02d7e2SAndroid Build Coastguard Worker self._base_server = http2_base_server.H2ProtocolBaseServer() 31*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers[ 32*cc02d7e2SAndroid Build Coastguard Worker "RequestReceived" 33*cc02d7e2SAndroid Build Coastguard Worker ] = self.on_request_received 34*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers["DataReceived"] = self.on_data_received 35*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers["SendDone"] = self.on_send_done 36*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers["ConnectionLost"] = self.on_connection_lost 37*cc02d7e2SAndroid Build Coastguard Worker self._ready_to_send = False 38*cc02d7e2SAndroid Build Coastguard Worker self._iteration = iteration 39*cc02d7e2SAndroid Build Coastguard Worker 40*cc02d7e2SAndroid Build Coastguard Worker def get_base_server(self): 41*cc02d7e2SAndroid Build Coastguard Worker return self._base_server 42*cc02d7e2SAndroid Build Coastguard Worker 43*cc02d7e2SAndroid Build Coastguard Worker def on_connection_lost(self, reason): 44*cc02d7e2SAndroid Build Coastguard Worker logging.info("Disconnect received. Count %d" % self._iteration) 45*cc02d7e2SAndroid Build Coastguard Worker # _iteration == 2 => Two different connections have been used. 46*cc02d7e2SAndroid Build Coastguard Worker if self._iteration == 2: 47*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_connection_lost(reason) 48*cc02d7e2SAndroid Build Coastguard Worker 49*cc02d7e2SAndroid Build Coastguard Worker def on_send_done(self, stream_id): 50*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_send_done_default(stream_id) 51*cc02d7e2SAndroid Build Coastguard Worker logging.info("Sending GOAWAY for stream %d:" % stream_id) 52*cc02d7e2SAndroid Build Coastguard Worker self._base_server._conn.close_connection( 53*cc02d7e2SAndroid Build Coastguard Worker error_code=0, additional_data=None, last_stream_id=stream_id 54*cc02d7e2SAndroid Build Coastguard Worker ) 55*cc02d7e2SAndroid Build Coastguard Worker self._base_server._stream_status[stream_id] = False 56*cc02d7e2SAndroid Build Coastguard Worker 57*cc02d7e2SAndroid Build Coastguard Worker def on_request_received(self, event): 58*cc02d7e2SAndroid Build Coastguard Worker self._ready_to_send = False 59*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_request_received_default(event) 60*cc02d7e2SAndroid Build Coastguard Worker 61*cc02d7e2SAndroid Build Coastguard Worker def on_data_received(self, event): 62*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_data_received_default(event) 63*cc02d7e2SAndroid Build Coastguard Worker sr = self._base_server.parse_received_data(event.stream_id) 64*cc02d7e2SAndroid Build Coastguard Worker if sr: 65*cc02d7e2SAndroid Build Coastguard Worker logging.info("Creating response size = %s" % sr.response_size) 66*cc02d7e2SAndroid Build Coastguard Worker response_data = self._base_server.default_response_data( 67*cc02d7e2SAndroid Build Coastguard Worker sr.response_size 68*cc02d7e2SAndroid Build Coastguard Worker ) 69*cc02d7e2SAndroid Build Coastguard Worker self._ready_to_send = True 70*cc02d7e2SAndroid Build Coastguard Worker self._base_server.setup_send(response_data, event.stream_id) 71