From 23f3773e572907e0831ef8ce08ca0abcb75833e3 Mon Sep 17 00:00:00 2001 From: Lilit0x Date: Thu, 14 Sep 2023 14:33:44 +0100 Subject: [PATCH 1/2] feat: wrapped sqlness with clap to provide nice interface --- Cargo.lock | 1 + tests/runner/Cargo.toml | 1 + tests/runner/src/main.rs | 38 +++++++++++++++++++++++++++++--------- tests/runner/src/util.rs | 21 +++++++++++++-------- 4 files changed, 44 insertions(+), 17 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index df924fe0097d..3ad496c82ebf 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -9019,6 +9019,7 @@ name = "sqlness-runner" version = "0.4.0-nightly" dependencies = [ "async-trait", + "clap 4.4.1", "client", "common-base", "common-error", diff --git a/tests/runner/Cargo.toml b/tests/runner/Cargo.toml index 89ae0233a602..69894f30932c 100644 --- a/tests/runner/Cargo.toml +++ b/tests/runner/Cargo.toml @@ -6,6 +6,7 @@ license.workspace = true [dependencies] async-trait = "0.1" +clap = { version = "4.0", features = ["derive"] } client = { workspace = true } common-base = { workspace = true } common-error = { workspace = true } diff --git a/tests/runner/src/main.rs b/tests/runner/src/main.rs index 3f6a757ad3e2..a1f07edecd66 100644 --- a/tests/runner/src/main.rs +++ b/tests/runner/src/main.rs @@ -12,20 +12,39 @@ // See the License for the specific language governing permissions and // limitations under the License. +use std::path::PathBuf; + +use clap::Parser; use env::Env; use sqlness::{ConfigBuilder, Runner}; mod env; mod util; +#[derive(Parser, Debug)] +#[clap(author, version, about, long_about = None)] +/// SQL Harness for GrepTimeDB +struct Args { + /// Directory of test cases + #[clap(short, long)] + case_dir: Option, + + ///Fail this run as soon as one case fails if true + #[arg(short, long, action = clap::ArgAction::Count)] + fail_fast: u8, + + ///Environment Configuration File + #[clap(short, long, default_value = "config.toml")] + env_config_file: String, + + ///Name of test case to be matched + #[clap(short, long, default_value = "")] + test_filter: String, +} + #[tokio::main] async fn main() { - let mut args: Vec = std::env::args().collect(); - let test_filter = if args.len() > 1 { - args.pop().unwrap() - } else { - "".to_string() - }; + let args = Args::parse(); #[cfg(windows)] let data_home = std::env::temp_dir(); @@ -33,10 +52,11 @@ async fn main() { let data_home = std::path::PathBuf::from("/tmp"); let config = ConfigBuilder::default() - .case_dir(util::get_case_dir()) - .fail_fast(false) - .test_filter(test_filter) + .case_dir(util::get_case_dir(args.case_dir)) + .fail_fast(matches!(args.fail_fast, 0)) + .test_filter(args.test_filter) .follow_links(true) + .env_config_file(args.env_config_file) .build() .unwrap(); let runner = Runner::new(config, Env::new(data_home)); diff --git a/tests/runner/src/util.rs b/tests/runner/src/util.rs index a052b6e3e34b..c51b81db25bb 100644 --- a/tests/runner/src/util.rs +++ b/tests/runner/src/util.rs @@ -62,15 +62,20 @@ where /// Get the dir of test cases. This function only works when the runner is run /// under the project's dir because it depends on some envs set by cargo. -pub fn get_case_dir() -> String { - // retrieve the manifest runner (./tests/runner) - let mut runner_crate_path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - // change directory to cases' dir from runner's (should be runner/../cases) - let _ = runner_crate_path.pop(); - runner_crate_path.push("cases"); +pub fn get_case_dir(case_dir: Option) -> String { + let runner_path = match case_dir { + Some(path) => path, + None => { + // retrieve the manifest runner (./tests/runner) + let mut runner_crate_path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); + // change directory to cases' dir from runner's (should be runner/../cases) + let _ = runner_crate_path.pop(); + runner_crate_path.push("cases"); + runner_crate_path + } + }; - runner_crate_path.into_os_string().into_string().unwrap() + runner_path.into_os_string().into_string().unwrap() } /// Get the dir that contains workspace manifest (the top-level Cargo.toml). From 145b5ca3c5724c41fcaf1d1c5828be955c4a29f9 Mon Sep 17 00:00:00 2001 From: Lilit0x Date: Thu, 14 Sep 2023 15:47:16 +0100 Subject: [PATCH 2/2] fix: added spaces and changed -f flag to bool --- tests/runner/src/main.rs | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/tests/runner/src/main.rs b/tests/runner/src/main.rs index a1f07edecd66..8cf02d53668b 100644 --- a/tests/runner/src/main.rs +++ b/tests/runner/src/main.rs @@ -29,16 +29,16 @@ struct Args { #[clap(short, long)] case_dir: Option, - ///Fail this run as soon as one case fails if true - #[arg(short, long, action = clap::ArgAction::Count)] - fail_fast: u8, + /// Fail this run as soon as one case fails if true + #[arg(short, long, default_value = "false")] + fail_fast: bool, - ///Environment Configuration File + /// Environment Configuration File #[clap(short, long, default_value = "config.toml")] env_config_file: String, - ///Name of test case to be matched - #[clap(short, long, default_value = "")] + /// Name of test cases to run. Accept as a regexp. + #[clap(short, long, default_value = ".*")] test_filter: String, } @@ -53,7 +53,7 @@ async fn main() { let config = ConfigBuilder::default() .case_dir(util::get_case_dir(args.case_dir)) - .fail_fast(matches!(args.fail_fast, 0)) + .fail_fast(args.fail_fast) .test_filter(args.test_filter) .follow_links(true) .env_config_file(args.env_config_file)