fix: Do not leave child processes around after the end-to-end test (#955)

pull/24376/head
Andrew Lamb 2021-03-10 09:25:27 -05:00 committed by GitHub
parent 1c6d25e7d8
commit f568c083a4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 31 additions and 8 deletions

1
Cargo.lock generated
View File

@ -1507,6 +1507,7 @@ dependencies = [
"opentelemetry-jaeger", "opentelemetry-jaeger",
"packers", "packers",
"panic_logging", "panic_logging",
"parking_lot",
"predicates", "predicates",
"prost", "prost",
"query", "query",

View File

@ -94,6 +94,7 @@ influxdb2_client = { path = "influxdb2_client" }
influxdb_iox_client = { path = "influxdb_iox_client", features = ["flight"] } influxdb_iox_client = { path = "influxdb_iox_client", features = ["flight"] }
test_helpers = { path = "test_helpers" } test_helpers = { path = "test_helpers" }
once_cell = { version = "1.4.0", features = ["parking_lot"] } once_cell = { version = "1.4.0", features = ["parking_lot"] }
parking_lot = "0.11.1"
# Crates.io dependencies, in alphabetical order # Crates.io dependencies, in alphabetical order
assert_cmd = "1.0.0" assert_cmd = "1.0.0"

View File

@ -1,7 +1,10 @@
use std::{ use std::{
fs::File, fs::File,
str, str,
sync::atomic::{AtomicUsize, Ordering::SeqCst}, sync::{
atomic::{AtomicUsize, Ordering::SeqCst},
Weak,
},
}; };
use std::{num::NonZeroU32, process::Child}; use std::{num::NonZeroU32, process::Child};
@ -89,15 +92,33 @@ impl ServerFixture {
/// This is currently implemented as a singleton so all tests *must* /// This is currently implemented as a singleton so all tests *must*
/// use a new database and not interfere with the existing database. /// use a new database and not interfere with the existing database.
pub async fn create_shared() -> Self { pub async fn create_shared() -> Self {
static SERVER: OnceCell<Arc<TestServer>> = OnceCell::new(); // Try and reuse the same shared server, if there is already
// one present
static SHARED_SERVER: OnceCell<parking_lot::Mutex<Weak<TestServer>>> = OnceCell::new();
let server = Arc::clone(SERVER.get_or_init(|| { let shared_server = SHARED_SERVER.get_or_init(|| parking_lot::Mutex::new(Weak::new()));
let server = TestServer::new().expect("Could start test server");
Arc::new(server) let mut shared_server = shared_server.lock();
}));
// is a shared server already present?
let server = match shared_server.upgrade() {
Some(server) => server,
None => {
// if not, create one
let server = TestServer::new().expect("Could start test server");
let server = Arc::new(server);
// ensure the server is ready
server.wait_until_ready(InitialConfig::SetWriterId).await;
// save a reference for other threads that may want to
// use this server, but don't prevent it from being
// destroyed when going out of scope
*shared_server = Arc::downgrade(&server);
server
}
};
std::mem::drop(shared_server);
// ensure the server is ready
server.wait_until_ready(InitialConfig::SetWriterId).await;
Self::create_common(server).await Self::create_common(server).await
} }