1
0
mirror of https://github.com/go-gitea/gitea.git synced 2024-12-04 14:46:57 -05:00

Handle duplicated Co-authored-by entries

This commit is contained in:
Kemal Zebari 2024-05-13 23:12:19 -07:00
parent 8e3209b09a
commit fd0bf3b563
6 changed files with 92 additions and 0 deletions

View File

@ -153,6 +153,7 @@ func getExtendedCommitStats(repo *git.Repository, revision string /*, limit int
date := strings.TrimSpace(scanner.Text())
var coAuthors []*api.CommitUser
emailSet := map[string]bool{}
for scanner.Scan() {
line := scanner.Text()
if line == "" {
@ -163,6 +164,10 @@ func getExtendedCommitStats(repo *git.Repository, revision string /*, limit int
if err != nil {
continue
}
if _, exists := emailSet[coAuthorEmail]; exists {
continue
}
emailSet[coAuthorEmail] = true
coAuthor := &api.CommitUser{
Identity: api.Identity{Name: coAuthorName, Email: coAuthorEmail},
Date: date,

View File

@ -172,4 +172,88 @@ func TestRepository_ContributorsGraph(t *testing.T) {
},
}, data["total"])
})
t.Run("generate contributor stats with commit that has duplicate co-authored lines", func(t *testing.T) {
mockCache, err := cache.NewStringCache(setting.Cache{})
assert.NoError(t, err)
generateContributorStats(nil, mockCache, "key", repo, "branch-with-duplicated-co-author-entries")
var data map[string]*ContributorData
exist, _ := mockCache.GetJSON("key", &data)
assert.True(t, exist)
var keys []string
for k := range data {
keys = append(keys, k)
}
slices.Sort(keys)
assert.EqualValues(t, []string{
"ethantkoenig@gmail.com",
"fizzbuzz@example.com",
"foobar@example.com",
"jimmy.praet@telenet.be",
"jon@allspice.io",
"total",
}, keys)
// make sure we can see the author of the commit
assert.EqualValues(t, &ContributorData{
Name: "Foo Bar",
AvatarLink: "https://secure.gravatar.com/avatar/0d4907cea9d97688aa7a5e722d742f71?d=identicon",
TotalCommits: 1,
Weeks: map[int64]*WeekData{
1715472000000: {
Week: 1715472000000, // sunday 2024-05-12
Additions: 1,
Deletions: 0,
Commits: 1,
},
},
}, data["foobar@example.com"])
// make sure that we can also see the co-author and that we don't see duplicated additions/deletions/commits
assert.EqualValues(t, &ContributorData{
Name: "Fizz Buzz",
AvatarLink: "https://secure.gravatar.com/avatar/474e3516254f43b2337011c4ac4de421?d=identicon",
TotalCommits: 1,
Weeks: map[int64]*WeekData{
1715472000000: {
Week: 1715472000000, // sunday 2024-05-12
Additions: 1,
Deletions: 0,
Commits: 1,
},
},
}, data["fizzbuzz@example.com"])
// let's also make sure we don't duplicate the additions/deletions/commits counts in the overall stats that week
assert.EqualValues(t, &ContributorData{
Name: "Total",
AvatarLink: "",
TotalCommits: 4,
Weeks: map[int64]*WeekData{
1715472000000: {
Week: 1715472000000, // sunday 2024-05-12
Additions: 1,
Deletions: 0,
Commits: 1,
},
1511654400000: {
Week: 1511654400000, // sunday 2017-11-26
Additions: 3,
Deletions: 0,
Commits: 1,
},
1607817600000: {
Week: 1607817600000, // sunday 2020-12-13
Additions: 10,
Deletions: 0,
Commits: 1,
},
1624752000000: {
Week: 1624752000000, // sunday 2021-06-27
Additions: 2,
Deletions: 0,
Commits: 1,
},
},
}, data["total"])
})
}

View File

@ -0,0 +1 @@
xм▌мJд0┘]В)Н tHзФO┼ # ┌k7ННMnфbcJх─ЖИмЮй┘{7┤s|ПЫ°рRaф╩Z≤│)■▐йЙ╖╗▒╫fIч#] я &╚╖nцб╒(M$/┌СN╘Iз─д6ZОэ`╛╒цk}кн9ц л1gбrДOLшй÷сH#∙жй9 ╫╦AМmv∙ <sб^╧1 лО╥╣3<^.КxВ O9Я!┘╝{лЩ▐┤·╬НА╪Л;°╝-Фь*╣ЖкХ?ъМ╩▐

View File

@ -0,0 +1 @@
x+)JMU040g040031QðÈÏMÕËMa˜”*¼8<C2BC>_±—wŠÛÿøú*O¹UMÅP%9™y©zÅeé ÉS·õÉ¿Û-ç“Zí??{Qz† 7TMIjq‰^EnƒÚ§=kÍ9,Ümrzë;Åy<C385>cÛl˸*Ú

View File

@ -0,0 +1 @@
79a64f10ca2ea21fa2a94102751f0dd9f2c15ce8