2007-12-14 23:46:47 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
2009-03-30 21:35:00 +00:00
|
|
|
#
|
|
|
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
# or more contributor license agreements. See the NOTICE file
|
|
|
|
# distributed with this work for additional information
|
|
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
|
|
# to you 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.
|
|
|
|
#
|
|
|
|
|
2007-12-14 23:46:47 +00:00
|
|
|
from thrift.transport import TSocket
|
|
|
|
import unittest
|
|
|
|
import time
|
|
|
|
import socket
|
|
|
|
import random
|
2015-11-08 14:43:55 +00:00
|
|
|
|
2007-12-14 23:46:47 +00:00
|
|
|
|
|
|
|
class TimeoutTest(unittest.TestCase):
|
|
|
|
def setUp(self):
|
2015-11-06 12:24:16 +00:00
|
|
|
for i in range(50):
|
2007-12-14 23:46:47 +00:00
|
|
|
try:
|
|
|
|
# find a port we can use
|
|
|
|
self.listen_sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
|
|
|
self.port = random.randint(10000, 30000)
|
|
|
|
self.listen_sock.bind(('localhost', self.port))
|
|
|
|
self.listen_sock.listen(5)
|
|
|
|
break
|
|
|
|
except:
|
|
|
|
if i == 49:
|
|
|
|
raise
|
|
|
|
|
|
|
|
def testConnectTimeout(self):
|
|
|
|
starttime = time.time()
|
2008-02-06 22:18:40 +00:00
|
|
|
|
2007-12-14 23:46:47 +00:00
|
|
|
try:
|
|
|
|
leaky = []
|
2015-11-06 12:24:16 +00:00
|
|
|
for i in range(100):
|
2007-12-14 23:46:47 +00:00
|
|
|
socket = TSocket.TSocket('localhost', self.port)
|
|
|
|
socket.setTimeout(10)
|
|
|
|
socket.open()
|
|
|
|
leaky.append(socket)
|
|
|
|
except:
|
2008-10-17 19:30:35 +00:00
|
|
|
self.assert_(time.time() - starttime < 5.0)
|
2007-12-14 23:46:47 +00:00
|
|
|
|
|
|
|
def testWriteTimeout(self):
|
|
|
|
starttime = time.time()
|
2008-02-06 22:18:40 +00:00
|
|
|
|
2007-12-14 23:46:47 +00:00
|
|
|
try:
|
|
|
|
socket = TSocket.TSocket('localhost', self.port)
|
|
|
|
socket.setTimeout(10)
|
|
|
|
socket.open()
|
|
|
|
lsock = self.listen_sock.accept()
|
|
|
|
while True:
|
|
|
|
socket.write("hi" * 100)
|
2008-02-06 22:18:40 +00:00
|
|
|
|
2007-12-14 23:46:47 +00:00
|
|
|
except:
|
2008-10-17 19:30:35 +00:00
|
|
|
self.assert_(time.time() - starttime < 5.0)
|
2008-02-06 22:18:40 +00:00
|
|
|
|
2015-11-08 14:43:55 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
suite = unittest.TestSuite()
|
|
|
|
loader = unittest.TestLoader()
|
2007-12-14 23:46:47 +00:00
|
|
|
|
2015-11-08 14:43:55 +00:00
|
|
|
suite.addTest(loader.loadTestsFromTestCase(TimeoutTest))
|
2007-12-14 23:46:47 +00:00
|
|
|
|
2015-11-08 14:43:55 +00:00
|
|
|
testRunner = unittest.TextTestRunner(verbosity=2)
|
|
|
|
testRunner.run(suite)
|