2014-03-13 15:49:37 +00:00
|
|
|
import time
|
2014-03-13 15:55:34 +00:00
|
|
|
import pydle
|
2014-03-13 15:49:37 +00:00
|
|
|
|
2014-03-14 23:26:55 +00:00
|
|
|
from pytest import raises, mark
|
2014-03-13 15:55:34 +00:00
|
|
|
from .fixtures import with_client
|
|
|
|
from .mocks import Mock
|
|
|
|
|
2014-03-14 03:32:51 +00:00
|
|
|
pydle.client.PING_TIMEOUT = 10
|
|
|
|
|
2014-03-13 15:49:37 +00:00
|
|
|
|
2014-03-14 23:26:55 +00:00
|
|
|
## Initialization.
|
|
|
|
|
|
|
|
@with_client(invalid_kwarg=False)
|
|
|
|
def test_client_superfluous_arguments(server, client):
|
|
|
|
assert client.logger.warning.called
|
|
|
|
|
|
|
|
|
|
|
|
## Connection.
|
|
|
|
|
2014-03-13 15:49:37 +00:00
|
|
|
@with_client()
|
2014-03-14 23:26:55 +00:00
|
|
|
def test_client_reconnect(server, client):
|
|
|
|
client.disconnect(expected=True)
|
|
|
|
assert not client.connected
|
2014-03-13 15:49:37 +00:00
|
|
|
|
2014-03-14 23:26:55 +00:00
|
|
|
client.connect(reconnect=True)
|
|
|
|
assert client.connected
|
|
|
|
|
|
|
|
@mark.slow
|
2014-03-13 15:49:37 +00:00
|
|
|
@with_client()
|
2014-03-14 23:26:55 +00:00
|
|
|
def test_client_reconnect_delay(server, client):
|
|
|
|
client._reconnect_delay = Mock(return_value=1)
|
|
|
|
client.disconnect(expected=False)
|
|
|
|
|
|
|
|
assert not client.connected
|
|
|
|
time.sleep(1.1)
|
|
|
|
assert client.connected
|
2014-03-13 15:49:37 +00:00
|
|
|
|
2014-03-14 23:48:57 +00:00
|
|
|
@with_client()
|
|
|
|
def test_client_reconnect_delay_calculation(server, client):
|
|
|
|
client.RECONNECT_DELAYED = False
|
|
|
|
assert client._reconnect_delay() == 0
|
|
|
|
|
|
|
|
client.RECONNECT_DELAYED = True
|
|
|
|
for expected_delay in client.RECONNECT_DELAYS:
|
|
|
|
delay = client._reconnect_delay()
|
|
|
|
assert delay == expected_delay
|
|
|
|
|
|
|
|
client._reconnect_attempts += 1
|
|
|
|
|
|
|
|
assert client._reconnect_delay() == client.RECONNECT_DELAYS[-1]
|
|
|
|
|
2014-03-13 15:49:37 +00:00
|
|
|
@with_client()
|
2014-03-14 23:26:55 +00:00
|
|
|
def test_client_disconnect_on_connect(server, client):
|
|
|
|
client.disconnect = Mock()
|
2014-03-13 15:49:37 +00:00
|
|
|
|
2014-03-14 23:26:55 +00:00
|
|
|
client.connect('mock://local', 1337)
|
|
|
|
assert client.connected
|
|
|
|
assert client.disconnect.called
|
|
|
|
|
|
|
|
@with_client(connected=False)
|
|
|
|
def test_client_connect_invalid_params(server, client):
|
|
|
|
with raises(ValueError):
|
|
|
|
client.connect()
|
|
|
|
with raises(ValueError):
|
|
|
|
client.connect(port=1337)
|
|
|
|
|
|
|
|
@mark.slow
|
2014-03-13 15:49:37 +00:00
|
|
|
@with_client()
|
|
|
|
def test_client_timeout(server, client):
|
|
|
|
client.on_data_error = Mock()
|
|
|
|
time.sleep(pydle.client.PING_TIMEOUT + 1)
|
2014-03-14 23:26:55 +00:00
|
|
|
|
2014-03-13 15:49:37 +00:00
|
|
|
assert client.on_data_error.called
|
2014-03-14 23:26:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
## Messages.
|
|
|
|
|
|
|
|
@with_client()
|
|
|
|
def test_client_message(server, client):
|
|
|
|
client.on_raw_install = Mock()
|
|
|
|
server.send('INSTALL', 'gentoo')
|
|
|
|
assert client.on_raw_install.called
|
|
|
|
|
|
|
|
message = client.on_raw_install.call_args[0][0]
|
|
|
|
assert isinstance(message, pydle.protocol.Message)
|
|
|
|
assert message.command == 'INSTALL'
|
|
|
|
assert message.params == ('gentoo',)
|
|
|
|
|
|
|
|
@with_client()
|
|
|
|
def test_client_unknown(server, client):
|
|
|
|
client.on_unknown = Mock()
|
|
|
|
server.send('INSTALL', 'gentoo')
|
|
|
|
assert client.on_unknown.called
|