fix: speed up end-to-end test harness so it polls rather than waits
parent
97a5eb7e19
commit
8be278aadd
|
@ -227,6 +227,13 @@ async fn read(req: hyper::Request<Body>, app: Arc<App>) -> Result<Option<Body>,
|
||||||
Ok(Some(response_body.into()))
|
Ok(Some(response_body.into()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Route to test that the server is alive
|
||||||
|
#[tracing::instrument]
|
||||||
|
async fn ping(req: hyper::Request<Body>) -> Result<Option<Body>, ApplicationError> {
|
||||||
|
let response_body = "PONG";
|
||||||
|
Ok(Some(response_body.into()))
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Deserialize, Debug)]
|
#[derive(Deserialize, Debug)]
|
||||||
struct CreateBucketInfo {
|
struct CreateBucketInfo {
|
||||||
org: Id,
|
org: Id,
|
||||||
|
@ -271,6 +278,7 @@ async fn create_bucket(
|
||||||
async fn service(req: hyper::Request<Body>, app: Arc<App>) -> http::Result<hyper::Response<Body>> {
|
async fn service(req: hyper::Request<Body>, app: Arc<App>) -> http::Result<hyper::Response<Body>> {
|
||||||
let response = match (req.method(), req.uri().path()) {
|
let response = match (req.method(), req.uri().path()) {
|
||||||
(&Method::POST, "/api/v2/write") => write(req, app).await,
|
(&Method::POST, "/api/v2/write") => write(req, app).await,
|
||||||
|
(&Method::GET, "/ping") => ping(req).await,
|
||||||
(&Method::GET, "/api/v2/read") => read(req, app).await,
|
(&Method::GET, "/api/v2/read") => read(req, app).await,
|
||||||
(&Method::POST, "/api/v2/create_bucket") => create_bucket(req, app).await,
|
(&Method::POST, "/api/v2/create_bucket") => create_bucket(req, app).await,
|
||||||
_ => Err(ApplicationError::new(
|
_ => Err(ApplicationError::new(
|
||||||
|
|
|
@ -37,6 +37,8 @@ use std::time::{Duration, SystemTime};
|
||||||
use std::u32;
|
use std::u32;
|
||||||
use tempfile::TempDir;
|
use tempfile::TempDir;
|
||||||
|
|
||||||
|
use tokio::time::Instant;
|
||||||
|
|
||||||
const URL_BASE: &str = "http://localhost:8080/api/v2";
|
const URL_BASE: &str = "http://localhost:8080/api/v2";
|
||||||
const GRPC_URL_BASE: &str = "http://localhost:8082/";
|
const GRPC_URL_BASE: &str = "http://localhost:8082/";
|
||||||
|
|
||||||
|
@ -622,8 +624,53 @@ impl TestServer {
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn wait_until_ready(&self) {
|
async fn wait_until_ready(&self) {
|
||||||
// TODO: poll the server to see if it's ready instead of sleeping
|
// Poll the RPC and HTTP servers separately as they listen on
|
||||||
tokio::time::delay_for(Duration::from_secs(3)).await;
|
// different ports but both need to be up for the test to run
|
||||||
|
async fn try_grpc_connect() {
|
||||||
|
let mut interval = tokio::time::interval(Duration::from_millis(500));
|
||||||
|
loop {
|
||||||
|
match StorageClient::connect(GRPC_URL_BASE).await {
|
||||||
|
Ok(storage_client) => {
|
||||||
|
println!(
|
||||||
|
"Successfully connected storage_client: {:?}",
|
||||||
|
storage_client
|
||||||
|
);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
println!("Waiting for gRPM server to be up: {}", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
interval.tick().await;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn try_http_connect() {
|
||||||
|
let client = reqwest::Client::new();
|
||||||
|
let url = format!("{}/ping", URL_BASE);
|
||||||
|
let mut interval = tokio::time::interval(Duration::from_millis(500));
|
||||||
|
loop {
|
||||||
|
match client.get(&url).send().await {
|
||||||
|
Ok(resp) => {
|
||||||
|
println!("Successfully got a response from http: {:?}", resp);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
println!("Waiting for HTTP server to be up: {}", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
interval.tick().await;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let pair = futures::future::join(try_http_connect(), try_grpc_connect());
|
||||||
|
|
||||||
|
let capped_check = tokio::time::timeout_at(Instant::now() + Duration::from_secs(3), pair);
|
||||||
|
|
||||||
|
match capped_check.await {
|
||||||
|
Ok(_) => println!("Server is up correctly"),
|
||||||
|
Err(e) => println!("WARNING: server was not ready: {}", e),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue