mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-09 05:58:55 +00:00
cli: clean up .git directory if "jj git clone --colocate" failed
This commit is contained in:
parent
6625e91a4b
commit
97b6eb2684
2 changed files with 13 additions and 11 deletions
|
@ -1,11 +1,11 @@
|
|||
use std::collections::HashSet;
|
||||
use std::fs;
|
||||
use std::io::{Read, Write};
|
||||
use std::ops::Deref;
|
||||
use std::path::{Path, PathBuf};
|
||||
use std::process::{Command, Stdio};
|
||||
use std::sync::Mutex;
|
||||
use std::time::Instant;
|
||||
use std::{fs, io};
|
||||
|
||||
use clap::{ArgGroup, Subcommand};
|
||||
use itertools::Itertools;
|
||||
|
@ -418,13 +418,17 @@ fn cmd_git_clone(
|
|||
if clone_result.is_err() {
|
||||
// Canonicalize because fs::remove_dir_all() doesn't seem to like e.g.
|
||||
// `/some/path/.`
|
||||
if let Err(err) = fs::remove_dir_all(canonical_wc_path.join(".jj")).and_then(|_| {
|
||||
if !wc_path_existed {
|
||||
fs::remove_dir(&canonical_wc_path)
|
||||
} else {
|
||||
Ok(())
|
||||
let clean_up_dirs = || -> io::Result<()> {
|
||||
fs::remove_dir_all(canonical_wc_path.join(".jj"))?;
|
||||
if args.colocate {
|
||||
fs::remove_dir_all(canonical_wc_path.join(".git"))?;
|
||||
}
|
||||
}) {
|
||||
if !wc_path_existed {
|
||||
fs::remove_dir(&canonical_wc_path)?;
|
||||
}
|
||||
Ok(())
|
||||
};
|
||||
if let Err(err) = clean_up_dirs() {
|
||||
writeln!(
|
||||
ui.warning(),
|
||||
"Failed to clean up {}: {}",
|
||||
|
|
|
@ -219,11 +219,9 @@ fn test_git_clone_colocate() {
|
|||
Fetching into new repo in "$TEST_ENV/failed"
|
||||
"###);
|
||||
insta::assert_snapshot!(stderr, @r###"
|
||||
Failed to clean up $TEST_ENV/failed: Directory not empty (os error 39)
|
||||
Error: could not find repository from '$TEST_ENV/bad'; class=Repository (6)
|
||||
"###);
|
||||
// FIXME: assert!(!test_env.env_root().join("failed").exists());
|
||||
std::fs::remove_dir_all(test_env.env_root().join("failed")).unwrap();
|
||||
assert!(!test_env.env_root().join("failed").exists());
|
||||
|
||||
// Failed clone shouldn't remove the existing destination directory
|
||||
std::fs::create_dir(test_env.env_root().join("failed")).unwrap();
|
||||
|
@ -243,7 +241,7 @@ fn test_git_clone_colocate() {
|
|||
Error: could not find repository from '$TEST_ENV/bad'; class=Repository (6)
|
||||
"###);
|
||||
assert!(test_env.env_root().join("failed").exists());
|
||||
// FIXME: assert!(!test_env.env_root().join("failed").join(".git").exists());
|
||||
assert!(!test_env.env_root().join("failed").join(".git").exists());
|
||||
assert!(!test_env.env_root().join("failed").join(".jj").exists());
|
||||
|
||||
// Failed clone (if attempted) shouldn't remove the existing workspace
|
||||
|
|
Loading…
Reference in a new issue