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 Worker 17*cc02d7e2SAndroid Build Coastguard Workerimport http2_base_server 18*cc02d7e2SAndroid Build Coastguard Worker 19*cc02d7e2SAndroid Build Coastguard Worker 20*cc02d7e2SAndroid Build Coastguard Workerclass TestcasePing(object): 21*cc02d7e2SAndroid Build Coastguard Worker """ 22*cc02d7e2SAndroid Build Coastguard Worker This test injects PING frames before and after header and data. Keeps count 23*cc02d7e2SAndroid Build Coastguard Worker of outstanding ping response and asserts when the count is non-zero at the 24*cc02d7e2SAndroid Build Coastguard Worker end of the test. 25*cc02d7e2SAndroid Build Coastguard Worker """ 26*cc02d7e2SAndroid Build Coastguard Worker 27*cc02d7e2SAndroid Build Coastguard Worker def __init__(self): 28*cc02d7e2SAndroid Build Coastguard Worker self._base_server = http2_base_server.H2ProtocolBaseServer() 29*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers[ 30*cc02d7e2SAndroid Build Coastguard Worker "RequestReceived" 31*cc02d7e2SAndroid Build Coastguard Worker ] = self.on_request_received 32*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers["DataReceived"] = self.on_data_received 33*cc02d7e2SAndroid Build Coastguard Worker self._base_server._handlers["ConnectionLost"] = self.on_connection_lost 34*cc02d7e2SAndroid Build Coastguard Worker 35*cc02d7e2SAndroid Build Coastguard Worker def get_base_server(self): 36*cc02d7e2SAndroid Build Coastguard Worker return self._base_server 37*cc02d7e2SAndroid Build Coastguard Worker 38*cc02d7e2SAndroid Build Coastguard Worker def on_request_received(self, event): 39*cc02d7e2SAndroid Build Coastguard Worker self._base_server.default_ping() 40*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_request_received_default(event) 41*cc02d7e2SAndroid Build Coastguard Worker self._base_server.default_ping() 42*cc02d7e2SAndroid Build Coastguard Worker 43*cc02d7e2SAndroid Build Coastguard Worker def on_data_received(self, event): 44*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_data_received_default(event) 45*cc02d7e2SAndroid Build Coastguard Worker sr = self._base_server.parse_received_data(event.stream_id) 46*cc02d7e2SAndroid Build Coastguard Worker if sr: 47*cc02d7e2SAndroid Build Coastguard Worker logging.info("Creating response size = %s" % sr.response_size) 48*cc02d7e2SAndroid Build Coastguard Worker response_data = self._base_server.default_response_data( 49*cc02d7e2SAndroid Build Coastguard Worker sr.response_size 50*cc02d7e2SAndroid Build Coastguard Worker ) 51*cc02d7e2SAndroid Build Coastguard Worker self._base_server.default_ping() 52*cc02d7e2SAndroid Build Coastguard Worker self._base_server.setup_send(response_data, event.stream_id) 53*cc02d7e2SAndroid Build Coastguard Worker self._base_server.default_ping() 54*cc02d7e2SAndroid Build Coastguard Worker 55*cc02d7e2SAndroid Build Coastguard Worker def on_connection_lost(self, reason): 56*cc02d7e2SAndroid Build Coastguard Worker logging.info( 57*cc02d7e2SAndroid Build Coastguard Worker "Disconnect received. Ping Count %d" 58*cc02d7e2SAndroid Build Coastguard Worker % self._base_server._outstanding_pings 59*cc02d7e2SAndroid Build Coastguard Worker ) 60*cc02d7e2SAndroid Build Coastguard Worker assert self._base_server._outstanding_pings == 0 61*cc02d7e2SAndroid Build Coastguard Worker self._base_server.on_connection_lost(reason) 62