From 1c84172ad48a7b9a8a59e91d28594026c520440c Mon Sep 17 00:00:00 2001 From: Casey Rodarmor Date: Wed, 18 Mar 2020 01:02:55 -0700 Subject: [PATCH] Skip torrent file creation with `imdl torrent create --dry-run` Torrent files will not be written to disk with `--dry-run`: imdl torrrent create --input foo --dry-run type: added --- src/subcommand/torrent/create.rs | 55 ++++++++++++++++++++++++-------- 1 file changed, 41 insertions(+), 14 deletions(-) diff --git a/src/subcommand/torrent/create.rs b/src/subcommand/torrent/create.rs index 6df5953..d37353c 100644 --- a/src/subcommand/torrent/create.rs +++ b/src/subcommand/torrent/create.rs @@ -59,7 +59,6 @@ pub(crate) struct Create { comment: Option, #[structopt( long = "node", - short = "n", value_name = "NODE", help = "Add DHT bootstrap node `NODE` to torrent. `NODE` should be in the form `HOST:PORT`, \ where `HOST` is a domain name, an IPv4 address, or an IPv6 address surrounded by \ @@ -69,6 +68,12 @@ pub(crate) struct Create { `--node [2001:db8:4275:7920:6269:7463:6f69:6e21]:8832`" )] dht_nodes: Vec, + #[structopt( + long = "dry-run", + short = "n", + help = "Skip writing `.torrent` file to disk." + )] + dry_run: bool, #[structopt( long = "follow-symlinks", short = "F", @@ -369,22 +374,24 @@ impl Create { let bytes = metainfo.serialize()?; - match &output { - OutputTarget::File(path) => { - let mut open_options = fs::OpenOptions::new(); + if !self.dry_run { + match &output { + OutputTarget::File(path) => { + let mut open_options = fs::OpenOptions::new(); - if self.force { - open_options.write(true).create(true).truncate(true); - } else { - open_options.write(true).create_new(true); + if self.force { + open_options.write(true).create(true).truncate(true); + } else { + open_options.write(true).create_new(true); + } + + open_options + .open(path) + .and_then(|mut file| file.write_all(&bytes)) + .context(error::Filesystem { path })?; } - - open_options - .open(path) - .and_then(|mut file| file.write_all(&bytes)) - .context(error::Filesystem { path })?; + OutputTarget::Stdout => env.out_mut().write_all(&bytes).context(error::Stdout)?, } - OutputTarget::Stdout => env.out_mut().write_all(&bytes).context(error::Stdout)?, } #[cfg(test)] @@ -2420,4 +2427,24 @@ Content Size 9 bytes 666\n" ); } + + #[test] + fn dry_run_skips_torrent_file_creation() { + let mut env = test_env! { + args: [ + "torrent", + "create", + "--input", + "foo", + "--dry-run", + ], + tree: { + foo: "", + } + }; + assert_matches!(env.run(), Ok(())); + let torrent = env.resolve("foo.torrent"); + let err = fs::read(torrent).unwrap_err(); + assert_eq!(err.kind(), io::ErrorKind::NotFound); + } }