summaryrefslogtreecommitdiffstats
path: root/integrations
diff options
context:
space:
mode:
Diffstat (limited to 'integrations')
-rw-r--r--integrations/benchmarks_test.go113
-rw-r--r--integrations/repo_branch_test.go2
-rw-r--r--integrations/repo_migrate_test.go26
3 files changed, 114 insertions, 27 deletions
diff --git a/integrations/benchmarks_test.go b/integrations/benchmarks_test.go
new file mode 100644
index 0000000000..7c4196f2b9
--- /dev/null
+++ b/integrations/benchmarks_test.go
@@ -0,0 +1,113 @@
+// 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 (
+ "math/rand"
+ "net/http"
+ "testing"
+
+ "code.gitea.io/gitea/models"
+ api "code.gitea.io/sdk/gitea"
+)
+
+func BenchmarkRepo(b *testing.B) {
+ samples := []struct {
+ url string
+ name string
+ skipShort bool
+ }{
+ {url: "https://github.com/go-gitea/gitea.git", name: "gitea"},
+ {url: "https://github.com/ethantkoenig/manyfiles.git", name: "manyfiles"},
+ {url: "https://github.com/moby/moby.git", name: "moby", skipShort: true},
+ {url: "https://github.com/golang/go.git", name: "go", skipShort: true},
+ {url: "https://github.com/torvalds/linux.git", name: "linux", skipShort: true},
+ }
+ prepareTestEnv(b)
+ session := loginUser(b, "user2")
+ b.ResetTimer()
+
+ for _, s := range samples {
+ b.Run(s.name, func(b *testing.B) {
+ if testing.Short() && s.skipShort {
+ b.Skip("skipping test in short mode.")
+ }
+ b.Run("Migrate", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ testRepoMigrate(b, session, s.url, s.name)
+ }
+ })
+ b.Run("Access", func(b *testing.B) {
+ var branches []*api.Branch
+ b.Run("APIBranchList", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ req := NewRequestf(b, "GET", "/api/v1/repos/%s/%s/branches", "user2", s.name)
+ resp := session.MakeRequest(b, req, http.StatusOK)
+ b.StopTimer()
+ if len(branches) == 0 {
+ DecodeJSON(b, resp, &branches) //Store for next phase
+ }
+ b.StartTimer()
+ }
+ })
+ branchCount := len(branches)
+ b.Run("WebViewCommit", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ req := NewRequestf(b, "GET", "/%s/%s/commit/%s", "user2", s.name, branches[i%branchCount].Commit.ID)
+ session.MakeRequest(b, req, http.StatusOK)
+ }
+ })
+ })
+ })
+ }
+}
+
+//StringWithCharset random string (from https://www.calhoun.io/creating-random-strings-in-go/)
+func StringWithCharset(length int, charset string) string {
+ b := make([]byte, length)
+ for i := range b {
+ b[i] = charset[rand.Intn(len(charset))]
+ }
+ return string(b)
+}
+
+func BenchmarkRepoBranchCommit(b *testing.B) {
+ samples := []int64{1, 3, 15, 16}
+ prepareTestEnv(b)
+ b.ResetTimer()
+
+ for _, repoID := range samples {
+ b.StopTimer()
+ repo := models.AssertExistsAndLoadBean(b, &models.Repository{ID: repoID}).(*models.Repository)
+ b.StartTimer()
+ b.Run(repo.Name, func(b *testing.B) {
+ owner := models.AssertExistsAndLoadBean(b, &models.User{ID: repo.OwnerID}).(*models.User)
+ session := loginUser(b, owner.LoginName)
+ b.ResetTimer()
+ b.Run("Create", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ b.StopTimer()
+ branchName := StringWithCharset(5+rand.Intn(10), "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789")
+ b.StartTimer()
+ testCreateBranch(b, session, owner.LoginName, repo.Name, "branch/master", branchName, http.StatusFound)
+ }
+ })
+ b.Run("Access", func(b *testing.B) {
+ var branches []*api.Branch
+ req := NewRequestf(b, "GET", "/api/v1/%s/branches", repo.FullName())
+ resp := session.MakeRequest(b, req, http.StatusOK)
+ DecodeJSON(b, resp, &branches)
+ branchCount := len(branches)
+ b.ResetTimer() //We measure from here
+ for i := 0; i < b.N; i++ {
+ req := NewRequestf(b, "GET", "/%s/%s/commits/%s", owner.Name, repo.Name, branches[i%branchCount])
+ session.MakeRequest(b, req, http.StatusOK)
+ }
+ })
+ })
+ }
+}
+
+//TODO list commits /repos/{owner}/{repo}/commits
diff --git a/integrations/repo_branch_test.go b/integrations/repo_branch_test.go
index c20fd6192c..fb33778cde 100644
--- a/integrations/repo_branch_test.go
+++ b/integrations/repo_branch_test.go
@@ -16,7 +16,7 @@ import (
"github.com/stretchr/testify/assert"
)
-func testCreateBranch(t *testing.T, session *TestSession, user, repo, oldRefSubURL, newBranchName string, expectedStatus int) string {
+func testCreateBranch(t testing.TB, session *TestSession, user, repo, oldRefSubURL, newBranchName string, expectedStatus int) string {
var csrf string
if expectedStatus == http.StatusNotFound {
csrf = GetCSRF(t, session, path.Join(user, repo, "src/branch/master"))
diff --git a/integrations/repo_migrate_test.go b/integrations/repo_migrate_test.go
index 9f41cca827..41791c1d0b 100644
--- a/integrations/repo_migrate_test.go
+++ b/integrations/repo_migrate_test.go
@@ -40,29 +40,3 @@ func TestRepoMigrate(t *testing.T) {
session := loginUser(t, "user2")
testRepoMigrate(t, session, "https://github.com/go-gitea/git.git", "git")
}
-
-func BenchmarkRepoMigrate(b *testing.B) {
- samples := []struct {
- url string
- name string
- }{
- {url: "https://github.com/go-gitea/gitea.git", name: "gitea"},
- {url: "https://github.com/ethantkoenig/manyfiles.git", name: "manyfiles"},
- {url: "https://github.com/moby/moby.git", name: "moby"},
- {url: "https://github.com/golang/go.git", name: "go"},
- {url: "https://github.com/torvalds/linux.git", name: "linux"},
- }
-
- prepareTestEnv(b)
- session := loginUser(b, "user2")
- b.ResetTimer()
-
- for _, s := range samples {
- b.Run(s.name, func(b *testing.B) {
- for i := 0; i < b.N; i++ {
- testRepoMigrate(b, session, s.url, s.name)
- }
-
- })
- }
-}