From b5f3c8318833c0cb7e3e842ed485a2d4281565ff Mon Sep 17 00:00:00 2001 From: Phil Freeman Date: Fri, 1 Mar 2024 13:01:15 -0800 Subject: [PATCH] Put ndc-test commands behind a feature flag --- rust-connector-sdk/Cargo.toml | 6 +- rust-connector-sdk/src/default_main.rs | 253 +++++++++++++------------ 2 files changed, 140 insertions(+), 119 deletions(-) diff --git a/rust-connector-sdk/Cargo.toml b/rust-connector-sdk/Cargo.toml index 3eb706e4..d12277d2 100644 --- a/rust-connector-sdk/Cargo.toml +++ b/rust-connector-sdk/Cargo.toml @@ -11,10 +11,14 @@ path = "src/lib.rs" name = "ndc_hub_example" path = "bin/main.rs" +[features] +ndc-test = ["dep:ndc-test"] +default = ["ndc-test"] + [dependencies] gdc_rust_types = { git = "https://github.com/hasura/gdc_rust_types.git", rev = "3273434" } ndc-client = { git = "http://github.com/hasura/ndc-spec.git", tag = "v0.1.0-rc.19" } -ndc-test = { git = "http://github.com/hasura/ndc-spec.git", tag = "v0.1.0-rc.19" } +ndc-test = { git = "http://github.com/hasura/ndc-spec.git", tag = "v0.1.0-rc.19", optional = true } async-trait = "^0.1.74" axum = "^0.6.20" diff --git a/rust-connector-sdk/src/default_main.rs b/rust-connector-sdk/src/default_main.rs index eb92b973..1b67e056 100644 --- a/rust-connector-sdk/src/default_main.rs +++ b/rust-connector-sdk/src/default_main.rs @@ -3,9 +3,7 @@ mod v2_compat; use std::error::Error; use std::net; use std::path::{Path, PathBuf}; -use std::process::exit; -use async_trait::async_trait; use axum::{ body::Body, extract::State, @@ -16,7 +14,6 @@ use axum::{ }; use axum_extra::extract::WithRejection; use clap::{Parser, Subcommand}; -use ndc_test::reporter::{ConsoleReporter, TestResults}; use prometheus::Registry; use tower_http::{trace::TraceLayer, validate_request::ValidateRequestHeaderLayer}; @@ -43,10 +40,13 @@ enum Command { #[command()] Serve(ServeCommand), #[command()] + #[cfg(feature = "ndc-test")] Test(TestCommand), #[command()] + #[cfg(feature = "ndc-test")] Replay(ReplayCommand), #[command()] + #[cfg(feature = "ndc-test")] Bench(BenchCommand), #[command()] CheckHealth(CheckHealthCommand), @@ -205,10 +205,13 @@ where match command { Command::Serve(serve_command) => serve(setup, serve_command).await, - Command::Test(test_command) => test(setup, test_command).await, - Command::Bench(bench_command) => bench(setup, bench_command).await, - Command::Replay(replay_command) => replay(setup, replay_command).await, Command::CheckHealth(check_health_command) => check_health(check_health_command).await, + #[cfg(feature = "ndc-test")] + Command::Test(test_command) => ndc_test_commands::test(setup, test_command).await, + #[cfg(feature = "ndc-test")] + Command::Bench(bench_command) => ndc_test_commands::bench(setup, bench_command).await, + #[cfg(feature = "ndc-test")] + Command::Replay(replay_command) => ndc_test_commands::replay(setup, replay_command).await, } } @@ -499,145 +502,159 @@ async fn post_query( routes::post_query::(&state.configuration, &state.state, request).await } -struct ConnectorAdapter { - configuration: C::Configuration, - state: C::State, -} - -#[async_trait(?Send)] -impl ndc_test::connector::Connector for ConnectorAdapter { - async fn get_capabilities( - &self, - ) -> Result { - C::get_capabilities() - .await - .into_value::>() - .map_err(|err| ndc_test::error::Error::OtherError(err)) +#[cfg(feature = "ndc-test")] +mod ndc_test_commands { + use super::{BenchCommand, Connector, ConnectorSetup}; + use crate::json_response::JsonResponse; + use async_trait::async_trait; + use ndc_test::reporter::{ConsoleReporter, TestResults}; + use prometheus::Registry; + use std::error::Error; + use std::path::PathBuf; + use std::process::exit; + + struct ConnectorAdapter { + configuration: C::Configuration, + state: C::State, } - async fn get_schema( - &self, - ) -> Result { - match C::get_schema(&self.configuration).await { - Ok(response) => response + #[async_trait(?Send)] + impl ndc_test::connector::Connector for ConnectorAdapter { + async fn get_capabilities( + &self, + ) -> Result { + C::get_capabilities() + .await .into_value::>() - .map_err(|err| ndc_test::error::Error::OtherError(err)), - Err(err) => Err(ndc_test::error::Error::OtherError(err.into())), + .map_err(|err| ndc_test::error::Error::OtherError(err)) } - } - async fn query( - &self, - request: ndc_client::models::QueryRequest, - ) -> Result { - match C::query(&self.configuration, &self.state, request) - .await - .and_then(JsonResponse::into_value) - { - Ok(response) => Ok(response), - Err(err) => Err(ndc_test::error::Error::OtherError(err.into())), + async fn get_schema( + &self, + ) -> Result { + match C::get_schema(&self.configuration).await { + Ok(response) => response + .into_value::>() + .map_err(|err| ndc_test::error::Error::OtherError(err)), + Err(err) => Err(ndc_test::error::Error::OtherError(err.into())), + } } - } - async fn mutation( - &self, - request: ndc_client::models::MutationRequest, - ) -> Result { - match C::mutation(&self.configuration, &self.state, request) - .await - .and_then(JsonResponse::into_value) - { - Ok(response) => Ok(response), - Err(err) => Err(ndc_test::error::Error::OtherError(err.into())), + async fn query( + &self, + request: ndc_client::models::QueryRequest, + ) -> Result { + match C::query(&self.configuration, &self.state, request) + .await + .and_then(JsonResponse::into_value) + { + Ok(response) => Ok(response), + Err(err) => Err(ndc_test::error::Error::OtherError(err.into())), + } + } + + async fn mutation( + &self, + request: ndc_client::models::MutationRequest, + ) -> Result { + match C::mutation(&self.configuration, &self.state, request) + .await + .and_then(JsonResponse::into_value) + { + Ok(response) => Ok(response), + Err(err) => Err(ndc_test::error::Error::OtherError(err.into())), + } } } -} -async fn test( - setup: Setup, - command: TestCommand, -) -> Result<(), Box> { - let test_configuration = ndc_test::configuration::TestConfiguration { - seed: command.seed.map(|s| s.as_bytes().try_into()).transpose()?, - snapshots_dir: command.snapshots_dir, - gen_config: ndc_test::configuration::TestGenerationConfiguration::default(), - }; + pub async fn test( + setup: Setup, + command: super::TestCommand, + ) -> Result<(), Box> { + let test_configuration = ndc_test::configuration::TestConfiguration { + seed: command.seed.map(|s| s.as_bytes().try_into()).transpose()?, + snapshots_dir: command.snapshots_dir, + gen_config: ndc_test::configuration::TestGenerationConfiguration::default(), + }; - let connector = make_connector_adapter(setup, command.configuration).await?; - let mut reporter = (ConsoleReporter::new(), TestResults::default()); + let connector = make_connector_adapter(setup, command.configuration).await?; + let mut reporter = (ConsoleReporter::new(), TestResults::default()); - ndc_test::test_connector(&test_configuration, &connector, &mut reporter).await; + ndc_test::test_connector(&test_configuration, &connector, &mut reporter).await; - if !reporter.1.failures.is_empty() { - println!(); - println!("{}", reporter.1.report()); + if !reporter.1.failures.is_empty() { + println!(); + println!("{}", reporter.1.report()); - exit(1) + exit(1) + } + + Ok(()) } - Ok(()) -} + pub async fn replay( + setup: Setup, + command: super::ReplayCommand, + ) -> Result<(), Box> { + let connector = make_connector_adapter(setup, command.configuration).await?; + let mut reporter = (ConsoleReporter::new(), TestResults::default()); -async fn replay( - setup: Setup, - command: ReplayCommand, -) -> Result<(), Box> { - let connector = make_connector_adapter(setup, command.configuration).await?; - let mut reporter = (ConsoleReporter::new(), TestResults::default()); + ndc_test::test_snapshots_in_directory(&connector, &mut reporter, command.snapshots_dir) + .await; - ndc_test::test_snapshots_in_directory(&connector, &mut reporter, command.snapshots_dir).await; + if !reporter.1.failures.is_empty() { + println!(); + println!("{}", reporter.1.report()); - if !reporter.1.failures.is_empty() { - println!(); - println!("{}", reporter.1.report()); + exit(1) + } - exit(1) + Ok(()) } - Ok(()) -} -async fn bench( - setup: Setup, - command: BenchCommand, -) -> Result<(), Box> { - let configuration = ndc_test::ReportConfiguration { - samples: command.samples, - tolerance: command.tolerance, - }; - - let connector = make_connector_adapter(setup, command.configuration).await?; - let mut reporter = (ConsoleReporter::new(), TestResults::default()); + pub async fn bench( + setup: Setup, + command: BenchCommand, + ) -> Result<(), Box> { + let configuration = ndc_test::ReportConfiguration { + samples: command.samples, + tolerance: command.tolerance, + }; + + let connector = make_connector_adapter(setup, command.configuration).await?; + let mut reporter = (ConsoleReporter::new(), TestResults::default()); + + let reports = ndc_test::bench_snapshots_in_directory( + &configuration, + &connector, + &mut reporter, + command.snapshots_dir, + ) + .await + .map_err(|e| e.to_string())?; - let reports = ndc_test::bench_snapshots_in_directory( - &configuration, - &connector, - &mut reporter, - command.snapshots_dir, - ) - .await - .map_err(|e| e.to_string())?; + println!(); + println!("{}", ndc_test::benchmark_report(&configuration, reports)); - println!(); - println!("{}", ndc_test::benchmark_report(&configuration, reports)); + if !reporter.1.failures.is_empty() { + exit(1); + } - if !reporter.1.failures.is_empty() { - exit(1); + Ok(()) } - Ok(()) -} - -async fn make_connector_adapter( - setup: Setup, - configuration_path: PathBuf, -) -> Result, Box> { - let mut metrics = Registry::new(); - let configuration = setup.parse_configuration(configuration_path).await?; - let state = setup.try_init_state(&configuration, &mut metrics).await?; - Ok(ConnectorAdapter { - configuration, - state, - }) + async fn make_connector_adapter( + setup: Setup, + configuration_path: PathBuf, + ) -> Result, Box> { + let mut metrics = Registry::new(); + let configuration = setup.parse_configuration(configuration_path).await?; + let state = setup.try_init_state(&configuration, &mut metrics).await?; + Ok(ConnectorAdapter { + configuration, + state, + }) + } } async fn check_health(