2020-10-27 14:38:55 +00:00
|
|
|
import os
|
|
|
|
import pytest
|
|
|
|
import sys
|
|
|
|
import grpc
|
2021-01-22 14:27:23 +00:00
|
|
|
from helpers.cluster import ClickHouseCluster, run_and_check
|
2020-10-27 14:38:55 +00:00
|
|
|
|
2023-09-23 19:13:13 +00:00
|
|
|
script_dir = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
pb2_dir = os.path.join(script_dir, "pb2")
|
|
|
|
if pb2_dir not in sys.path:
|
|
|
|
sys.path.append(pb2_dir)
|
|
|
|
import clickhouse_grpc_pb2, clickhouse_grpc_pb2_grpc # Execute pb2/generate.py to generate these modules.
|
|
|
|
|
|
|
|
|
2022-08-09 10:50:28 +00:00
|
|
|
# The test cluster is configured with certificate for that host name, see 'server-ext.cnf'.
|
2022-08-09 09:54:28 +00:00
|
|
|
# The client have to verify server certificate against that name. Client uses SNI
|
|
|
|
SSL_HOST = "integration-tests.clickhouse.com"
|
2021-08-06 10:55:49 +00:00
|
|
|
GRPC_PORT = 9100
|
|
|
|
DEFAULT_ENCODING = "utf-8"
|
2020-10-27 14:38:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
# Utilities
|
|
|
|
|
2023-09-23 19:13:13 +00:00
|
|
|
config_dir = os.path.join(script_dir, "./configs")
|
2020-10-27 14:38:55 +00:00
|
|
|
cluster = ClickHouseCluster(__file__)
|
2021-08-06 10:55:49 +00:00
|
|
|
node = cluster.add_instance(
|
|
|
|
"node",
|
|
|
|
main_configs=[
|
|
|
|
"configs/grpc_config.xml",
|
|
|
|
"configs/server-key.pem",
|
|
|
|
"configs/server-cert.pem",
|
|
|
|
"configs/ca-cert.pem",
|
2022-03-22 16:39:58 +00:00
|
|
|
],
|
2022-12-29 19:07:14 +00:00
|
|
|
# Bug in TSAN reproduces in this test https://github.com/grpc/grpc/issues/29550#issuecomment-1188085387
|
2023-04-10 13:07:20 +00:00
|
|
|
env_variables={
|
2023-05-16 19:27:30 +00:00
|
|
|
"TSAN_OPTIONS": "report_atomic_races=0 " + os.getenv("TSAN_OPTIONS", default="")
|
2023-04-10 13:07:20 +00:00
|
|
|
},
|
2021-08-06 10:55:49 +00:00
|
|
|
)
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
|
2022-08-09 09:54:28 +00:00
|
|
|
def get_grpc_url(instance=node):
|
|
|
|
return f"{instance.ip_address}:{GRPC_PORT}"
|
|
|
|
|
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def create_secure_channel():
|
|
|
|
ca_cert = open(os.path.join(config_dir, "ca-cert.pem"), "rb").read()
|
|
|
|
client_key = open(os.path.join(config_dir, "client-key.pem"), "rb").read()
|
|
|
|
client_cert = open(os.path.join(config_dir, "client-cert.pem"), "rb").read()
|
|
|
|
credentials = grpc.ssl_channel_credentials(ca_cert, client_key, client_cert)
|
2022-08-09 09:54:28 +00:00
|
|
|
channel = grpc.secure_channel(
|
|
|
|
get_grpc_url(),
|
|
|
|
credentials,
|
|
|
|
options=(("grpc.ssl_target_name_override", SSL_HOST),),
|
|
|
|
)
|
2020-10-27 14:38:55 +00:00
|
|
|
grpc.channel_ready_future(channel).result(timeout=10)
|
|
|
|
return channel
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def create_insecure_channel():
|
2022-08-09 09:54:28 +00:00
|
|
|
channel = grpc.insecure_channel(get_grpc_url())
|
2020-10-27 14:38:55 +00:00
|
|
|
grpc.channel_ready_future(channel).result(timeout=2)
|
|
|
|
return channel
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def create_secure_channel_with_wrong_client_certificate():
|
|
|
|
ca_cert = open(os.path.join(config_dir, "ca-cert.pem"), "rb").read()
|
|
|
|
client_key = open(os.path.join(config_dir, "wrong-client-key.pem"), "rb").read()
|
|
|
|
client_cert = open(os.path.join(config_dir, "wrong-client-cert.pem"), "rb").read()
|
|
|
|
credentials = grpc.ssl_channel_credentials(ca_cert, client_key, client_cert)
|
2022-08-09 09:54:28 +00:00
|
|
|
channel = grpc.secure_channel(get_grpc_url(), credentials)
|
2020-10-27 14:38:55 +00:00
|
|
|
grpc.channel_ready_future(channel).result(timeout=2)
|
|
|
|
return channel
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def query(query_text, channel):
|
|
|
|
query_info = clickhouse_grpc_pb2.QueryInfo(query=query_text)
|
|
|
|
stub = clickhouse_grpc_pb2_grpc.ClickHouseStub(channel)
|
|
|
|
result = stub.ExecuteQuery(query_info)
|
|
|
|
if result and result.HasField("exception"):
|
|
|
|
raise Exception(result.exception.display_text)
|
2021-08-06 10:55:49 +00:00
|
|
|
return result.output.decode(DEFAULT_ENCODING)
|
2020-10-27 14:38:55 +00:00
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
@pytest.fixture(scope="module", autouse=True)
|
|
|
|
def start_cluster():
|
|
|
|
cluster.start()
|
|
|
|
try:
|
|
|
|
yield cluster
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
finally:
|
|
|
|
cluster.shutdown()
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
# Actual tests
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def test_secure_channel():
|
|
|
|
with create_secure_channel() as channel:
|
|
|
|
assert query("SELECT 'ok'", channel) == "ok\n"
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def test_insecure_channel():
|
|
|
|
with pytest.raises(grpc.FutureTimeoutError):
|
|
|
|
with create_insecure_channel() as channel:
|
|
|
|
query("SELECT 'ok'", channel)
|
|
|
|
|
2022-03-22 16:39:58 +00:00
|
|
|
|
2020-10-27 14:38:55 +00:00
|
|
|
def test_wrong_client_certificate():
|
|
|
|
with pytest.raises(grpc.FutureTimeoutError):
|
|
|
|
with create_insecure_channel() as channel:
|
|
|
|
query("SELECT 'ok'", channel)
|