Don't overwrite destination torrent without --force

type: changed
This commit is contained in:
Casey Rodarmor 2020-02-04 21:55:19 -08:00
parent df3326510c
commit 551617de4f
No known key found for this signature in database
GPG Key ID: 556186B153EC6FE0

View File

@ -43,6 +43,12 @@ Note: Many BitTorrent clients do not implement the behavior described in BEP 12.
long_help = "Include `COMMENT` in generated `.torrent` file. Stored under `comment` key of top-level metainfo dictionary." long_help = "Include `COMMENT` in generated `.torrent` file. Stored under `comment` key of top-level metainfo dictionary."
)] )]
comment: Option<String>, comment: Option<String>,
#[structopt(
name = "FORCE",
long = "force",
help = "Overwrite the destination `.torrent` file, if it exists."
)]
force: bool,
#[structopt( #[structopt(
name = "INPUT", name = "INPUT",
long = "input", long = "input",
@ -232,7 +238,19 @@ impl Create {
match &output { match &output {
Target::File(path) => { Target::File(path) => {
fs::write(path, &bytes).context(error::Filesystem { 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);
}
open_options
.open(path)
.and_then(|mut file| file.write_all(&bytes))
.context(error::Filesystem { path })?;
TorrentSummary::from_metainfo(metainfo)?.write(env)?; TorrentSummary::from_metainfo(metainfo)?.write(env)?;
if self.open { if self.open {
Platform::open(&path)?; Platform::open(&path)?;
@ -912,4 +930,28 @@ Content Size 0 bytes
let value = bencode::Value::decode(&bytes).unwrap(); let value = bencode::Value::decode(&bytes).unwrap();
assert!(matches!(value, bencode::Value::Dict(_))); assert!(matches!(value, bencode::Value::Dict(_)));
} }
#[test]
fn force_default() {
let mut env = environment(&["--input", "foo", "--announce", "http://bar"]);
fs::write(env.resolve("foo"), "").unwrap();
fs::write(env.resolve("foo.torrent"), "").unwrap();
assert_matches!(
env.run().unwrap_err(),
Error::Filesystem {source, path}
if path == env.resolve("foo.torrent") && source.kind() == io::ErrorKind::AlreadyExists
)
}
#[test]
fn force_true() {
let mut env = environment(&["--input", "foo", "--announce", "http://bar", "--force"]);
fs::write(env.resolve("foo"), "").unwrap();
fs::write(env.resolve("foo.torrent"), "foo").unwrap();
env.run().unwrap();
let torrent = env.resolve("foo.torrent");
let bytes = fs::read(torrent).unwrap();
let value = bencode::Value::decode(&bytes).unwrap();
assert!(matches!(value, bencode::Value::Dict(_)));
}
} }