* Fixes #2738 - /git/tags API * proper URLs * Adds function comments * Updates swagger * Removes newline from tag message * Removes trailing newline from commit message * Adds integration test * Removed debugging * Adds tests * Fixes bug where multiple tags of same commit show wrong tag name * Fix formatting * Removes unused varaible * Fix to annotated tag function names and response * Update modules/git/repo_tag.go Co-Authored-By: Lauris BH <lauris@nix.lv> * Uses TagPrefix * Changes per review, better error handling for getting tag and commit IDs * Fix to getting commit ID * Fix to getting commit ID * Fix to getting commit ID * Fix to getting commit IDtokarchuk/v1.17
parent
23a2ee3510
commit
8de0b0a3f0
@ -0,0 +1,59 @@ |
|||||||
|
// 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 ( |
||||||
|
"net/http" |
||||||
|
"testing" |
||||||
|
|
||||||
|
"code.gitea.io/gitea/models" |
||||||
|
"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) { |
||||||
|
prepareTestEnv(t) |
||||||
|
user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User) |
||||||
|
repo := models.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository) |
||||||
|
// 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()) |
||||||
|
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) |
||||||
|
assert.Equal(t, aTagMessage, tag.Message) |
||||||
|
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) |
||||||
|
} |
Loading…
Reference in new issue