894d9b2836
Since `modules/context` has to depend on `models` and many other packages, it should be moved from `modules/context` to `services/context` according to design principles. There is no logic code change on this PR, only move packages. - Move `code.gitea.io/gitea/modules/context` to `code.gitea.io/gitea/services/context` - Move `code.gitea.io/gitea/modules/contexttest` to `code.gitea.io/gitea/services/contexttest` because of depending on context - Move `code.gitea.io/gitea/modules/upload` to `code.gitea.io/gitea/services/context/upload` because of depending on context (cherry picked from commit 29f149bd9f517225a3c9f1ca3fb0a7b5325af696) Conflicts: routers/api/packages/alpine/alpine.go routers/api/v1/repo/issue_reaction.go routers/install/install.go routers/web/admin/config.go routers/web/passkey.go routers/web/repo/search.go routers/web/repo/setting/default_branch.go routers/web/user/home.go routers/web/user/profile.go tests/integration/editor_test.go tests/integration/integration_test.go tests/integration/mirror_push_test.go trivial context conflicts also modified all other occurrences in Forgejo specific files
116 lines
3.5 KiB
Go
116 lines
3.5 KiB
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package admin
|
|
|
|
import (
|
|
"testing"
|
|
|
|
activities_model "code.gitea.io/gitea/models/activities"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
"code.gitea.io/gitea/modules/test"
|
|
"code.gitea.io/gitea/services/contexttest"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestShadowPassword(t *testing.T) {
|
|
kases := []struct {
|
|
Provider string
|
|
CfgItem string
|
|
Result string
|
|
}{
|
|
{
|
|
Provider: "redis",
|
|
CfgItem: "network=tcp,addr=:6379,password=gitea,db=0,pool_size=100,idle_timeout=180",
|
|
Result: "network=tcp,addr=:6379,password=******,db=0,pool_size=100,idle_timeout=180",
|
|
},
|
|
{
|
|
Provider: "mysql",
|
|
CfgItem: "root:@tcp(localhost:3306)/gitea?charset=utf8",
|
|
Result: "root:******@tcp(localhost:3306)/gitea?charset=utf8",
|
|
},
|
|
{
|
|
Provider: "mysql",
|
|
CfgItem: "/gitea?charset=utf8",
|
|
Result: "/gitea?charset=utf8",
|
|
},
|
|
{
|
|
Provider: "mysql",
|
|
CfgItem: "user:mypassword@/dbname",
|
|
Result: "user:******@/dbname",
|
|
},
|
|
{
|
|
Provider: "postgres",
|
|
CfgItem: "user=pqgotest dbname=pqgotest sslmode=verify-full",
|
|
Result: "user=pqgotest dbname=pqgotest sslmode=verify-full",
|
|
},
|
|
{
|
|
Provider: "postgres",
|
|
CfgItem: "user=pqgotest password= dbname=pqgotest sslmode=verify-full",
|
|
Result: "user=pqgotest password=****** dbname=pqgotest sslmode=verify-full",
|
|
},
|
|
{
|
|
Provider: "postgres",
|
|
CfgItem: "postgres://user:pass@hostname/dbname",
|
|
Result: "postgres://user:******@hostname/dbname",
|
|
},
|
|
{
|
|
Provider: "couchbase",
|
|
CfgItem: "http://dev-couchbase.example.com:8091/",
|
|
Result: "http://dev-couchbase.example.com:8091/",
|
|
},
|
|
{
|
|
Provider: "couchbase",
|
|
CfgItem: "http://user:the_password@dev-couchbase.example.com:8091/",
|
|
Result: "http://user:******@dev-couchbase.example.com:8091/",
|
|
},
|
|
}
|
|
|
|
for _, k := range kases {
|
|
assert.EqualValues(t, k.Result, shadowPassword(k.Provider, k.CfgItem))
|
|
}
|
|
}
|
|
|
|
func TestMonitorStats(t *testing.T) {
|
|
unittest.PrepareTestEnv(t)
|
|
|
|
t.Run("Normal", func(t *testing.T) {
|
|
defer test.MockVariableValue(&setting.Metrics.EnabledIssueByLabel, false)()
|
|
defer test.MockVariableValue(&setting.Metrics.EnabledIssueByRepository, false)()
|
|
|
|
ctx, _ := contexttest.MockContext(t, "admin/stats")
|
|
MonitorStats(ctx)
|
|
|
|
// Test some of the stats manually.
|
|
mappedStats := ctx.Data["Stats"].(map[string]any)
|
|
stats := activities_model.GetStatistic(ctx).Counter
|
|
|
|
assert.EqualValues(t, stats.Comment, mappedStats["Comment"])
|
|
assert.EqualValues(t, stats.Issue, mappedStats["Issue"])
|
|
assert.EqualValues(t, stats.User, mappedStats["User"])
|
|
assert.EqualValues(t, stats.Milestone, mappedStats["Milestone"])
|
|
|
|
// Ensure that these aren't set.
|
|
assert.Empty(t, stats.IssueByLabel)
|
|
assert.Empty(t, stats.IssueByRepository)
|
|
assert.Nil(t, mappedStats["IssueByLabel"])
|
|
assert.Nil(t, mappedStats["IssueByRepository"])
|
|
})
|
|
|
|
t.Run("IssueByX", func(t *testing.T) {
|
|
defer test.MockVariableValue(&setting.Metrics.EnabledIssueByLabel, true)()
|
|
defer test.MockVariableValue(&setting.Metrics.EnabledIssueByRepository, true)()
|
|
|
|
ctx, _ := contexttest.MockContext(t, "admin/stats")
|
|
MonitorStats(ctx)
|
|
|
|
mappedStats := ctx.Data["Stats"].(map[string]any)
|
|
stats := activities_model.GetStatistic(ctx).Counter
|
|
|
|
assert.NotEmpty(t, stats.IssueByLabel)
|
|
assert.NotEmpty(t, stats.IssueByRepository)
|
|
assert.EqualValues(t, stats.IssueByLabel, mappedStats["IssueByLabel"])
|
|
assert.EqualValues(t, stats.IssueByRepository, mappedStats["IssueByRepository"])
|
|
})
|
|
}
|