aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCameron Braid <cameron@drivenow.com.au>2021-02-04 14:12:25 +1100
committerGitHub <noreply@github.com>2021-02-04 04:12:25 +0100
commit3c965c3e308a9399b6598e9d0f545f4e31fc578d (patch)
tree97ca058e88315ade3dbad9a14e1b3edd8079078a
parent87009ab40a905b6f7d267f71434fda2a32725c57 (diff)
downloadgitea-3c965c3e308a9399b6598e9d0f545f4e31fc578d.tar.gz
gitea-3c965c3e308a9399b6598e9d0f545f4e31fc578d.zip
[API] GetRelease by tag only return release (#14397)
get release by tag should filter out tag releases to be consistent with list releases and get by id Co-authored-by: 6543 <6543@obermui.de>
-rw-r--r--integrations/api_releases_test.go3
-rw-r--r--routers/api/v1/repo/release_tags.go9
2 files changed, 8 insertions, 4 deletions
diff --git a/integrations/api_releases_test.go b/integrations/api_releases_test.go
index 870d7d0e64..2b310d11e0 100644
--- a/integrations/api_releases_test.go
+++ b/integrations/api_releases_test.go
@@ -7,7 +7,6 @@ package integrations
import (
"fmt"
"net/http"
- "strings"
"testing"
"code.gitea.io/gitea/models"
@@ -152,7 +151,7 @@ func TestAPIGetReleaseByTag(t *testing.T) {
var err *api.APIError
DecodeJSON(t, resp, &err)
- assert.True(t, strings.HasPrefix(err.Message, "release tag does not exist"))
+ assert.EqualValues(t, "Not Found", err.Message)
}
func TestAPIDeleteTagByName(t *testing.T) {
diff --git a/routers/api/v1/repo/release_tags.go b/routers/api/v1/repo/release_tags.go
index ef07ce5e1a..70011a6a8e 100644
--- a/routers/api/v1/repo/release_tags.go
+++ b/routers/api/v1/repo/release_tags.go
@@ -48,14 +48,19 @@ func GetReleaseTag(ctx *context.APIContext) {
release, err := models.GetRelease(ctx.Repo.Repository.ID, tag)
if err != nil {
if models.IsErrReleaseNotExist(err) {
- ctx.Error(http.StatusNotFound, "GetRelease", err)
+ ctx.NotFound()
return
}
ctx.Error(http.StatusInternalServerError, "GetRelease", err)
return
}
- if err := release.LoadAttributes(); err != nil {
+ if release.IsTag {
+ ctx.NotFound()
+ return
+ }
+
+ if err = release.LoadAttributes(); err != nil {
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
return
}