fix release creation via API (#5076)
* fix release creation via API * fix release create tests
This commit is contained in:
parent
0cd8cecdf8
commit
970c690681
2 changed files with 98 additions and 2 deletions
|
@ -115,9 +115,9 @@ func createTag(gitRepo *git.Repository, rel *Release) error {
|
||||||
// Only actual create when publish.
|
// Only actual create when publish.
|
||||||
if !rel.IsDraft {
|
if !rel.IsDraft {
|
||||||
if !gitRepo.IsTagExist(rel.TagName) {
|
if !gitRepo.IsTagExist(rel.TagName) {
|
||||||
commit, err := gitRepo.GetBranchCommit(rel.Target)
|
commit, err := gitRepo.GetCommit(rel.Target)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("GetBranchCommit: %v", err)
|
return fmt.Errorf("GetCommit: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Trim '--' prefix to prevent command line argument vulnerability.
|
// Trim '--' prefix to prevent command line argument vulnerability.
|
||||||
|
|
96
models/release_test.go
Normal file
96
models/release_test.go
Normal file
|
@ -0,0 +1,96 @@
|
||||||
|
// Copyright 2018 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package models
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"code.gitea.io/git"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestRelease_Create(t *testing.T) {
|
||||||
|
assert.NoError(t, PrepareTestDatabase())
|
||||||
|
|
||||||
|
user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
||||||
|
repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
|
||||||
|
repoPath := RepoPath(user.Name, repo.Name)
|
||||||
|
|
||||||
|
gitRepo, err := git.OpenRepository(repoPath)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
|
||||||
|
assert.NoError(t, CreateRelease(gitRepo, &Release{
|
||||||
|
RepoID: repo.ID,
|
||||||
|
PublisherID: user.ID,
|
||||||
|
TagName: "v0.1",
|
||||||
|
Target: "master",
|
||||||
|
Title: "v0.1 is released",
|
||||||
|
Note: "v0.1 is released",
|
||||||
|
IsDraft: false,
|
||||||
|
IsPrerelease: false,
|
||||||
|
IsTag: false,
|
||||||
|
}, nil))
|
||||||
|
|
||||||
|
assert.NoError(t, CreateRelease(gitRepo, &Release{
|
||||||
|
RepoID: repo.ID,
|
||||||
|
PublisherID: user.ID,
|
||||||
|
TagName: "v0.1.1",
|
||||||
|
Target: "65f1bf27bc3bf70f64657658635e66094edbcb4d",
|
||||||
|
Title: "v0.1.1 is released",
|
||||||
|
Note: "v0.1.1 is released",
|
||||||
|
IsDraft: false,
|
||||||
|
IsPrerelease: false,
|
||||||
|
IsTag: false,
|
||||||
|
}, nil))
|
||||||
|
|
||||||
|
assert.NoError(t, CreateRelease(gitRepo, &Release{
|
||||||
|
RepoID: repo.ID,
|
||||||
|
PublisherID: user.ID,
|
||||||
|
TagName: "v0.1.2",
|
||||||
|
Target: "65f1bf2",
|
||||||
|
Title: "v0.1.2 is released",
|
||||||
|
Note: "v0.1.2 is released",
|
||||||
|
IsDraft: false,
|
||||||
|
IsPrerelease: false,
|
||||||
|
IsTag: false,
|
||||||
|
}, nil))
|
||||||
|
|
||||||
|
assert.NoError(t, CreateRelease(gitRepo, &Release{
|
||||||
|
RepoID: repo.ID,
|
||||||
|
PublisherID: user.ID,
|
||||||
|
TagName: "v0.1.3",
|
||||||
|
Target: "65f1bf2",
|
||||||
|
Title: "v0.1.3 is released",
|
||||||
|
Note: "v0.1.3 is released",
|
||||||
|
IsDraft: true,
|
||||||
|
IsPrerelease: false,
|
||||||
|
IsTag: false,
|
||||||
|
}, nil))
|
||||||
|
|
||||||
|
assert.NoError(t, CreateRelease(gitRepo, &Release{
|
||||||
|
RepoID: repo.ID,
|
||||||
|
PublisherID: user.ID,
|
||||||
|
TagName: "v0.1.4",
|
||||||
|
Target: "65f1bf2",
|
||||||
|
Title: "v0.1.4 is released",
|
||||||
|
Note: "v0.1.4 is released",
|
||||||
|
IsDraft: false,
|
||||||
|
IsPrerelease: true,
|
||||||
|
IsTag: false,
|
||||||
|
}, nil))
|
||||||
|
|
||||||
|
assert.NoError(t, CreateRelease(gitRepo, &Release{
|
||||||
|
RepoID: repo.ID,
|
||||||
|
PublisherID: user.ID,
|
||||||
|
TagName: "v0.1.5",
|
||||||
|
Target: "65f1bf2",
|
||||||
|
Title: "v0.1.5 is released",
|
||||||
|
Note: "v0.1.5 is released",
|
||||||
|
IsDraft: false,
|
||||||
|
IsPrerelease: false,
|
||||||
|
IsTag: true,
|
||||||
|
}, nil))
|
||||||
|
}
|
Reference in a new issue