Skip to content

Commit

Permalink
Merge pull request grpc#7086 from kpayson64/remove_python_beta_test
Browse files Browse the repository at this point in the history
Removed _connectivity_channel tests
  • Loading branch information
jtattermusch authored Jun 29, 2016
2 parents 40a3e64 + 4ea7784 commit 1f6faf3
Show file tree
Hide file tree
Showing 2 changed files with 0 additions and 154 deletions.
1 change: 0 additions & 1 deletion src/python/grpcio/tests/tests.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
"_channel_ready_future_test.ChannelReadyFutureTest",
"_channel_test.ChannelTest",
"_compression_test.CompressionTest",
"_connectivity_channel_test.ChannelConnectivityTest",
"_connectivity_channel_test.ConnectivityStatesTest",
"_empty_message_test.EmptyMessageTest",
"_exit_test.ExitTest",
Expand Down
153 changes: 0 additions & 153 deletions src/python/grpcio/tests/unit/beta/_connectivity_channel_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,162 +29,9 @@

"""Tests of grpc.beta._connectivity_channel."""

import threading
import time
import unittest

from grpc._adapter import _low
from grpc._adapter import _types
from grpc.beta import _connectivity_channel
from grpc.beta import interfaces
from tests.unit.framework.common import test_constants


def _drive_completion_queue(completion_queue):
while True:
event = completion_queue.next(time.time() + 24 * 60 * 60)
if event.type == _types.EventType.QUEUE_SHUTDOWN:
break


class _Callback(object):

def __init__(self):
self._condition = threading.Condition()
self._connectivities = []

def update(self, connectivity):
with self._condition:
self._connectivities.append(connectivity)
self._condition.notify()

def connectivities(self):
with self._condition:
return tuple(self._connectivities)

def block_until_connectivities_satisfy(self, predicate):
with self._condition:
while True:
connectivities = tuple(self._connectivities)
if predicate(connectivities):
return connectivities
else:
self._condition.wait()


class ChannelConnectivityTest(unittest.TestCase):

def test_lonely_channel_connectivity(self):
low_channel = _low.Channel('localhost:12345', ())
callback = _Callback()

connectivity_channel = _connectivity_channel.ConnectivityChannel(
low_channel)
connectivity_channel.subscribe(callback.update, try_to_connect=False)
first_connectivities = callback.block_until_connectivities_satisfy(bool)
connectivity_channel.subscribe(callback.update, try_to_connect=True)
second_connectivities = callback.block_until_connectivities_satisfy(
lambda connectivities: 2 <= len(connectivities))
# Wait for a connection that will never happen.
time.sleep(test_constants.SHORT_TIMEOUT)
third_connectivities = callback.connectivities()
connectivity_channel.unsubscribe(callback.update)
fourth_connectivities = callback.connectivities()
connectivity_channel.unsubscribe(callback.update)
fifth_connectivities = callback.connectivities()

self.assertSequenceEqual(
(interfaces.ChannelConnectivity.IDLE,), first_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.READY, second_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.READY, third_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.READY, fourth_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.READY, fifth_connectivities)

def test_immediately_connectable_channel_connectivity(self):
server_completion_queue = _low.CompletionQueue()
server = _low.Server(server_completion_queue, [])
port = server.add_http2_port('[::]:0')
server.start()
server_completion_queue_thread = threading.Thread(
target=_drive_completion_queue, args=(server_completion_queue,))
server_completion_queue_thread.start()
low_channel = _low.Channel('localhost:%d' % port, ())
first_callback = _Callback()
second_callback = _Callback()

connectivity_channel = _connectivity_channel.ConnectivityChannel(
low_channel)
connectivity_channel.subscribe(first_callback.update, try_to_connect=False)
first_connectivities = first_callback.block_until_connectivities_satisfy(
bool)
# Wait for a connection that will never happen because try_to_connect=True
# has not yet been passed.
time.sleep(test_constants.SHORT_TIMEOUT)
second_connectivities = first_callback.connectivities()
connectivity_channel.subscribe(second_callback.update, try_to_connect=True)
third_connectivities = first_callback.block_until_connectivities_satisfy(
lambda connectivities: 2 <= len(connectivities))
fourth_connectivities = second_callback.block_until_connectivities_satisfy(
bool)
# Wait for a connection that will happen (or may already have happened).
first_callback.block_until_connectivities_satisfy(
lambda connectivities:
interfaces.ChannelConnectivity.READY in connectivities)
second_callback.block_until_connectivities_satisfy(
lambda connectivities:
interfaces.ChannelConnectivity.READY in connectivities)
connectivity_channel.unsubscribe(first_callback.update)
connectivity_channel.unsubscribe(second_callback.update)

server.shutdown()
server_completion_queue.shutdown()
server_completion_queue_thread.join()

self.assertSequenceEqual(
(interfaces.ChannelConnectivity.IDLE,), first_connectivities)
self.assertSequenceEqual(
(interfaces.ChannelConnectivity.IDLE,), second_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.TRANSIENT_FAILURE, third_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.FATAL_FAILURE, third_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.TRANSIENT_FAILURE,
fourth_connectivities)
self.assertNotIn(
interfaces.ChannelConnectivity.FATAL_FAILURE, fourth_connectivities)

def test_reachable_then_unreachable_channel_connectivity(self):
server_completion_queue = _low.CompletionQueue()
server = _low.Server(server_completion_queue, [])
port = server.add_http2_port('[::]:0')
server.start()
server_completion_queue_thread = threading.Thread(
target=_drive_completion_queue, args=(server_completion_queue,))
server_completion_queue_thread.start()
low_channel = _low.Channel('localhost:%d' % port, ())
callback = _Callback()

connectivity_channel = _connectivity_channel.ConnectivityChannel(
low_channel)
connectivity_channel.subscribe(callback.update, try_to_connect=True)
callback.block_until_connectivities_satisfy(
lambda connectivities:
interfaces.ChannelConnectivity.READY in connectivities)
# Now take down the server and confirm that channel readiness is repudiated.
server.shutdown()
callback.block_until_connectivities_satisfy(
lambda connectivities:
connectivities[-1] is not interfaces.ChannelConnectivity.READY)
connectivity_channel.unsubscribe(callback.update)

server.shutdown()
server_completion_queue.shutdown()
server_completion_queue_thread.join()


class ConnectivityStatesTest(unittest.TestCase):
Expand Down

0 comments on commit 1f6faf3

Please sign in to comment.