diff options
author | Joey Hess <joeyh@joeyh.name> | 2016-10-11 14:22:49 -0400 |
---|---|---|
committer | Joey Hess <joeyh@joeyh.name> | 2016-10-11 14:22:49 -0400 |
commit | ce72696171a0bf212dfc8f40a5c6b875bf7e7692 (patch) | |
tree | 7e54f78829b08b06da84215d503c4733cfc908b1 | |
parent | 5d85a812205db3cbfb23ce47a38f35e773d299d8 (diff) |
add test case for sync_in_adjusted_branch_deleted_recently_added_files
This commit was sponsored by Denis Dzyubenko on Patreon.
-rw-r--r-- | Test.hs | 22 | ||||
-rw-r--r-- | doc/bugs/sync_in_adjusted_branch_deleted_recently_added_files.mdwn | 12 |
2 files changed, 32 insertions, 2 deletions
@@ -234,6 +234,7 @@ unitTests note = testGroup ("Unit Tests " ++ note) , testCase "sync" test_sync , testCase "union merge regression" test_union_merge_regression , testCase "adjusted branch merge regression" test_adjusted_branch_merge_regression + , testCase "adjusted branch subtree regression" test_adjusted_branch_subtree_regression , testCase "conflict resolution" test_conflict_resolution , testCase "conflict resolution (adjusted branch)" test_conflict_resolution_adjusted_branch , testCase "conflict resolution movein regression" test_conflict_resolution_movein_regression @@ -1425,6 +1426,27 @@ test_adjusted_branch_merge_regression = whenM Annex.AdjustedBranch.isGitVersionS conflictor `elem` l @? ("conflictor not present after merge in " ++ what) +{- Regression test for a bug in adjusted branch syncing code, where adding + - a subtree to an existing tree lost files. -} +test_adjusted_branch_subtree_regression :: Assertion +test_adjusted_branch_subtree_regression = + whenM Annex.AdjustedBranch.isGitVersionSupported $ + withtmpclonerepo $ \r -> do + indir r $ do + disconnectOrigin + git_annex "upgrade" [] @? "upgrade failed" + git_annex "adjust" ["--unlock", "--force"] @? "adjust failed" + createDirectoryIfMissing True "a/b/c" + writeFile "a/b/c/d" "foo" + git_annex "add" ["a/b/c"] @? "add a/b/c failed" + git_annex "sync" [] @? "sync failed" + createDirectoryIfMissing True "a/b/x" + writeFile "a/b/x/y" "foo" + git_annex "add" ["a/b/x"] @? "add a/b/x failed" + git_annex "sync" [] @? "sync failed" + boolSystem "git" [Param "checkout", Param "master"] @? "git checkout master failed" + doesFileExist "a/b/x/y" @? ("a/b/x/y missing from master after adjusted branch sync") + {- Set up repos as remotes of each other. -} pair :: FilePath -> FilePath -> Assertion pair r1 r2 = forM_ [r1, r2] $ \r -> indir r $ do diff --git a/doc/bugs/sync_in_adjusted_branch_deleted_recently_added_files.mdwn b/doc/bugs/sync_in_adjusted_branch_deleted_recently_added_files.mdwn index ce271d8dd..4681cbe48 100644 --- a/doc/bugs/sync_in_adjusted_branch_deleted_recently_added_files.mdwn +++ b/doc/bugs/sync_in_adjusted_branch_deleted_recently_added_files.mdwn @@ -64,8 +64,7 @@ tree items, but it can forget that it needed to modify the tree, which prevents the change from propigating up from the subtree to the root, and so it gets left out of the reverse adjusted commit. -I'm committing a fix, but this needs a test case. Leaving bug open for -that. +I'm committing a fix. With the fix, when I git annex sync in felix's tree, the files that were getting wrongly deleted are added. The commit summary shows @@ -77,4 +76,13 @@ This seems wrong. I think this is a separate bug that was hidden by the other one, it's grafting in files using their whole path, to a subtree that is itself part way down that path. +--- + +A simpler case of the both bugs is to have a file like a/b/c/d already +committed and make a commit that adds a/b/x/y, without otherwise modifying +that tree. On an adjusted branch, `git annex sync` makes a commit of a tree +that does not include the new file. It may made a commit on top of it for +the adjusted branch that adds the file back, but the file doesn't reach +the master branch in this scenario. + --[[Joey]] |