blob: 4a45a591252df5ba2c8496ee738295b0d38873f1 [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.
*/
use crate::test_server::ClientFactory;
use async_trait::async_trait;
use iggy::prelude::{Client, ClientWrapper, TcpClient, TcpClientConfig};
use iggy_common::TransportProtocol;
use std::sync::Arc;
#[derive(Debug, Clone, Default)]
pub struct TcpClientFactory {
pub server_addr: String,
pub nodelay: bool,
pub tls_enabled: bool,
pub tls_domain: String,
pub tls_ca_file: Option<String>,
pub tls_validate_certificate: bool,
}
#[async_trait]
impl ClientFactory for TcpClientFactory {
async fn create_client(&self) -> ClientWrapper {
let config = TcpClientConfig {
server_address: self.server_addr.clone(),
nodelay: self.nodelay,
tls_enabled: self.tls_enabled,
tls_domain: self.tls_domain.clone(),
tls_ca_file: self.tls_ca_file.clone(),
tls_validate_certificate: self.tls_validate_certificate,
..TcpClientConfig::default()
};
let client = TcpClient::create(Arc::new(config)).unwrap_or_else(|e| {
panic!(
"Failed to create TcpClient, iggy-server has address {}, error: {:?}",
self.server_addr, e
)
});
Client::connect(&client).await.unwrap_or_else(|e| {
if self.tls_enabled {
panic!(
"Failed to connect to iggy-server at {} with TLS enabled, error: {:?}\n\
Hint: Make sure the server is started with TLS enabled and self-signed certificate:\n\
IGGY_TCP_TLS_ENABLED=true IGGY_TCP_TLS_SELF_SIGNED=true\n
or start iggy-bench with relevant tcp tls arguments: --tls --tls-domain <domain> --tls-ca-file <ca_file>\n",
self.server_addr, e
)
} else {
panic!(
"Failed to connect to iggy-server at {}, error: {:?}",
self.server_addr, e
)
}
});
ClientWrapper::Tcp(client)
}
fn transport(&self) -> TransportProtocol {
TransportProtocol::Tcp
}
fn server_addr(&self) -> String {
self.server_addr.clone()
}
}
unsafe impl Send for TcpClientFactory {}
unsafe impl Sync for TcpClientFactory {}