blob: 7af2e28fdd64c11751a96442195f42c1a903c9a0 [file] [log] [blame]
Jan Tattermusch7897ae92017-06-07 22:57:36 +02001# Copyright 2016 gRPC authors.
ncteisen65a45ae2016-12-15 14:35:17 -08002#
Jan Tattermusch7897ae92017-06-07 22:57:36 +02003# 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
ncteisen65a45ae2016-12-15 14:35:17 -08006#
Jan Tattermusch7897ae92017-06-07 22:57:36 +02007# http://www.apache.org/licenses/LICENSE-2.0
ncteisen65a45ae2016-12-15 14:35:17 -08008#
Jan Tattermusch7897ae92017-06-07 22:57:36 +02009# 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.
ncteisen65a45ae2016-12-15 14:35:17 -080014
Makarand Dharmapurikar8c579172016-12-12 13:58:15 -080015import hyperframe.frame
Makarand Dharmapurikar323bfa72016-12-01 10:51:10 -080016import logging
Makarand Dharmapurikar8c579172016-12-12 13:58:15 -080017
Makarand Dharmapurikar323bfa72016-12-01 10:51:10 -080018import http2_base_server
Makarand Dharmapurikar323bfa72016-12-01 10:51:10 -080019
20class TestcaseSettingsMaxStreams(object):
21 """
22 This test sets MAX_CONCURRENT_STREAMS to 1 and asserts that at any point
23 only 1 stream is active.
24 """
25 def __init__(self):
26 self._base_server = http2_base_server.H2ProtocolBaseServer()
27 self._base_server._handlers['DataReceived'] = self.on_data_received
28 self._base_server._handlers['ConnectionMade'] = self.on_connection_made
29
30 def get_base_server(self):
31 return self._base_server
32
33 def on_connection_made(self):
34 logging.info('Connection Made')
35 self._base_server._conn.initiate_connection()
Makarand Dharmapurikar8c579172016-12-12 13:58:15 -080036 self._base_server._conn.update_settings(
37 {hyperframe.frame.SettingsFrame.MAX_CONCURRENT_STREAMS: 1})
Makarand Dharmapurikar323bfa72016-12-01 10:51:10 -080038 self._base_server.transport.setTcpNoDelay(True)
39 self._base_server.transport.write(self._base_server._conn.data_to_send())
40
41 def on_data_received(self, event):
42 self._base_server.on_data_received_default(event)
Makarand Dharmapurikar4350e742016-12-01 14:24:22 -080043 sr = self._base_server.parse_received_data(event.stream_id)
44 if sr:
Makarand Dharmapurikar8c579172016-12-12 13:58:15 -080045 logging.info('Creating response of size = %s' % sr.response_size)
Makarand Dharmapurikar4350e742016-12-01 14:24:22 -080046 response_data = self._base_server.default_response_data(sr.response_size)
47 self._base_server.setup_send(response_data, event.stream_id)
Makarand Dharmapurikar8c579172016-12-12 13:58:15 -080048 # TODO (makdharma): Add assertion to check number of live streams