mirror of
https://github.com/GothenburgBitFactory/taskchampion-sync-server.git
synced 2025-06-26 10:54:29 +02:00
Allow specifying configuration params in env vars
This commit is contained in:
parent
5ffd179dcc
commit
7dec5fe1af
6 changed files with 189 additions and 43 deletions
|
@ -24,3 +24,4 @@ chrono.workspace = true
|
|||
actix-rt.workspace = true
|
||||
tempfile.workspace = true
|
||||
pretty_assertions.workspace = true
|
||||
temp-env.workspace = true
|
||||
|
|
|
@ -23,29 +23,36 @@ fn command() -> Command {
|
|||
.arg(
|
||||
arg!(-l --listen <ADDRESS>)
|
||||
.help("Address and Port on which to listen on. Can be an IP Address or a DNS name followed by a colon and a port e.g. localhost:8080")
|
||||
.value_delimiter(',')
|
||||
.value_parser(ValueParser::string())
|
||||
.env("LISTEN")
|
||||
.action(ArgAction::Append)
|
||||
.required(true),
|
||||
)
|
||||
.arg(
|
||||
arg!(-d --"data-dir" <DIR> "Directory in which to store data")
|
||||
.value_parser(ValueParser::os_string())
|
||||
.env("DATA_DIR")
|
||||
.default_value("/var/lib/taskchampion-sync-server"),
|
||||
)
|
||||
.arg(
|
||||
arg!(-C --"allow-client-id" <CLIENT_ID> "Client IDs to allow (can be repeated; if not specified, all clients are allowed)")
|
||||
.value_delimiter(',')
|
||||
.value_parser(value_parser!(Uuid))
|
||||
.env("CLIENT_ID")
|
||||
.action(ArgAction::Append)
|
||||
.required(false),
|
||||
)
|
||||
.arg(
|
||||
arg!(--"snapshot-versions" <NUM> "Target number of versions between snapshots")
|
||||
.value_parser(value_parser!(u32))
|
||||
.env("SNAPSHOT_VERSIONS")
|
||||
.default_value(default_snapshot_versions),
|
||||
)
|
||||
.arg(
|
||||
arg!(--"snapshot-days" <NUM> "Target number of days between snapshots")
|
||||
.value_parser(value_parser!(i64))
|
||||
.env("SNAPSHOT_DAYS")
|
||||
.default_value(default_snapshot_days),
|
||||
)
|
||||
}
|
||||
|
@ -95,6 +102,7 @@ mod test {
|
|||
use actix_web::{self, App};
|
||||
use clap::ArgMatches;
|
||||
use taskchampion_sync_server_core::InMemoryStorage;
|
||||
use temp_env::{with_var, with_var_unset, with_vars, with_vars_unset};
|
||||
|
||||
/// Get the list of allowed client IDs
|
||||
fn allowed(matches: &ArgMatches) -> Option<Vec<Uuid>> {
|
||||
|
@ -103,60 +111,180 @@ mod test {
|
|||
.map(|ids| ids.copied().collect::<Vec<_>>())
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_listen_two() {
|
||||
with_var_unset("LISTEN", || {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
"--listen",
|
||||
"otherhost:9090",
|
||||
]);
|
||||
assert_eq!(
|
||||
matches
|
||||
.get_many::<String>("listen")
|
||||
.unwrap()
|
||||
.cloned()
|
||||
.collect::<Vec<String>>(),
|
||||
vec!["localhost:8080".to_string(), "otherhost:9090".to_string()]
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_listen_two_env() {
|
||||
with_var("LISTEN", Some("localhost:8080,otherhost:9090"), || {
|
||||
let matches = command().get_matches_from(["tss"]);
|
||||
assert_eq!(
|
||||
matches
|
||||
.get_many::<String>("listen")
|
||||
.unwrap()
|
||||
.cloned()
|
||||
.collect::<Vec<String>>(),
|
||||
vec!["localhost:8080".to_string(), "otherhost:9090".to_string()]
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_allowed_client_ids_none() {
|
||||
let matches = command().get_matches_from(["tss", "--listen", "localhost:8080"]);
|
||||
assert_eq!(allowed(&matches), None);
|
||||
with_var_unset("CLIENT_ID", || {
|
||||
let matches = command().get_matches_from(["tss", "--listen", "localhost:8080"]);
|
||||
assert_eq!(allowed(&matches), None);
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_allowed_client_ids_one() {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
"-C",
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0",
|
||||
]);
|
||||
assert_eq!(
|
||||
allowed(&matches),
|
||||
Some(vec![Uuid::parse_str(
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0"
|
||||
)
|
||||
.unwrap()])
|
||||
with_var_unset("CLIENT_ID", || {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
"-C",
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0",
|
||||
]);
|
||||
assert_eq!(
|
||||
allowed(&matches),
|
||||
Some(vec![Uuid::parse_str(
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0"
|
||||
)
|
||||
.unwrap()])
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_allowed_client_ids_one_env() {
|
||||
with_var(
|
||||
"CLIENT_ID",
|
||||
Some("711d5cf3-0cf0-4eb8-9eca-6f7f220638c0"),
|
||||
|| {
|
||||
let matches = command().get_matches_from(["tss", "--listen", "localhost:8080"]);
|
||||
assert_eq!(
|
||||
allowed(&matches),
|
||||
Some(vec![Uuid::parse_str(
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0"
|
||||
)
|
||||
.unwrap()])
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_allowed_client_ids_two() {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
"-C",
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0",
|
||||
"-C",
|
||||
"bbaf4b61-344a-4a39-a19e-8caa0669b353",
|
||||
]);
|
||||
assert_eq!(
|
||||
allowed(&matches),
|
||||
Some(vec![
|
||||
Uuid::parse_str("711d5cf3-0cf0-4eb8-9eca-6f7f220638c0").unwrap(),
|
||||
Uuid::parse_str("bbaf4b61-344a-4a39-a19e-8caa0669b353").unwrap()
|
||||
])
|
||||
with_var_unset("CLIENT_ID", || {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
"-C",
|
||||
"711d5cf3-0cf0-4eb8-9eca-6f7f220638c0",
|
||||
"-C",
|
||||
"bbaf4b61-344a-4a39-a19e-8caa0669b353",
|
||||
]);
|
||||
assert_eq!(
|
||||
allowed(&matches),
|
||||
Some(vec![
|
||||
Uuid::parse_str("711d5cf3-0cf0-4eb8-9eca-6f7f220638c0").unwrap(),
|
||||
Uuid::parse_str("bbaf4b61-344a-4a39-a19e-8caa0669b353").unwrap()
|
||||
])
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_allowed_client_ids_two_env() {
|
||||
with_var(
|
||||
"CLIENT_ID",
|
||||
Some("711d5cf3-0cf0-4eb8-9eca-6f7f220638c0,bbaf4b61-344a-4a39-a19e-8caa0669b353"),
|
||||
|| {
|
||||
let matches = command().get_matches_from(["tss", "--listen", "localhost:8080"]);
|
||||
assert_eq!(
|
||||
allowed(&matches),
|
||||
Some(vec![
|
||||
Uuid::parse_str("711d5cf3-0cf0-4eb8-9eca-6f7f220638c0").unwrap(),
|
||||
Uuid::parse_str("bbaf4b61-344a-4a39-a19e-8caa0669b353").unwrap()
|
||||
])
|
||||
);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_data_dir() {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--data-dir",
|
||||
"/foo/bar",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
]);
|
||||
assert_eq!(matches.get_one::<OsString>("data-dir").unwrap(), "/foo/bar");
|
||||
with_var_unset("DATA_DIR", || {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--data-dir",
|
||||
"/foo/bar",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
]);
|
||||
assert_eq!(matches.get_one::<OsString>("data-dir").unwrap(), "/foo/bar");
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_data_dir_env() {
|
||||
with_var("DATA_DIR", Some("/foo/bar"), || {
|
||||
let matches = command().get_matches_from(["tss", "--listen", "localhost:8080"]);
|
||||
assert_eq!(matches.get_one::<OsString>("data-dir").unwrap(), "/foo/bar");
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_snapshot() {
|
||||
with_vars_unset(["SNAPSHOT_DAYS", "SNAPSHOT_VERSIONS"], || {
|
||||
let matches = command().get_matches_from([
|
||||
"tss",
|
||||
"--listen",
|
||||
"localhost:8080",
|
||||
"--snapshot-days",
|
||||
"13",
|
||||
"--snapshot-versions",
|
||||
"20",
|
||||
]);
|
||||
assert_eq!(*matches.get_one::<i64>("snapshot-days").unwrap(), 13i64);
|
||||
assert_eq!(*matches.get_one::<u32>("snapshot-versions").unwrap(), 20u32);
|
||||
});
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn command_snapshot_env() {
|
||||
with_vars(
|
||||
[
|
||||
("SNAPSHOT_DAYS", Some("13")),
|
||||
("SNAPSHOT_VERSIONS", Some("20")),
|
||||
],
|
||||
|| {
|
||||
let matches = command().get_matches_from(["tss", "--listen", "localhost:8080"]);
|
||||
assert_eq!(*matches.get_one::<i64>("snapshot-days").unwrap(), 13i64);
|
||||
assert_eq!(*matches.get_one::<u32>("snapshot-versions").unwrap(), 20u32);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
#[actix_rt::test]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue