Skip to content

Commit

Permalink
git: migrate import_refs() to diffing git_refs and known remote refs
Browse files Browse the repository at this point in the history
  • Loading branch information
yuja committed Oct 9, 2023
1 parent 6e052ea commit 4d7f65e
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 28 deletions.
22 changes: 3 additions & 19 deletions cli/tests/test_git_import_export.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,8 +143,9 @@ fn test_git_import_undo() {
a: qpvuntsm 230dd059 (empty) (no description set)
"###);

// If we don't restore the git_refs, undoing the import removes the local branch
// but makes a following import a no-op.
// Even if we don't restore the git_refs, "git import" can re-import the
// local branch "a".
// TODO: This will be the default "op restore" mode.
let stdout = test_env.jj_cmd_success(
&repo_path,
&[
Expand All @@ -158,23 +159,6 @@ fn test_git_import_undo() {
insta::assert_snapshot!(stdout, @r###"
"###);
insta::assert_snapshot!(get_branch_output(&test_env, &repo_path), @"");
// Try "git import" again, which should *not* re-import the branch "a" and be a
// no-op.
insta::assert_snapshot!(test_env.jj_cmd_success(&repo_path, &["git", "import"]), @r###"
Nothing changed.
"###);
insta::assert_snapshot!(get_branch_output(&test_env, &repo_path), @"");

// We can restore *only* the git refs to make an import re-import the branch
let stdout = test_env.jj_cmd_success(
&repo_path,
&["op", "restore", &base_operation_id, "--what=git-tracking"],
);
insta::assert_snapshot!(stdout, @r###"
"###);
// The git-tracking branch disappears.
insta::assert_snapshot!(get_branch_output(&test_env, &repo_path), @"");
// Try "git import" again, which should again re-import the branch "a".
insta::assert_snapshot!(test_env.jj_cmd_success(&repo_path, &["git", "import"]), @"");
insta::assert_snapshot!(get_branch_output(&test_env, &repo_path), @r###"
a: qpvuntsm 230dd059 (empty) (no description set)
Expand Down
32 changes: 23 additions & 9 deletions lib/src/git.rs
Original file line number Diff line number Diff line change
Expand Up @@ -340,15 +340,29 @@ fn diff_refs_to_import(
git_ref_filter(&ref_name).then_some((full_name.as_ref(), target))
})
.collect();
let mut known_remote_refs: HashMap<RefName, &RefTarget> = view
.git_refs()
.iter()
.filter_map(|(full_name, target)| {
// TODO: or clean up invalid ref in case it was stored due to historical bug?
let ref_name = parse_git_ref(full_name).expect("stored git ref should be parsable");
git_ref_filter(&ref_name).then_some((ref_name, target))
})
.collect();
let mut known_remote_refs: HashMap<RefName, &RefTarget> = itertools::chain(
view.remote_branches().map(|((branch, remote), target)| {
// TODO: want to abstract local ref as "git" tracking remote, but
// we'll probably need to refactor the git_ref_filter API first.
let ref_name = if remote == REMOTE_NAME_FOR_LOCAL_GIT_REPO {
RefName::LocalBranch(branch.to_owned())
} else {
RefName::RemoteBranch {
branch: branch.to_owned(),
remote: remote.to_owned(),
}
};
(ref_name, target)
}),
// TODO: compare to tags stored in the "git" remote view. Since tags should never
// be moved locally in jj, we can consider local tags as merge base.
view.tags().iter().map(|(name, target)| {
let ref_name = RefName::Tag(name.to_owned());
(ref_name, target)
}),
)
.filter(|(ref_name, _)| git_ref_filter(ref_name))
.collect();
let mut changed_git_refs = Vec::new();
let mut changed_remote_refs = BTreeMap::new();
for git_ref in git_repo.references()? {
Expand Down

0 comments on commit 4d7f65e

Please sign in to comment.