Skip to content
This repository has been archived by the owner on Sep 11, 2020. It is now read-only.

Commit

Permalink
Merge pull request #1088 from oleksii-shnyra/fix-1074
Browse files Browse the repository at this point in the history
plumbing: object, Count stats properly when no new line added at the …
  • Loading branch information
mcuadros committed Apr 18, 2019
2 parents 829edc9 + f69d206 commit cc5579e
Show file tree
Hide file tree
Showing 2 changed files with 87 additions and 2 deletions.
78 changes: 78 additions & 0 deletions plumbing/object/commit_stats_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
package object_test

import (
"time"

"gopkg.in/src-d/go-git.v4"
"gopkg.in/src-d/go-git.v4/plumbing"
"gopkg.in/src-d/go-git.v4/plumbing/object"
"gopkg.in/src-d/go-git.v4/storage/memory"

. "gopkg.in/check.v1"
"gopkg.in/src-d/go-billy.v4/memfs"
"gopkg.in/src-d/go-billy.v4/util"
"gopkg.in/src-d/go-git-fixtures.v3"
)

type CommitStatsSuite struct {
fixtures.Suite
}

var _ = Suite(&CommitStatsSuite{})

func (s *CommitStatsSuite) TestStats(c *C) {
r, hash := s.writeHisotry(c, []byte("foo\n"), []byte("foo\nbar\n"))

aCommit, err := r.CommitObject(hash)
c.Assert(err, IsNil)

fileStats, err := aCommit.Stats()
c.Assert(err, IsNil)

c.Assert(fileStats[0].Name, Equals, "foo")
c.Assert(fileStats[0].Addition, Equals, 1)
c.Assert(fileStats[0].Deletion, Equals, 0)
c.Assert(fileStats[0].String(), Equals, " foo | 1 +\n")
}

func (s *CommitStatsSuite) TestStats_WithoutNewLine(c *C) {
r, hash := s.writeHisotry(c, []byte("foo\nbar"), []byte("foo\nbar\n"))

aCommit, err := r.CommitObject(hash)
c.Assert(err, IsNil)

fileStats, err := aCommit.Stats()
c.Assert(err, IsNil)

c.Assert(fileStats[0].Name, Equals, "foo")
c.Assert(fileStats[0].Addition, Equals, 1)
c.Assert(fileStats[0].Deletion, Equals, 1)
c.Assert(fileStats[0].String(), Equals, " foo | 2 +-\n")
}

func (s *CommitStatsSuite) writeHisotry(c *C, files ...[]byte) (*git.Repository, plumbing.Hash) {
cm := &git.CommitOptions{
Author: &object.Signature{Name: "Foo", Email: "foo@example.local", When: time.Now()},
}

fs := memfs.New()
r, err := git.Init(memory.NewStorage(), fs)
c.Assert(err, IsNil)

w, err := r.Worktree()
c.Assert(err, IsNil)

var hash plumbing.Hash
for _, content := range files {
util.WriteFile(fs, "foo", content, 0644)

_, err = w.Add("foo")
c.Assert(err, IsNil)

hash, err = w.Commit("foo\n", cm)
c.Assert(err, IsNil)

}

return r, hash
}
11 changes: 9 additions & 2 deletions plumbing/object/patch.go
Original file line number Diff line number Diff line change
Expand Up @@ -320,11 +320,18 @@ func getFileStatsFromFilePatches(filePatches []fdiff.FilePatch) FileStats {
}

for _, chunk := range fp.Chunks() {
s := chunk.Content()
switch chunk.Type() {
case fdiff.Add:
cs.Addition += strings.Count(chunk.Content(), "\n")
cs.Addition += strings.Count(s, "\n")
if s[len(s)-1] != '\n' {
cs.Addition++
}
case fdiff.Delete:
cs.Deletion += strings.Count(chunk.Content(), "\n")
cs.Deletion += strings.Count(s, "\n")
if s[len(s)-1] != '\n' {
cs.Deletion++
}
}
}

Expand Down

0 comments on commit cc5579e

Please sign in to comment.