Skip to content

Commit 783b196

Browse files
lafrikslunny
authored andcommitted
Fix release display and correct paging (#2080)
1 parent 33f3165 commit 783b196

File tree

5 files changed

+135
-39
lines changed

5 files changed

+135
-39
lines changed

integrations/release_test.go

Lines changed: 93 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -5,12 +5,60 @@
55
package integrations
66

77
import (
8+
"fmt"
89
"net/http"
910
"testing"
1011

12+
"github.com/Unknwon/i18n"
1113
"github.com/stretchr/testify/assert"
1214
)
1315

16+
func createNewRelease(t *testing.T, session *TestSession, repoURL, tag, title string, preRelease, draft bool) {
17+
req := NewRequest(t, "GET", repoURL+"/releases/new")
18+
resp := session.MakeRequest(t, req)
19+
assert.EqualValues(t, http.StatusOK, resp.HeaderCode)
20+
htmlDoc := NewHTMLParser(t, resp.Body)
21+
22+
link, exists := htmlDoc.doc.Find("form").Attr("action")
23+
assert.True(t, exists, "The template has changed")
24+
25+
postData := map[string]string{
26+
"_csrf": htmlDoc.GetCSRF(),
27+
"tag_name": tag,
28+
"tag_target": "master",
29+
"title": title,
30+
"content": "",
31+
}
32+
if preRelease {
33+
postData["prerelease"] = "on"
34+
}
35+
if draft {
36+
postData["draft"] = "Save Draft"
37+
}
38+
req = NewRequestWithValues(t, "POST", link, postData)
39+
40+
resp = session.MakeRequest(t, req)
41+
assert.EqualValues(t, http.StatusFound, resp.HeaderCode)
42+
43+
redirectedURL := resp.Headers["Location"]
44+
assert.NotEmpty(t, redirectedURL, "Redirected URL is not found")
45+
}
46+
47+
func checkLatestReleaseAndCount(t *testing.T, session *TestSession, repoURL, version, label string, count int) {
48+
req := NewRequest(t, "GET", repoURL+"/releases")
49+
resp := session.MakeRequest(t, req)
50+
assert.EqualValues(t, http.StatusOK, resp.HeaderCode)
51+
52+
htmlDoc := NewHTMLParser(t, resp.Body)
53+
labelText := htmlDoc.doc.Find("#release-list > li .meta .label").First().Text()
54+
assert.EqualValues(t, label, labelText)
55+
titleText := htmlDoc.doc.Find("#release-list > li .detail h3 a").First().Text()
56+
assert.EqualValues(t, version, titleText)
57+
58+
releaseList := htmlDoc.doc.Find("#release-list > li")
59+
assert.EqualValues(t, count, releaseList.Length())
60+
}
61+
1462
func TestViewReleases(t *testing.T) {
1563
prepareTestEnv(t)
1664

@@ -27,3 +75,48 @@ func TestViewReleasesNoLogin(t *testing.T) {
2775
resp := MakeRequest(req)
2876
assert.EqualValues(t, http.StatusOK, resp.HeaderCode)
2977
}
78+
79+
func TestCreateRelease(t *testing.T) {
80+
prepareTestEnv(t)
81+
82+
session := loginUser(t, "user2")
83+
createNewRelease(t, session, "/user2/repo1", "v0.0.1", "v0.0.1", false, false)
84+
85+
checkLatestReleaseAndCount(t, session, "/user2/repo1", "v0.0.1", i18n.Tr("en", "repo.release.stable"), 1)
86+
}
87+
88+
func TestCreateReleasePreRelease(t *testing.T) {
89+
prepareTestEnv(t)
90+
91+
session := loginUser(t, "user2")
92+
createNewRelease(t, session, "/user2/repo1", "v0.0.1", "v0.0.1", true, false)
93+
94+
checkLatestReleaseAndCount(t, session, "/user2/repo1", "v0.0.1", i18n.Tr("en", "repo.release.prerelease"), 1)
95+
}
96+
97+
func TestCreateReleaseDraft(t *testing.T) {
98+
prepareTestEnv(t)
99+
100+
session := loginUser(t, "user2")
101+
createNewRelease(t, session, "/user2/repo1", "v0.0.1", "v0.0.1", false, true)
102+
103+
checkLatestReleaseAndCount(t, session, "/user2/repo1", "v0.0.1", i18n.Tr("en", "repo.release.draft"), 1)
104+
}
105+
106+
func TestCreateReleasePaging(t *testing.T) {
107+
prepareTestEnv(t)
108+
109+
session := loginUser(t, "user2")
110+
// Create enaugh releases to have paging
111+
for i := 0; i < 12; i++ {
112+
version := fmt.Sprintf("v0.0.%d", i)
113+
createNewRelease(t, session, "/user2/repo1", version, version, false, false)
114+
}
115+
createNewRelease(t, session, "/user2/repo1", "v0.0.12", "v0.0.12", false, true)
116+
117+
checkLatestReleaseAndCount(t, session, "/user2/repo1", "v0.0.12", i18n.Tr("en", "repo.release.draft"), 10)
118+
119+
// Check that user3 does not see draft and still see 10 latest releases
120+
session2 := loginUser(t, "user3")
121+
checkLatestReleaseAndCount(t, session2, "/user2/repo1", "v0.0.11", i18n.Tr("en", "repo.release.stable"), 10)
122+
}

models/fixtures/release.yml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
[] # empty

models/release.go

Lines changed: 26 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -233,40 +233,44 @@ func GetReleaseByID(id int64) (*Release, error) {
233233
return rel, nil
234234
}
235235

236-
// GetReleasesByRepoID returns a list of releases of repository.
237-
func GetReleasesByRepoID(repoID int64, page, pageSize int) (rels []*Release, err error) {
238-
if page <= 0 {
239-
page = 1
240-
}
241-
err = x.
242-
Desc("created_unix").
243-
Limit(pageSize, (page-1)*pageSize).
244-
Find(&rels, Release{RepoID: repoID})
245-
return rels, err
236+
// FindReleasesOptions describes the conditions to Find releases
237+
type FindReleasesOptions struct {
238+
IncludeDrafts bool
239+
TagNames []string
246240
}
247241

248-
// GetReleaseCountByRepoID returns the count of releases of repository
249-
func GetReleaseCountByRepoID(repoID int64, includeDrafts bool) (int64, error) {
242+
func (opts *FindReleasesOptions) toConds(repoID int64) builder.Cond {
250243
var cond = builder.NewCond()
251244
cond = cond.And(builder.Eq{"repo_id": repoID})
252245

253-
if includeDrafts {
254-
return x.Where(cond).Count(&Release{})
246+
if !opts.IncludeDrafts {
247+
cond = cond.And(builder.Eq{"is_draft": false})
255248
}
256-
257-
cond = cond.And(builder.Eq{"is_draft": false})
258-
return x.Where(cond).Count(&Release{})
249+
if len(opts.TagNames) > 0 {
250+
cond = cond.And(builder.In("tag_name", opts.TagNames))
251+
}
252+
return cond
259253
}
260254

261-
// GetReleasesByRepoIDAndNames returns a list of releases of repository according repoID and tagNames.
262-
func GetReleasesByRepoIDAndNames(repoID int64, tagNames []string) (rels []*Release, err error) {
255+
// GetReleasesByRepoID returns a list of releases of repository.
256+
func GetReleasesByRepoID(repoID int64, opts FindReleasesOptions, page, pageSize int) (rels []*Release, err error) {
257+
if page <= 0 {
258+
page = 1
259+
}
260+
263261
err = x.
264-
Desc("created_unix").
265-
In("tag_name", tagNames).
266-
Find(&rels, Release{RepoID: repoID})
262+
Desc("created_unix", "id").
263+
Limit(pageSize, (page-1)*pageSize).
264+
Where(opts.toConds(repoID)).
265+
Find(&rels)
267266
return rels, err
268267
}
269268

269+
// GetReleaseCountByRepoID returns the count of releases of repository
270+
func GetReleaseCountByRepoID(repoID int64, opts FindReleasesOptions) (int64, error) {
271+
return x.Where(opts.toConds(repoID)).Count(&Release{})
272+
}
273+
270274
type releaseMetaSearch struct {
271275
ID []int64
272276
Rel []*Release

routers/api/v1/repo/release.go

Lines changed: 8 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -34,22 +34,21 @@ func GetRelease(ctx *context.APIContext) {
3434

3535
// ListReleases list a repository's releases
3636
func ListReleases(ctx *context.APIContext) {
37-
releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, 1, 2147483647)
37+
access, err := models.AccessLevel(ctx.User.ID, ctx.Repo.Repository)
3838
if err != nil {
39-
ctx.Error(500, "GetReleasesByRepoID", err)
39+
ctx.Error(500, "AccessLevel", err)
4040
return
4141
}
42-
rels := make([]*api.Release, len(releases))
43-
access, err := models.AccessLevel(ctx.User.ID, ctx.Repo.Repository)
42+
43+
releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, models.FindReleasesOptions{
44+
IncludeDrafts: access >= models.AccessModeWrite,
45+
}, 1, 2147483647)
4446
if err != nil {
45-
ctx.Error(500, "AccessLevel", err)
47+
ctx.Error(500, "GetReleasesByRepoID", err)
4648
return
4749
}
50+
rels := make([]*api.Release, len(releases))
4851
for i, release := range releases {
49-
if release.IsDraft && access < models.AccessModeWrite {
50-
// hide drafts from users without push access
51-
continue
52-
}
5352
if err := release.LoadAttributes(); err != nil {
5453
ctx.Error(500, "LoadAttributes", err)
5554
return

routers/repo/release.go

Lines changed: 7 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -65,13 +65,17 @@ func Releases(ctx *context.Context) {
6565
limit = 10
6666
}
6767

68-
releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, page, limit)
68+
opts := models.FindReleasesOptions{
69+
IncludeDrafts: ctx.Repo.IsWriter(),
70+
}
71+
72+
releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, opts, page, limit)
6973
if err != nil {
7074
ctx.Handle(500, "GetReleasesByRepoID", err)
7175
return
7276
}
7377

74-
count, err := models.GetReleaseCountByRepoID(ctx.Repo.Repository.ID, ctx.Repo.IsOwner())
78+
count, err := models.GetReleaseCountByRepoID(ctx.Repo.Repository.ID, opts)
7579
if err != nil {
7680
ctx.Handle(500, "GetReleaseCountByRepoID", err)
7781
return
@@ -91,11 +95,7 @@ func Releases(ctx *context.Context) {
9195
}
9296
var ok bool
9397

94-
releasesToDisplay := make([]*models.Release, 0, len(releases))
9598
for _, r := range releases {
96-
if r.IsDraft && !ctx.Repo.IsOwner() {
97-
continue
98-
}
9999
if r.Publisher, ok = cacheUsers[r.PublisherID]; !ok {
100100
r.Publisher, err = models.GetUserByID(r.PublisherID)
101101
if err != nil {
@@ -113,12 +113,11 @@ func Releases(ctx *context.Context) {
113113
return
114114
}
115115
r.Note = markdown.RenderString(r.Note, ctx.Repo.RepoLink, ctx.Repo.Repository.ComposeMetas())
116-
releasesToDisplay = append(releasesToDisplay, r)
117116
}
118117

119118
pager := paginater.New(int(count), limit, page, 5)
120119
ctx.Data["Page"] = pager
121-
ctx.Data["Releases"] = releasesToDisplay
120+
ctx.Data["Releases"] = releases
122121
ctx.HTML(200, tplReleases)
123122
}
124123

0 commit comments

Comments
 (0)