def test_identify(): @mock_server def handle(socket, address): assert socket.recv(4) == ' V2' assert socket.recv(9) == 'IDENTIFY\n' size = nsq.unpack_size(socket.recv(4)) data = json.loads(socket.recv(size)) assert 'gnsq' in data['user_agent'] socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, 'OK')) with handle as server: conn = Nsqd(address='127.0.0.1', tcp_port=server.server_port) conn.connect() assert conn.identify() is None
def test_identify(): @mock_server def handle(socket, address): assert socket.recv(4) == b' V2' assert socket.recv(9) == b'IDENTIFY\n' size = nsq.unpack_size(socket.recv(4)) data = json.loads(socket.recv(size).decode('utf-8')) assert 'gnsq' in data['user_agent'] socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, b'OK')) with handle as server: conn = Nsqd(address='127.0.0.1', tcp_port=server.server_port) conn.connect() assert conn.identify() is None
def test_sync_receive_messages(): @mock_server def handle(socket, address): assert socket.recv(4) == b' V2' assert socket.recv(9) == b'IDENTIFY\n' size = nsq.unpack_size(socket.recv(4)) data = json.loads(socket.recv(size).decode('utf-8')) assert isinstance(data, dict) socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, b'OK')) msg = b'SUB topic channel\n' assert socket.recv(len(msg)) == msg socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, b'OK')) for i in range(10): assert socket.recv(6) == b'RDY 1\n' body = six.b(json.dumps({'data': {'test_key': i}})) ts = i * 1000 * 1000 socket.send(mock_response_message(ts, i, i, body)) with handle as server: conn = Nsqd(address='127.0.0.1', tcp_port=server.server_port) conn.connect() assert conn.identify() is None conn.subscribe('topic', 'channel') frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_RESPONSE assert data == b'OK' for i in range(10): conn.ready(1) frame, msg = conn.read_response() assert frame == nsq.FRAME_TYPE_MESSAGE assert isinstance(msg, Message) assert msg.timestamp == i * 1000 * 1000 assert msg.id == six.b('%016d' % i) assert msg.attempts == i assert json.loads( msg.body.decode('utf-8'))['data']['test_key'] == i
def test_sync_receive_messages(): @mock_server def handle(socket, address): assert socket.recv(4) == ' V2' assert socket.recv(9) == 'IDENTIFY\n' size = nsq.unpack_size(socket.recv(4)) data = json.loads(socket.recv(size)) assert isinstance(data, dict) socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, 'OK')) msg = 'SUB topic channel\n' assert socket.recv(len(msg)) == msg socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, 'OK')) for i in xrange(10): assert socket.recv(6) == 'RDY 1\n' body = json.dumps({'data': {'test_key': i}}) ts = i * 1000 * 1000 socket.send(mock_response_message(ts, i, i, body)) with handle as server: conn = Nsqd(address='127.0.0.1', tcp_port=server.server_port) conn.connect() assert conn.identify() is None conn.subscribe('topic', 'channel') frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_RESPONSE assert data == 'OK' for i in xrange(10): conn.ready(1) frame, msg = conn.read_response() assert frame == nsq.FRAME_TYPE_MESSAGE assert isinstance(msg, Message) assert msg.timestamp == i * 1000 * 1000 assert msg.id == '%016d' % i assert msg.attempts == i assert json.loads(msg.body)['data']['test_key'] == i
def test_negotiation(): @mock_server def handle(socket, address): assert socket.recv(4) == b' V2' assert socket.recv(9) == b'IDENTIFY\n' size = nsq.unpack_size(socket.recv(4)) data = json.loads(socket.recv(size).decode('utf-8')) assert 'gnsq' in data['user_agent'] resp = six.b(json.dumps({'test': 42})) socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, resp)) with handle as server: conn = Nsqd(address='127.0.0.1', tcp_port=server.server_port) conn.connect() assert conn.identify()['test'] == 42
def test_identify_auth(): @mock_server def handle(socket, address): assert socket.recv(4) == ' V2' assert socket.recv(9) == 'IDENTIFY\n' size = nsq.unpack_size(socket.recv(4)) data = json.loads(socket.recv(size)) assert 'gnsq' in data['user_agent'] resp = json.dumps({'auth_required': True}) socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, resp)) assert socket.recv(5) == 'AUTH\n' assert nsq.unpack_size(socket.recv(4)) == 6 assert socket.recv(6) == 'secret' resp = json.dumps({'identity': 'awesome'}) socket.send(mock_response(nsq.FRAME_TYPE_RESPONSE, resp)) with handle as server: conn = Nsqd( address='127.0.0.1', tcp_port=server.server_port, auth_secret='secret' ) @conn.on_auth.connect def assert_auth(conn, response): assert assert_auth.was_called is False assert_auth.was_called = True assert response['identity'] == 'awesome' assert_auth.was_called = False conn.connect() resp = conn.identify() assert resp['auth_required'] assert assert_auth.was_called
def test_socket_upgrades(tls, deflate, snappy): with NsqdIntegrationServer() as server: options = { 'address': server.address, 'tcp_port': server.tcp_port, 'deflate': deflate, 'snappy': snappy, } if tls: options.update({ 'tls_v1': True, 'tls_options': { 'keyfile': server.tls_key, 'certfile': server.tls_cert, } }) conn = Nsqd(**options) conn.connect() assert conn.state == states.CONNECTED if deflate and snappy: with pytest.raises(errors.NSQErrorCode): conn.identify() return if tls and BAD_GEVENT: with pytest.raises(AttributeError): conn.identify() return if tls and server.version < (0, 2, 28): with pytest.raises(ssl.SSLError): conn.identify() return resp = conn.identify() assert isinstance(resp, dict) assert resp['tls_v1'] is tls assert resp['deflate'] is deflate assert resp['snappy'] is snappy if tls and (deflate or snappy): assert isinstance(conn.stream.socket._socket, SSLSocket) elif tls: assert isinstance(conn.stream.socket, SSLSocket) if deflate: assert isinstance(conn.stream.socket, DefalteSocket) if snappy: assert isinstance(conn.stream.socket, SnappySocket) conn.publish('topic', b'sup') frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_RESPONSE assert data == b'OK' conn.subscribe('topic', 'channel') frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_RESPONSE assert data == b'OK' conn.ready(1) frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_MESSAGE assert data.body == b'sup' conn.close_stream()
def test_socket_upgrades(tls, deflate, snappy): with NsqdIntegrationServer() as server: options = { 'address': server.address, 'tcp_port': server.tcp_port, 'deflate': deflate, 'snappy': snappy, } if tls: options.update({ 'tls_v1': True, 'tls_options': { 'keyfile': server.tls_key, 'certfile': server.tls_cert, } }) conn = Nsqd(**options) conn.connect() assert conn.state == states.CONNECTED if deflate and snappy: with pytest.raises(errors.NSQErrorCode): conn.identify() return if tls and BAD_GEVENT: with pytest.raises(AttributeError): conn.identify() return if tls and server.version < (0, 2, 28): with pytest.raises(ssl.SSLError): conn.identify() return resp = conn.identify() assert isinstance(resp, dict) assert resp['tls_v1'] is tls assert resp['deflate'] is deflate assert resp['snappy'] is snappy if tls and (deflate or snappy): assert isinstance(conn.stream.socket._socket, SSLSocket) elif tls: assert isinstance(conn.stream.socket, SSLSocket) if deflate: assert isinstance(conn.stream.socket, DefalteSocket) if snappy: assert isinstance(conn.stream.socket, SnappySocket) conn.publish('topic', 'sup') frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_RESPONSE assert data == 'OK' conn.subscribe('topic', 'channel') frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_RESPONSE assert data == 'OK' conn.ready(1) frame, data = conn.read_response() assert frame == nsq.FRAME_TYPE_MESSAGE assert data.body == 'sup' conn.close_stream()