239 lines
5.9 KiB
Rust
239 lines
5.9 KiB
Rust
use super::*;
|
|
|
|
#[test]
|
|
fn cli_config_opens_wizard() {
|
|
let cli = Cli::try_parse_from(["refray", "config"]).unwrap();
|
|
|
|
assert!(matches!(cli.command, Command::Config));
|
|
}
|
|
|
|
#[test]
|
|
fn cli_rejects_removed_config_subcommands() {
|
|
for args in [
|
|
["refray", "config", "wizard"].as_slice(),
|
|
["refray", "config", "init"].as_slice(),
|
|
["refray", "config", "show"].as_slice(),
|
|
["refray", "config", "site", "list"].as_slice(),
|
|
["refray", "config", "mirror", "list"].as_slice(),
|
|
] {
|
|
assert!(Cli::try_parse_from(args).is_err());
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_sync_repo_pattern() {
|
|
let cli = Cli::try_parse_from([
|
|
"refray",
|
|
"sync",
|
|
"--repo-pattern",
|
|
"^(foo|bar)-",
|
|
"--dry-run",
|
|
])
|
|
.unwrap();
|
|
|
|
let Command::Sync(args) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert_eq!(args.repo_pattern, Some("^(foo|bar)-".to_string()));
|
|
assert!(args.dry_run);
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_sync_retry_failed() {
|
|
let cli = Cli::try_parse_from(["refray", "sync", "--retry-failed"]).unwrap();
|
|
|
|
let Command::Sync(args) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert!(args.retry_failed);
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_sync_jobs() {
|
|
let cli = Cli::try_parse_from(["refray", "sync", "--jobs", "8"]).unwrap();
|
|
|
|
let Command::Sync(args) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert_eq!(args.jobs, 8);
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_webhook_serve() {
|
|
let cli = Cli::try_parse_from([
|
|
"refray",
|
|
"serve",
|
|
"--listen",
|
|
"127.0.0.1:9000",
|
|
"--secret-env",
|
|
"WEBHOOK_SECRET",
|
|
"--jobs",
|
|
"2",
|
|
"--full-sync-interval-minutes",
|
|
"30",
|
|
])
|
|
.unwrap();
|
|
|
|
let Command::Serve(args) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert_eq!(args.listen, "127.0.0.1:9000");
|
|
assert_eq!(args.secret_env, Some("WEBHOOK_SECRET".to_string()));
|
|
assert_eq!(args.jobs, 2);
|
|
assert_eq!(args.full_sync_interval_minutes, Some(30));
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_webhook_install() {
|
|
let cli = Cli::try_parse_from(["refray", "webhook", "install", "--jobs", "6"]).unwrap();
|
|
|
|
let Command::Webhook(WebhookCommand::Install(args)) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert_eq!(args.jobs, 6);
|
|
}
|
|
|
|
#[test]
|
|
fn cli_rejects_removed_webhook_install_args() {
|
|
for args in [
|
|
["refray", "webhook", "install", "repo-one"].as_slice(),
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"install",
|
|
"--url",
|
|
"https://mirror.example.test/webhook",
|
|
]
|
|
.as_slice(),
|
|
["refray", "webhook", "install", "--group", "sync-1"].as_slice(),
|
|
["refray", "webhook", "install", "--work-dir", "/tmp/refray"].as_slice(),
|
|
["refray", "webhook", "install", "--secret", "secret"].as_slice(),
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"install",
|
|
"--secret-env",
|
|
"WEBHOOK_SECRET",
|
|
]
|
|
.as_slice(),
|
|
["refray", "webhook", "install", "--repo-pattern", "^repo$"].as_slice(),
|
|
] {
|
|
assert!(Cli::try_parse_from(args).is_err());
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_webhook_uninstall() {
|
|
let cli = Cli::try_parse_from(["refray", "webhook", "uninstall", "--dry-run", "--jobs", "3"])
|
|
.unwrap();
|
|
|
|
let Command::Webhook(WebhookCommand::Uninstall(args)) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert!(args.dry_run);
|
|
assert_eq!(args.jobs, 3);
|
|
}
|
|
|
|
#[test]
|
|
fn cli_rejects_removed_webhook_uninstall_args() {
|
|
for args in [
|
|
["refray", "webhook", "uninstall", "repo-one"].as_slice(),
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"uninstall",
|
|
"--url",
|
|
"https://mirror.example.test/webhook",
|
|
]
|
|
.as_slice(),
|
|
["refray", "webhook", "uninstall", "--group", "sync-1"].as_slice(),
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"uninstall",
|
|
"--work-dir",
|
|
"/tmp/refray",
|
|
]
|
|
.as_slice(),
|
|
] {
|
|
assert!(Cli::try_parse_from(args).is_err());
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn cli_accepts_webhook_update() {
|
|
let cli = Cli::try_parse_from([
|
|
"refray",
|
|
"webhook",
|
|
"update",
|
|
"https://new.example.test/webhook",
|
|
"--jobs",
|
|
"5",
|
|
])
|
|
.unwrap();
|
|
|
|
let Command::Webhook(WebhookCommand::Update(args)) = cli.command else {
|
|
panic!("parsed unexpected command");
|
|
};
|
|
assert_eq!(args.url, "https://new.example.test/webhook");
|
|
assert_eq!(args.jobs, 5);
|
|
}
|
|
|
|
#[test]
|
|
fn cli_rejects_removed_webhook_update_secret_args() {
|
|
for args in [
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"update",
|
|
"--url",
|
|
"https://new.example.test/webhook",
|
|
]
|
|
.as_slice(),
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"update",
|
|
"https://new.example.test/webhook",
|
|
"--secret",
|
|
"secret",
|
|
]
|
|
.as_slice(),
|
|
[
|
|
"refray",
|
|
"webhook",
|
|
"update",
|
|
"https://new.example.test/webhook",
|
|
"--secret-env",
|
|
"WEBHOOK_SECRET",
|
|
]
|
|
.as_slice(),
|
|
] {
|
|
assert!(Cli::try_parse_from(args).is_err());
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn cli_rejects_scoped_webhook_update() {
|
|
let result = Cli::try_parse_from([
|
|
"refray",
|
|
"webhook",
|
|
"update",
|
|
"repo-one",
|
|
"https://new.example.test/webhook",
|
|
]);
|
|
|
|
assert!(result.is_err());
|
|
}
|
|
|
|
#[test]
|
|
fn missing_config_error_asks_user_to_run_config() {
|
|
let temp = tempfile::tempdir().unwrap();
|
|
let path = temp.path().join("config.toml");
|
|
|
|
let error = load_config(&path).unwrap_err().to_string();
|
|
|
|
assert!(error.contains("config not found at"));
|
|
assert!(error.contains("Run `refray config` first"));
|
|
}
|