aboutsummaryrefslogtreecommitdiffstats
path: root/plumbing/object/rename_test.go
diff options
context:
space:
mode:
authorMáximo Cuadros <mcuadros@gmail.com>2020-05-04 09:42:02 +0200
committerGitHub <noreply@github.com>2020-05-04 09:42:02 +0200
commit79798d4a85b9389b28ef26b70944157d16fc205a (patch)
tree848a70f42abc28f125109d9ec3412993810e7b5a /plumbing/object/rename_test.go
parent8543c83ab70a33834b90df74fef7f398791fb4ae (diff)
parent8cdf70ac123b26d2234014bce344332f9b0787b3 (diff)
downloadgo-git-79798d4a85b9389b28ef26b70944157d16fc205a.tar.gz
Merge pull request #54 from go-git/fix/rename-exact-gaps
plumbing: exact renames detection could leave gaps in the changes
Diffstat (limited to 'plumbing/object/rename_test.go')
-rw-r--r--plumbing/object/rename_test.go26
1 files changed, 26 insertions, 0 deletions
diff --git a/plumbing/object/rename_test.go b/plumbing/object/rename_test.go
index bf5044d..5dd77e8 100644
--- a/plumbing/object/rename_test.go
+++ b/plumbing/object/rename_test.go
@@ -271,6 +271,32 @@ func (s *RenameSuite) TestRenameLimit(c *C) {
}
}
+func (s *RenameSuite) TestRenameExactManyAddsManyDeletesNoGaps(c *C) {
+ content := "a"
+ detector := &renameDetector{
+ added: []*Change{
+ makeAdd(c, makeFile(c, pathA, filemode.Regular, content)),
+ makeAdd(c, makeFile(c, pathQ, filemode.Regular, content)),
+ makeAdd(c, makeFile(c, "something", filemode.Regular, content)),
+ },
+ deleted: []*Change{
+ makeDelete(c, makeFile(c, pathA, filemode.Regular, content)),
+ makeDelete(c, makeFile(c, pathB, filemode.Regular, content)),
+ makeDelete(c, makeFile(c, "foo/bar/other", filemode.Regular, content)),
+ },
+ }
+
+ detector.detectExactRenames()
+
+ for _, added := range detector.added {
+ c.Assert(added, NotNil)
+ }
+
+ for _, deleted := range detector.deleted {
+ c.Assert(deleted, NotNil)
+ }
+}
+
func detectRenames(c *C, changes Changes, opts *DiffTreeOptions, expectedResults int) Changes {
result, err := DetectRenames(changes, opts)
c.Assert(err, IsNil)