mirror of
https://github.com/go-gitea/gitea.git
synced 2025-10-24 00:54:42 +02:00
Backport #30127 by @lunny This also fixed #22238 Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
83 lines
2.7 KiB
Go
83 lines
2.7 KiB
Go
// Copyright 2018 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package repo_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
repo_model "code.gitea.io/gitea/models/repo"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestAddTopic(t *testing.T) {
|
|
totalNrOfTopics := 6
|
|
repo1NrOfTopics := 3
|
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
topics, err := db.Find[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, totalNrOfTopics)
|
|
|
|
topics, total, err := db.FindAndCount[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{
|
|
ListOptions: db.ListOptions{Page: 1, PageSize: 2},
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, 2)
|
|
assert.EqualValues(t, 6, total)
|
|
|
|
topics, err = db.Find[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{
|
|
RepoID: 1,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, repo1NrOfTopics)
|
|
|
|
assert.NoError(t, repo_model.SaveTopics(db.DefaultContext, 2, "golang"))
|
|
repo2NrOfTopics := 1
|
|
topics, err = db.Find[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, totalNrOfTopics)
|
|
|
|
topics, err = db.Find[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{
|
|
RepoID: 2,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, repo2NrOfTopics)
|
|
|
|
assert.NoError(t, repo_model.SaveTopics(db.DefaultContext, 2, "golang", "gitea"))
|
|
repo2NrOfTopics = 2
|
|
totalNrOfTopics++
|
|
topic, err := repo_model.GetTopicByName(db.DefaultContext, "gitea")
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 1, topic.RepoCount)
|
|
|
|
topics, err = db.Find[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, totalNrOfTopics)
|
|
|
|
topics, err = db.Find[repo_model.Topic](db.DefaultContext, &repo_model.FindTopicOptions{
|
|
RepoID: 2,
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, topics, repo2NrOfTopics)
|
|
}
|
|
|
|
func TestTopicValidator(t *testing.T) {
|
|
assert.True(t, repo_model.ValidateTopic("12345"))
|
|
assert.True(t, repo_model.ValidateTopic("2-test"))
|
|
assert.True(t, repo_model.ValidateTopic("foo.bar"))
|
|
assert.True(t, repo_model.ValidateTopic("test-3"))
|
|
assert.True(t, repo_model.ValidateTopic("first"))
|
|
assert.True(t, repo_model.ValidateTopic("second-test-topic"))
|
|
assert.True(t, repo_model.ValidateTopic("third-project-topic-with-max-length"))
|
|
|
|
assert.False(t, repo_model.ValidateTopic("$fourth-test,topic"))
|
|
assert.False(t, repo_model.ValidateTopic("-fifth-test-topic"))
|
|
assert.False(t, repo_model.ValidateTopic("sixth-go-project-topic-with-excess-length"))
|
|
assert.False(t, repo_model.ValidateTopic(".foo"))
|
|
}
|