2019-06-08 08:31:11 -06:00
|
|
|
// 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 integrations
|
|
|
|
|
|
|
|
import (
|
2021-02-07 11:32:18 -07:00
|
|
|
"fmt"
|
2019-06-08 08:31:11 -06:00
|
|
|
"net/http"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"code.gitea.io/gitea/models"
|
2021-11-16 01:53:21 -07:00
|
|
|
"code.gitea.io/gitea/models/unittest"
|
2019-06-08 08:31:11 -06:00
|
|
|
"code.gitea.io/gitea/modules/git"
|
|
|
|
api "code.gitea.io/gitea/modules/structs"
|
|
|
|
"code.gitea.io/gitea/modules/util"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAPIGitTags(t *testing.T) {
|
2019-11-25 16:21:37 -07:00
|
|
|
defer prepareTestEnv(t)()
|
2021-11-16 01:53:21 -07:00
|
|
|
user := unittest.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
|
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
|
2019-06-08 08:31:11 -06:00
|
|
|
// Login as User2.
|
|
|
|
session := loginUser(t, user.Name)
|
|
|
|
token := getTokenForLoggedInUser(t, session)
|
|
|
|
|
|
|
|
// Set up git config for the tagger
|
|
|
|
git.NewCommand("config", "user.name", user.Name).RunInDir(repo.RepoPath())
|
|
|
|
git.NewCommand("config", "user.email", user.Email).RunInDir(repo.RepoPath())
|
|
|
|
|
|
|
|
gitRepo, _ := git.OpenRepository(repo.RepoPath())
|
2019-11-13 00:01:19 -07:00
|
|
|
defer gitRepo.Close()
|
|
|
|
|
2019-06-08 08:31:11 -06:00
|
|
|
commit, _ := gitRepo.GetBranchCommit("master")
|
|
|
|
lTagName := "lightweightTag"
|
|
|
|
gitRepo.CreateTag(lTagName, commit.ID.String())
|
|
|
|
|
|
|
|
aTagName := "annotatedTag"
|
|
|
|
aTagMessage := "my annotated message"
|
|
|
|
gitRepo.CreateAnnotatedTag(aTagName, aTagMessage, commit.ID.String())
|
|
|
|
aTag, _ := gitRepo.GetTag(aTagName)
|
|
|
|
|
|
|
|
// SHOULD work for annotated tags
|
|
|
|
req := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/git/tags/%s?token=%s", user.Name, repo.Name, aTag.ID.String(), token)
|
|
|
|
res := session.MakeRequest(t, req, http.StatusOK)
|
|
|
|
|
|
|
|
var tag *api.AnnotatedTag
|
|
|
|
DecodeJSON(t, res, &tag)
|
|
|
|
|
|
|
|
assert.Equal(t, aTagName, tag.Tag)
|
|
|
|
assert.Equal(t, aTag.ID.String(), tag.SHA)
|
|
|
|
assert.Equal(t, commit.ID.String(), tag.Object.SHA)
|
2020-12-22 13:44:25 -07:00
|
|
|
assert.Equal(t, aTagMessage+"\n", tag.Message)
|
2019-06-08 08:31:11 -06:00
|
|
|
assert.Equal(t, user.Name, tag.Tagger.Name)
|
|
|
|
assert.Equal(t, user.Email, tag.Tagger.Email)
|
|
|
|
assert.Equal(t, util.URLJoin(repo.APIURL(), "git/tags", aTag.ID.String()), tag.URL)
|
|
|
|
|
|
|
|
// Should NOT work for lightweight tags
|
|
|
|
badReq := NewRequestf(t, "GET", "/api/v1/repos/%s/%s/git/tags/%s?token=%s", user.Name, repo.Name, commit.ID.String(), token)
|
|
|
|
session.MakeRequest(t, badReq, http.StatusBadRequest)
|
|
|
|
}
|
2021-02-07 11:32:18 -07:00
|
|
|
|
|
|
|
func TestAPIDeleteTagByName(t *testing.T) {
|
|
|
|
defer prepareTestEnv(t)()
|
|
|
|
|
2021-11-16 01:53:21 -07:00
|
|
|
repo := unittest.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
|
|
|
|
owner := unittest.AssertExistsAndLoadBean(t, &models.User{ID: repo.OwnerID}).(*models.User)
|
2021-02-07 11:32:18 -07:00
|
|
|
session := loginUser(t, owner.LowerName)
|
|
|
|
token := getTokenForLoggedInUser(t, session)
|
|
|
|
|
|
|
|
urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/tags/delete-tag?token=%s",
|
|
|
|
owner.Name, repo.Name, token)
|
|
|
|
|
|
|
|
req := NewRequestf(t, http.MethodDelete, urlStr)
|
|
|
|
_ = session.MakeRequest(t, req, http.StatusNoContent)
|
|
|
|
|
|
|
|
// Make sure that actual releases can't be deleted outright
|
|
|
|
createNewReleaseUsingAPI(t, session, token, owner, repo, "release-tag", "", "Release Tag", "test")
|
|
|
|
urlStr = fmt.Sprintf("/api/v1/repos/%s/%s/tags/release-tag?token=%s",
|
|
|
|
owner.Name, repo.Name, token)
|
|
|
|
|
|
|
|
req = NewRequestf(t, http.MethodDelete, urlStr)
|
|
|
|
_ = session.MakeRequest(t, req, http.StatusConflict)
|
|
|
|
}
|