From: "Elijah Newren via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: "Elijah Newren" <newren@gmail.com>,
"Jonathan Tan" <jonathantanmy@google.com>,
"Calvin Wan" <calvinwan@google.com>,
"Ævar Arnfjörð Bjarmason" <avarab@gmail.com>,
"Elijah Newren" <newren@gmail.com>
Subject: [PATCH v3 0/5] Fix dual rename into each other plus conflicting adds
Date: Fri, 01 Jul 2022 05:23:15 +0000 [thread overview]
Message-ID: <pull.1268.v3.git.1656653000.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.1268.v2.git.1656572225.gitgitgadget@gmail.com>
This series adds some testcases based on the tensorflow repository issue
reported by Glen Choo at [1], demonstrating bugs in both the ort and
recursive strategies. It also provides a fix for the ort strategy.
Changes since v2:
* Added a couple preparatory cleanup patches
* Added a comment about why sub1/newfile is important to the new testcases
* A couple other minor code cleanups
Changes since v1:
* Fixed some wording issues in comments, and added a bit more details to
one of the commit messages
[1]
https://lore.kernel.org/git/kl6lee006mle.fsf@chooglen-macbookpro.roam.corp.google.com/
Elijah Newren (5):
t6423: add tests of dual directory rename plus add/add conflict
merge-ort: small cleanups of check_for_directory_rename
merge-ort: make a separate function for freeing struct collisions
merge-ort: shuffle the computation and cleanup of potential collisions
merge-ort: fix issue with dual rename and add/add conflict
merge-ort.c | 74 +++++++++++++-------
t/t6423-merge-rename-directories.sh | 105 ++++++++++++++++++++++++++++
2 files changed, 153 insertions(+), 26 deletions(-)
base-commit: e54793a95afeea1e10de1e5ad7eab914e7416250
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1268%2Fnewren%2Ffix-dual-rename-into-each-other-plus-conflicting-adds-v3
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1268/newren/fix-dual-rename-into-each-other-plus-conflicting-adds-v3
Pull-Request: https://github.com/gitgitgadget/git/pull/1268
Range-diff vs v2:
1: bf4c03d01d5 ! 1: a16a1c4d947 t6423: add tests of dual directory rename plus add/add conflict
@@ t/t6423-merge-rename-directories.sh: test_expect_success '12k: Directory rename
+#
+# Expected: sub3/{file, newfile, sub2/other}
+# CONFLICT (add/add): sub1/sub2/new_add_add_file
++#
++# Note that sub1/newfile is not extraneous. Directory renames are only
++# detected if they are needed, and they are only needed if the old directory
++# had a new file added on the opposite side of history. So sub1/newfile
++# is needed for there to be a sub1/ -> sub3/ rename.
+
+test_setup_12l () {
+ test_create_repo 12l_$1 &&
+ (
+ cd 12l_$1 &&
+
-+ mkdir -p sub1 sub2
++ mkdir sub1 sub2
+ echo file >sub1/file &&
+ echo other >sub2/other &&
+ git add sub1 sub2 &&
@@ t/t6423-merge-rename-directories.sh: test_expect_success '12k: Directory rename
+
+ test_must_fail git -c merge.directoryRenames=true merge -s recursive B^0 &&
+
-+ git ls-files -s >out &&
-+ test_line_count = 5 out &&
++ test_stdout_line_count = 5 git ls-files -s &&
+
+ git rev-parse >actual \
+ :0:sub3/file :0:sub3/newfile :0:sub3/sub2/other \
@@ t/t6423-merge-rename-directories.sh: test_expect_success '12k: Directory rename
+ test_cmp expect actual &&
+
+ git ls-files -o >actual &&
-+ test_write_lines actual expect out >expect &&
++ test_write_lines actual expect >expect &&
+ test_cmp expect actual
+ )
+'
@@ t/t6423-merge-rename-directories.sh: test_expect_success '12k: Directory rename
+
+ test_must_fail git -c merge.directoryRenames=true merge -s recursive A^0 &&
+
-+ git ls-files -s >out &&
-+ test_line_count = 5 out &&
++ test_stdout_line_count = 5 git ls-files -s &&
+
+ git rev-parse >actual \
+ :0:sub3/file :0:sub3/newfile :0:sub3/sub2/other \
@@ t/t6423-merge-rename-directories.sh: test_expect_success '12k: Directory rename
+ test_cmp expect actual &&
+
+ git ls-files -o >actual &&
-+ test_write_lines actual expect out >expect &&
++ test_write_lines actual expect >expect &&
+ test_cmp expect actual
+ )
+'
-: ----------- > 2: 297fef60b19 merge-ort: small cleanups of check_for_directory_rename
-: ----------- > 3: f5f87acbbd2 merge-ort: make a separate function for freeing struct collisions
2: cfa38f01481 ! 4: d3eac3d0bf6 merge-ort: shuffle the computation and cleanup of potential collisions
@@ Commit message
Signed-off-by: Elijah Newren <newren@gmail.com>
## merge-ort.c ##
-@@ merge-ort.c: static void compute_collisions(struct strmap *collisions,
- }
- }
-
-+static void free_collisions(struct strmap *collisions)
-+{
-+ struct hashmap_iter iter;
-+ struct strmap_entry *entry;
-+
-+ /* Free each value in the collisions map */
-+ strmap_for_each_entry(collisions, &iter, entry) {
-+ struct collision_info *info = entry->value;
-+ string_list_clear(&info->source_files, 0);
-+ }
-+ /*
-+ * In compute_collisions(), we set collisions.strdup_strings to 0
-+ * so that we wouldn't have to make another copy of the new_path
-+ * allocated by apply_dir_rename(). But now that we've used them
-+ * and have no other references to these strings, it is time to
-+ * deallocate them.
-+ */
-+ free_strmap_strings(collisions);
-+ strmap_clear(collisions, 1);
-+}
-+
- static char *check_for_directory_rename(struct merge_options *opt,
- const char *path,
- unsigned side_index,
@@ merge-ort.c: static char *check_for_directory_rename(struct merge_options *opt,
}
@@ merge-ort.c: static int detect_regular_renames(struct merge_options *opt,
int i, clean = 1;
- struct strmap collisions;
struct diff_queue_struct *side_pairs;
-- struct hashmap_iter iter;
-- struct strmap_entry *entry;
struct rename_info *renames = &opt->priv->renames;
side_pairs = &renames->pairs[side_index];
@@ merge-ort.c: static int collect_renames(struct merge_options *opt,
result->queue[result->nr++] = p;
}
-- /* Free each value in the collisions map */
-- strmap_for_each_entry(&collisions, &iter, entry) {
-- struct collision_info *info = entry->value;
-- string_list_clear(&info->source_files, 0);
-- }
-- /*
-- * In compute_collisions(), we set collisions.strdup_strings to 0
-- * so that we wouldn't have to make another copy of the new_path
-- * allocated by apply_dir_rename(). But now that we've used them
-- * and have no other references to these strings, it is time to
-- * deallocate them.
-- */
-- free_strmap_strings(&collisions);
-- strmap_clear(&collisions, 1);
+- free_collisions(&collisions);
return clean;
}
3: da3ae38e390 ! 5: 121761e26e2 merge-ort: fix issue with dual rename and add/add conflict
@@ Commit message
## merge-ort.c ##
@@ merge-ort.c: static char *check_for_directory_rename(struct merge_options *opt,
struct strmap_entry *rename_info;
- struct strmap_entry *otherinfo = NULL;
+ struct strmap_entry *otherinfo;
const char *new_dir;
+ int other_side = 3 - side_index;
+- /* Cases where we don't have a directory rename for this path */
+ /*
+ * Cases where we don't have or don't want a directory rename for
-+ * this path, so we return NULL.
++ * this path.
+ */
if (strmap_empty(dir_renames))
- return new_path;
+ return NULL;
+ if (strmap_get(&collisions[other_side], path))
-+ return new_path;
++ return NULL;
rename_info = check_dir_renamed(path, dir_renames);
if (!rename_info)
- return new_path;
+ return NULL;
## t/t6423-merge-rename-directories.sh ##
@@ t/t6423-merge-rename-directories.sh: test_setup_12l () {
--
gitgitgadget
next prev parent reply other threads:[~2022-07-01 5:23 UTC|newest]
Thread overview: 45+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-22 4:20 [PATCH 0/3] Fix dual rename into each other plus conflicting adds Elijah Newren via GitGitGadget
2022-06-22 4:20 ` [PATCH 1/3] t6423: add tests of dual directory rename plus add/add conflict Elijah Newren via GitGitGadget
2022-06-27 18:20 ` Jonathan Tan
2022-06-30 0:06 ` Elijah Newren
2022-06-30 22:32 ` Jonathan Tan
2022-07-01 2:57 ` Elijah Newren
2022-06-27 22:30 ` Calvin Wan
2022-06-30 0:07 ` Elijah Newren
2022-06-22 4:20 ` [PATCH 2/3] merge-ort: shuffle the computation and cleanup of potential collisions Elijah Newren via GitGitGadget
2022-06-27 18:48 ` Jonathan Tan
2022-06-27 21:04 ` Calvin Wan
2022-06-30 0:05 ` Elijah Newren
2022-06-22 4:20 ` [PATCH 3/3] merge-ort: fix issue with dual rename and add/add conflict Elijah Newren via GitGitGadget
2022-06-27 18:47 ` Jonathan Tan
2022-06-30 0:05 ` Elijah Newren
2022-07-06 17:25 ` Jonathan Tan
2022-06-22 4:36 ` [PATCH 0/3] Fix dual rename into each other plus conflicting adds Elijah Newren
2022-06-30 6:57 ` [PATCH v2 " Elijah Newren via GitGitGadget
2022-06-30 6:57 ` [PATCH v2 1/3] t6423: add tests of dual directory rename plus add/add conflict Elijah Newren via GitGitGadget
2022-06-30 10:21 ` Ævar Arnfjörð Bjarmason
2022-07-01 2:57 ` Elijah Newren
2022-07-01 9:29 ` Ævar Arnfjörð Bjarmason
2022-06-30 6:57 ` [PATCH v2 2/3] merge-ort: shuffle the computation and cleanup of potential collisions Elijah Newren via GitGitGadget
2022-06-30 10:28 ` Ævar Arnfjörð Bjarmason
2022-07-01 3:02 ` Elijah Newren
2022-06-30 6:57 ` [PATCH v2 3/3] merge-ort: fix issue with dual rename and add/add conflict Elijah Newren via GitGitGadget
2022-06-30 10:31 ` Ævar Arnfjörð Bjarmason
2022-07-01 3:03 ` Elijah Newren
2022-07-01 5:23 ` Elijah Newren via GitGitGadget [this message]
2022-07-01 5:23 ` [PATCH v3 1/5] t6423: add tests of dual directory rename plus " Elijah Newren via GitGitGadget
2022-07-01 5:23 ` [PATCH v3 2/5] merge-ort: small cleanups of check_for_directory_rename Elijah Newren via GitGitGadget
2022-07-01 5:23 ` [PATCH v3 3/5] merge-ort: make a separate function for freeing struct collisions Elijah Newren via GitGitGadget
2022-07-01 5:23 ` [PATCH v3 4/5] merge-ort: shuffle the computation and cleanup of potential collisions Elijah Newren via GitGitGadget
2022-07-01 9:16 ` Ævar Arnfjörð Bjarmason
2022-07-25 12:00 ` C99 "for (int ..." form on "master" (was: [PATCH v3 4/5] merge-ort: shuffle the computation and cleanup of potential collisions) Ævar Arnfjörð Bjarmason
2022-07-26 2:14 ` Elijah Newren
2022-07-26 4:48 ` C99 "for (int ..." form on "master" Junio C Hamano
2022-07-01 5:23 ` [PATCH v3 5/5] merge-ort: fix issue with dual rename and add/add conflict Elijah Newren via GitGitGadget
2022-07-05 1:33 ` [PATCH v4 0/5] Fix dual rename into each other plus conflicting adds Elijah Newren via GitGitGadget
2022-07-05 1:33 ` [PATCH v4 1/5] t6423: add tests of dual directory rename plus add/add conflict Elijah Newren via GitGitGadget
2022-07-05 1:33 ` [PATCH v4 2/5] merge-ort: small cleanups of check_for_directory_rename Elijah Newren via GitGitGadget
2022-07-05 1:33 ` [PATCH v4 3/5] merge-ort: make a separate function for freeing struct collisions Elijah Newren via GitGitGadget
2022-07-05 1:33 ` [PATCH v4 4/5] merge-ort: shuffle the computation and cleanup of potential collisions Elijah Newren via GitGitGadget
2022-07-05 1:33 ` [PATCH v4 5/5] merge-ort: fix issue with dual rename and add/add conflict Elijah Newren via GitGitGadget
2022-07-06 16:52 ` [PATCH v4 0/5] Fix dual rename into each other plus conflicting adds Junio C Hamano
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pull.1268.v3.git.1656653000.gitgitgadget@gmail.com \
--to=gitgitgadget@gmail.com \
--cc=avarab@gmail.com \
--cc=calvinwan@google.com \
--cc=git@vger.kernel.org \
--cc=jonathantanmy@google.com \
--cc=newren@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.