summaryrefslogtreecommitdiffstats
path: root/models
diff options
context:
space:
mode:
authormrsdizzie <info@mrsdizzie.com>2019-07-14 10:48:51 -0400
committerLunny Xiao <xiaolunwen@gmail.com>2019-07-14 22:48:51 +0800
commitfb0c562f8ba32804c5d025abe23a0c0a23ca181e (patch)
treea28730a96f057901a59c91e9c9163af397639c58 /models
parent97078d1bdf26cfc99e093234348ddea74af40baf (diff)
downloadgitea-fb0c562f8ba32804c5d025abe23a0c0a23ca181e.tar.gz
gitea-fb0c562f8ba32804c5d025abe23a0c0a23ca181e.zip
Fix regex for issues in commit messages (#7444)
* Fix regex for issues in commit messages Use same regex as markup for matching in commits. Fixes #7438 * make fmt
Diffstat (limited to 'models')
-rw-r--r--models/action.go3
-rw-r--r--models/action_test.go19
2 files changed, 21 insertions, 1 deletions
diff --git a/models/action.go b/models/action.go
index 21b008e3be..a092f564bf 100644
--- a/models/action.go
+++ b/models/action.go
@@ -65,6 +65,7 @@ var (
)
const issueRefRegexpStr = `(?:([0-9a-zA-Z-_\.]+)/([0-9a-zA-Z-_\.]+))?(#[0-9]+)+`
+const issueRefRegexpStrNoKeyword = `(?:\s|^|\(|\[)(?:([0-9a-zA-Z-_\.]+)/([0-9a-zA-Z-_\.]+))?(#[0-9]+)(?:\s|$|\)|\]|\.(\s|$))`
func assembleKeywordsPattern(words []string) string {
return fmt.Sprintf(`(?i)(?:%s)(?::?) %s`, strings.Join(words, "|"), issueRefRegexpStr)
@@ -73,7 +74,7 @@ func assembleKeywordsPattern(words []string) string {
func init() {
issueCloseKeywordsPat = regexp.MustCompile(assembleKeywordsPattern(issueCloseKeywords))
issueReopenKeywordsPat = regexp.MustCompile(assembleKeywordsPattern(issueReopenKeywords))
- issueReferenceKeywordsPat = regexp.MustCompile(issueRefRegexpStr)
+ issueReferenceKeywordsPat = regexp.MustCompile(issueRefRegexpStrNoKeyword)
}
// Action represents user operation type and other information to
diff --git a/models/action_test.go b/models/action_test.go
index 53a3202894..da50ebce80 100644
--- a/models/action_test.go
+++ b/models/action_test.go
@@ -155,6 +155,25 @@ func TestPushCommits_AvatarLink(t *testing.T) {
pushCommits.AvatarLink("nonexistent@example.com"))
}
+func TestRegExp_issueReferenceKeywordsPat(t *testing.T) {
+ trueTestCases := []string{
+ "#2",
+ "[#2]",
+ "please see go-gitea/gitea#5",
+ }
+ falseTestCases := []string{
+ "kb#2",
+ "#2xy",
+ }
+
+ for _, testCase := range trueTestCases {
+ assert.True(t, issueReferenceKeywordsPat.MatchString(testCase))
+ }
+ for _, testCase := range falseTestCases {
+ assert.False(t, issueReferenceKeywordsPat.MatchString(testCase))
+ }
+}
+
func Test_getIssueFromRef(t *testing.T) {
assert.NoError(t, PrepareTestDatabase())
repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)