Files
scylladb/test/topology/test_replace_alive_node.py
Avi Kivity f3eade2f62 treewide: relicense to ScyllaDB-Source-Available-1.0
Drop the AGPL license in favor of a source-available license.
See the blog post [1] for details.

[1] https://www.scylladb.com/2024/12/18/why-were-moving-to-a-source-available-license/
2024-12-18 17:45:13 +02:00

26 lines
1.1 KiB
Python

#
# Copyright (C) 2023-present ScyllaDB
#
# SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.0
#
from test.pylib.scylla_cluster import ReplaceConfig
from test.pylib.manager_client import ManagerClient
import asyncio
import pytest
@pytest.mark.asyncio
async def test_replacing_alive_node_fails(manager: ManagerClient) -> None:
"""Try replacing an alive node and check that it fails"""
servers = await manager.running_servers()
await asyncio.gather(*(manager.server_sees_others(srv.server_id, len(servers) - 1) for srv in servers))
# We test for every server because we expect a different error depending on
# whether we try to replace the topology coordinator. We want to test both cases.
# Both errors contain the expected string below.
for srv in servers:
replace_cfg = ReplaceConfig(replaced_id = srv.server_id, reuse_ip_addr = False,
use_host_id = False, wait_replaced_dead = False)
await manager.server_add(replace_cfg=replace_cfg,
expected_error="the topology coordinator rejected request to join the cluster")