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/
104 lines
5.1 KiB
Python
104 lines
5.1 KiB
Python
#
|
|
# Copyright 2023-present ScyllaDB
|
|
#
|
|
# SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.0
|
|
#
|
|
|
|
from test.nodetool.rest_api_mock import expected_request
|
|
from test.nodetool.utils import check_nodetool_fails_with
|
|
import pytest
|
|
|
|
|
|
# `scylla nodetool compact` invokes the newly added global compact api
|
|
def test_all_keyspaces(nodetool, scylla_only):
|
|
nodetool("compact", expected_requests=[
|
|
expected_request("POST", "/storage_service/compact")])
|
|
|
|
|
|
# The java-based `nodetool compact` lists all keyspaces and invoke the keyspace_compaction api on each of them
|
|
def test_all_keyspaces_jmx(nodetool, cassandra_only):
|
|
nodetool("compact", expected_requests=[
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system"),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system_schema")])
|
|
|
|
|
|
def test_keyspace(nodetool):
|
|
nodetool("compact", "system_schema", expected_requests=[
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system_schema")])
|
|
|
|
|
|
def test_nonexistent_keyspace(nodetool):
|
|
check_nodetool_fails_with(
|
|
nodetool,
|
|
("compact", "non_existent_ks"),
|
|
{"expected_requests": [
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system"])]},
|
|
["nodetool: Keyspace [non_existent_ks] does not exist.",
|
|
"error processing arguments: keyspace non_existent_ks does not exist"])
|
|
|
|
|
|
def test_table(nodetool):
|
|
nodetool("compact", "system_schema", "columns", expected_requests=[
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system_schema", params={"cf": "columns"})])
|
|
|
|
nodetool("compact", "system_schema", "columns", "computed_columns", expected_requests=[
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST",
|
|
"/storage_service/keyspace_compaction/system_schema",
|
|
params={"cf": "columns,computed_columns"})])
|
|
|
|
|
|
def test_split_output_compatibility_argument(nodetool):
|
|
dummy_request = [
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system_schema")]
|
|
|
|
nodetool("compact", "system_schema", "-s", expected_requests=dummy_request)
|
|
nodetool("compact", "system_schema", "--split-output", expected_requests=dummy_request)
|
|
|
|
|
|
def test_token_range_compatibility_argument(nodetool):
|
|
dummy_request = [
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system_schema")]
|
|
|
|
nodetool("compact", "system_schema", "-st", "0", "-et", "1000", expected_requests=dummy_request)
|
|
nodetool("compact", "system_schema", "--start-token", "0", "--end-token", "1000", expected_requests=dummy_request)
|
|
|
|
|
|
def test_user_defined(nodetool, scylla_only):
|
|
check_nodetool_fails_with(
|
|
nodetool,
|
|
("compact", "--user-defined", "/var/lib/scylla/data/system/local-7ad54392bcdd35a684174e047860b377/"
|
|
"me-3g8w_11cg_4317k2ppfb6d5vgp0w-big-Data.db"),
|
|
{},
|
|
["error processing arguments: --user-defined flag is unsupported"])
|
|
|
|
|
|
@pytest.mark.parametrize("flush", ("true", "false"))
|
|
# The `--flush-memtables` option to `nodetool compact` is available only with `scylla_nodetool`
|
|
def test_keyspace_flush_memtables_option(nodetool, scylla_only, flush):
|
|
params = {"flush_memtables": flush}
|
|
nodetool("compact", "system_schema", "--flush-memtables", flush, expected_requests=[
|
|
expected_request("GET", "/storage_service/keyspaces", multiple=expected_request.MULTIPLE,
|
|
response=["system", "system_schema"]),
|
|
expected_request("POST", "/storage_service/keyspace_compaction/system_schema", params=params)])
|
|
|
|
|
|
@pytest.mark.parametrize("flush", ("true", "false"))
|
|
# The `--flush-memtables` option to `nodetool compact` is available only with `scylla_nodetool`
|
|
def test_all_keyspaces_flush_memtables_option(nodetool, scylla_only, flush):
|
|
params = {"flush_memtables": flush}
|
|
nodetool("compact", "--flush-memtables", flush, expected_requests=[
|
|
expected_request("POST", "/storage_service/compact", params=params)])
|