parent
3d91bb2f2d
commit
ecefa9e724
@ -0,0 +1,32 @@ |
||||
// Copyright 2019 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" |
||||
) |
||||
|
||||
func TestAPIReposGitCommits(t *testing.T) { |
||||
prepareTestEnv(t) |
||||
user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User) |
||||
// Login as User2.
|
||||
session := loginUser(t, user.Name) |
||||
token := getTokenForLoggedInUser(t, session) |
||||
|
||||
for _, ref := range [...]string{ |
||||
"commits/master", // Branch
|
||||
"commits/v1.1", // Tag
|
||||
} { |
||||
req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo1/git/%s?token="+token, user.Name, ref) |
||||
session.MakeRequest(t, req, http.StatusOK) |
||||
} |
||||
|
||||
// Test getting non-existent refs
|
||||
req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo1/git/commits/unknown?token="+token, user.Name) |
||||
session.MakeRequest(t, req, http.StatusNotFound) |
||||
} |
@ -0,0 +1,119 @@ |
||||
// Copyright 2018 The Gogs Authors. All rights reserved.
|
||||
// Copyright 2019 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 repo |
||||
|
||||
import ( |
||||
"time" |
||||
|
||||
"code.gitea.io/git" |
||||
api "code.gitea.io/sdk/gitea" |
||||
|
||||
"code.gitea.io/gitea/models" |
||||
"code.gitea.io/gitea/modules/context" |
||||
"code.gitea.io/gitea/modules/setting" |
||||
) |
||||
|
||||
// GetSingleCommit get a commit via
|
||||
func GetSingleCommit(ctx *context.APIContext) { |
||||
// swagger:operation GET /repos/{owner}/{repo}/git/commits/{sha} repository repoGetSingleCommit
|
||||
// ---
|
||||
// summary: Get a single commit from a repository
|
||||
// produces:
|
||||
// - application/json
|
||||
// parameters:
|
||||
// - name: owner
|
||||
// in: path
|
||||
// description: owner of the repo
|
||||
// type: string
|
||||
// required: true
|
||||
// - name: repo
|
||||
// in: path
|
||||
// description: name of the repo
|
||||
// type: string
|
||||
// required: true
|
||||
// - name: sha
|
||||
// in: path
|
||||
// description: the commit hash
|
||||
// type: string
|
||||
// required: true
|
||||
// responses:
|
||||
// "200":
|
||||
// "$ref": "#/responses/Commit"
|
||||
// "404":
|
||||
// "$ref": "#/responses/notFound"
|
||||
|
||||
gitRepo, err := git.OpenRepository(ctx.Repo.Repository.RepoPath()) |
||||
if err != nil { |
||||
ctx.ServerError("OpenRepository", err) |
||||
return |
||||
} |
||||
commit, err := gitRepo.GetCommit(ctx.Params(":sha")) |
||||
if err != nil { |
||||
ctx.NotFoundOrServerError("GetCommit", git.IsErrNotExist, err) |
||||
return |
||||
} |
||||
|
||||
// Retrieve author and committer information
|
||||
var apiAuthor, apiCommitter *api.User |
||||
author, err := models.GetUserByEmail(commit.Author.Email) |
||||
if err != nil && !models.IsErrUserNotExist(err) { |
||||
ctx.ServerError("Get user by author email", err) |
||||
return |
||||
} else if err == nil { |
||||
apiAuthor = author.APIFormat() |
||||
} |
||||
// Save one query if the author is also the committer
|
||||
if commit.Committer.Email == commit.Author.Email { |
||||
apiCommitter = apiAuthor |
||||
} else { |
||||
committer, err := models.GetUserByEmail(commit.Committer.Email) |
||||
if err != nil && !models.IsErrUserNotExist(err) { |
||||
ctx.ServerError("Get user by committer email", err) |
||||
return |
||||
} else if err == nil { |
||||
apiCommitter = committer.APIFormat() |
||||
} |
||||
} |
||||
|
||||
// Retrieve parent(s) of the commit
|
||||
apiParents := make([]*api.CommitMeta, commit.ParentCount()) |
||||
for i := 0; i < commit.ParentCount(); i++ { |
||||
sha, _ := commit.ParentID(i) |
||||
apiParents[i] = &api.CommitMeta{ |
||||
URL: ctx.Repo.Repository.APIURL() + "/git/commits/" + sha.String(), |
||||
SHA: sha.String(), |
||||
} |
||||
} |
||||
|
||||
ctx.JSON(200, &api.Commit{ |
||||
CommitMeta: &api.CommitMeta{ |
||||
URL: setting.AppURL + ctx.Link[1:], |
||||
SHA: commit.ID.String(), |
||||
}, |
||||
HTMLURL: ctx.Repo.Repository.HTMLURL() + "/commits/" + commit.ID.String(), |
||||
RepoCommit: &api.RepoCommit{ |
||||
URL: setting.AppURL + ctx.Link[1:], |
||||
Author: &api.CommitUser{ |
||||
Name: commit.Author.Name, |
||||
Email: commit.Author.Email, |
||||
Date: commit.Author.When.Format(time.RFC3339), |
||||
}, |
||||
Committer: &api.CommitUser{ |
||||
Name: commit.Committer.Name, |
||||
Email: commit.Committer.Email, |
||||
Date: commit.Committer.When.Format(time.RFC3339), |
||||
}, |
||||
Message: commit.Summary(), |
||||
Tree: &api.CommitMeta{ |
||||
URL: ctx.Repo.Repository.APIURL() + "/trees/" + commit.ID.String(), |
||||
SHA: commit.ID.String(), |
||||
}, |
||||
}, |
||||
Author: apiAuthor, |
||||
Committer: apiCommitter, |
||||
Parents: apiParents, |
||||
}) |
||||
} |
Loading…
Reference in new issue