import re import pytest from helpers.cluster import ClickHouseCluster cluster = ClickHouseCluster(__file__) node = cluster.add_instance( "node", with_zookeeper=False, main_configs=["configs/log.xml"] ) config = """ debug /var/log/clickhouse-server/clickhouse-server.log """ @pytest.fixture(scope="module") def start_cluster(): try: cluster.start() yield cluster finally: cluster.shutdown() def get_log(node): return node.exec_in_container( ["bash", "-c", "cat /var/log/clickhouse-server/clickhouse-server.log"] ) def check_it_will_work_slowly(node, log): it_will_work_slowly = "It will work slowly" if node.is_built_with_sanitizer() or node.is_debug_build(): # message still in logs re.search(f".*{it_will_work_slowly}", log) # but not in system.warnings query = f"SELECT count() FROM system.warnings WHERE message ILIKE '%{it_will_work_slowly}%'" assert 0 == int(node.query(query).strip()) def test_log_levels_update(start_cluster): # Make sure that there are enough log messages for the test for _ in range(5): node.query("SELECT 1") log = get_log(node) assert re.search("(|)", log) check_it_will_work_slowly(node, log) node.replace_config("/etc/clickhouse-server/config.d/log.xml", config) node.query("SYSTEM RELOAD CONFIG;") node.exec_in_container( ["bash", "-c", "> /var/log/clickhouse-server/clickhouse-server.log"] ) for _ in range(5): node.query("SELECT 1") log = get_log(node) assert len(log) > 0 assert not re.search("", log)