]> source.dussan.org Git - gitea.git/commitdiff
fix bug when push a branch name with / & fix an integration test bug (#1689)
authorLunny Xiao <xiaolunwen@gmail.com>
Mon, 8 May 2017 02:55:27 +0000 (10:55 +0800)
committerBo-Yi Wu <appleboy.tw@gmail.com>
Mon, 8 May 2017 02:55:27 +0000 (10:55 +0800)
integrations/integration_test.go
integrations/internal_test.go [new file with mode: 0644]
routers/private/branch.go
routers/private/internal.go

index 6696ff65fcfe171133af0815f55f92a9565b5116..4a809403bda240a8f1d33a10fd622db13f05a1a2 100644 (file)
@@ -94,11 +94,12 @@ func initIntegrationTest() {
                if err != nil {
                        log.Fatalf("db.Query: %v", err)
                }
-               if rows.Next() {
-                       break // database already exists
-               }
-               if _, err = db.Exec("CREATE DATABASE testgitea"); err != nil {
-                       log.Fatalf("db.Exec: %v", err)
+               defer rows.Close()
+
+               if !rows.Next() {
+                       if _, err = db.Exec("CREATE DATABASE testgitea"); err != nil {
+                               log.Fatalf("db.Exec: %v", err)
+                       }
                }
        }
        routers.GlobalInit()
diff --git a/integrations/internal_test.go b/integrations/internal_test.go
new file mode 100644 (file)
index 0000000..12d6fc8
--- /dev/null
@@ -0,0 +1,45 @@
+// Copyright 2017 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 (
+       "encoding/json"
+       "fmt"
+       "net/http"
+       "net/url"
+       "testing"
+
+       "code.gitea.io/gitea/models"
+       "code.gitea.io/gitea/modules/setting"
+
+       "github.com/stretchr/testify/assert"
+)
+
+func assertProtectedBranch(t *testing.T, repoID int64, branchName string, isErr, canPush bool) {
+       reqURL := fmt.Sprintf("/api/internal/branch/%d/%s", repoID, url.QueryEscape(branchName))
+       req, err := http.NewRequest("GET", reqURL, nil)
+       t.Log(reqURL)
+       req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", setting.InternalToken))
+
+       assert.NoError(t, err)
+       resp := MakeRequest(req)
+       if isErr {
+               assert.EqualValues(t, 500, resp.HeaderCode)
+       } else {
+               assert.EqualValues(t, http.StatusOK, resp.HeaderCode)
+               var branch models.ProtectedBranch
+               t.Log(string(resp.Body))
+               assert.NoError(t, json.Unmarshal(resp.Body, &branch))
+               assert.Equal(t, canPush, branch.CanPush)
+       }
+}
+
+func TestInternal_GetProtectedBranch(t *testing.T) {
+       prepareTestEnv(t)
+
+       assertProtectedBranch(t, 1, "master", false, true)
+       assertProtectedBranch(t, 1, "dev", false, true)
+       assertProtectedBranch(t, 1, "lunny/dev", false, true)
+}
index e74087950ec432332217ae70273451decba4d5dc..8e42f730392c8c215f0177fd51647b29ecc21699 100644 (file)
@@ -13,7 +13,7 @@ import (
 // GetProtectedBranchBy get protected branch information
 func GetProtectedBranchBy(ctx *macaron.Context) {
        repoID := ctx.ParamsInt64(":id")
-       branchName := ctx.Params(":branch")
+       branchName := ctx.Params("*")
        protectBranch, err := models.GetProtectedBranchBy(repoID, branchName)
        if err != nil {
                ctx.JSON(500, map[string]interface{}{
index f663306e92e94101e603a09d6f38286a93056e4b..3e7233226a7234c0b2d7b913d51e5f962ae3f61e 100644 (file)
@@ -42,6 +42,6 @@ func RegisterRoutes(m *macaron.Macaron) {
        m.Group("/", func() {
                m.Post("/ssh/:id/update", UpdatePublicKey)
                m.Post("/push/update", PushUpdate)
-               m.Get("/branch/:id/:branch", GetProtectedBranchBy)
+               m.Get("/branch/:id/*", GetProtectedBranchBy)
        }, CheckInternalToken)
 }