diff options
author | wxiaoguang <wxiaoguang@gmail.com> | 2023-08-03 17:18:06 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-03 09:18:06 +0000 |
commit | 539015403f80326d662e31cf9d3a459b3efefcd7 (patch) | |
tree | 8738c457c8f245aeae2201157d2a5f44fafe6125 /models | |
parent | cad22512b8948fa52e1684ec30bb5a6e5d427d5f (diff) | |
download | gitea-539015403f80326d662e31cf9d3a459b3efefcd7.tar.gz gitea-539015403f80326d662e31cf9d3a459b3efefcd7.zip |
Fix the topic validation rule and suport dots (#26286)
1. Allow leading and trailing spaces by user input, these spaces have
already been trimmed at backend
2. Allow using dots in the topic
Diffstat (limited to 'models')
-rw-r--r-- | models/repo/topic.go | 2 | ||||
-rw-r--r-- | models/repo/topic_test.go | 2 |
2 files changed, 3 insertions, 1 deletions
diff --git a/models/repo/topic.go b/models/repo/topic.go index ec3de869d5..71302388b9 100644 --- a/models/repo/topic.go +++ b/models/repo/topic.go @@ -22,7 +22,7 @@ func init() { db.RegisterModel(new(RepoTopic)) } -var topicPattern = regexp.MustCompile(`^[a-z0-9][a-z0-9-]*$`) +var topicPattern = regexp.MustCompile(`^[a-z0-9][-.a-z0-9]*$`) // Topic represents a topic of repositories type Topic struct { diff --git a/models/repo/topic_test.go b/models/repo/topic_test.go index 8a8728168d..aaed91bdd3 100644 --- a/models/repo/topic_test.go +++ b/models/repo/topic_test.go @@ -69,6 +69,7 @@ func TestAddTopic(t *testing.T) { 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")) @@ -77,4 +78,5 @@ func TestTopicValidator(t *testing.T) { 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")) } |