blob: 2ec2b1b82a4c68c12decb120650b2efbc93c6655 [file] [log] [blame]
# 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.
import pytest
from pyignite import Client, AioClient
from tests.util import start_ignite_gen
# Sometimes on slow testing servers and unstable topology
# default timeout is not enough for cache ops.
CLIENT_SOCKET_TIMEOUT = 20.0
@pytest.fixture(scope='module', autouse=True)
def server1():
yield from start_ignite_gen(1)
@pytest.fixture(scope='module', autouse=True)
def server2():
yield from start_ignite_gen(2)
@pytest.fixture(scope='module', autouse=True)
def server3():
yield from start_ignite_gen(3)
@pytest.fixture
def client():
client = Client(partition_aware=True, timeout=CLIENT_SOCKET_TIMEOUT)
try:
client.connect([('127.0.0.1', 10800 + i) for i in range(1, 4)])
yield client
finally:
client.close()
@pytest.fixture
async def async_client():
client = AioClient(partition_aware=True)
try:
await client.connect([('127.0.0.1', 10800 + i) for i in range(1, 4)])
yield client
finally:
await client.close()
@pytest.fixture(scope='module', autouse=True)
def skip_if_no_affinity(request, server1):
client = Client(partition_aware=True)
client.connect('127.0.0.1', 10801)
if not client.partition_awareness_supported_by_protocol:
pytest.skip(f'skipped {request.node.name}, partition awareness is not supported.')