mirror of
https://codeberg.org/forgejo/forgejo
synced 2024-11-28 04:36:11 +01:00
84447df4d3
* feat: extend issue template for yaml * feat: support yaml template * feat: render form to markdown * feat: support yaml template for pr * chore: rename to Fields * feat: template unmarshal * feat: split template * feat: render to markdown * feat: use full name as template file name * chore: remove useless file * feat: use dropdown of fomantic ui * feat: update input style * docs: more comments * fix: render text without render * chore: fix lint error * fix: support use description as about in markdown * fix: add field class in form * chore: generate swagger * feat: validate template * feat: support is_nummber and regex * test: fix broken unit tests * fix: ignore empty body of md template * fix: make multiple easymde editors work in one page * feat: better UI * fix: js error in pr form * chore: generate swagger * feat: support regex validation * chore: generate swagger * fix: refresh each markdown editor * chore: give up required validation * fix: correct issue template candidates * fix: correct checkboxes style * chore: ignore .hugo_build.lock in docs * docs: separate out a new doc for merge templates * docs: introduce syntax of yaml template * feat: show a alert for invalid templates * test: add case for a valid template * fix: correct attributes of required checkbox * fix: add class not-under-easymde for dropzone * fix: use more back-quotes * chore: remove translation in zh-CN * fix EasyMDE statusbar margin * fix: remove repeated blocks * fix: reuse regex for quotes Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
75 lines
2.1 KiB
Go
75 lines
2.1 KiB
Go
// Copyright 2020 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 markdown
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/modules/structs"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func validateMetadata(it structs.IssueTemplate) bool {
|
|
/*
|
|
A legacy to keep the unit tests working.
|
|
Copied from the method "func (it IssueTemplate) Valid() bool", the original method has been removed.
|
|
Because it becomes quite complicated to validate an issue template which is support yaml form now.
|
|
The new way to validate an issue template is to call the Validate in modules/issue/template,
|
|
*/
|
|
return strings.TrimSpace(it.Name) != "" && strings.TrimSpace(it.About) != ""
|
|
}
|
|
|
|
func TestExtractMetadata(t *testing.T) {
|
|
t.Run("ValidFrontAndBody", func(t *testing.T) {
|
|
var meta structs.IssueTemplate
|
|
body, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s\n%s", sepTest, frontTest, sepTest, bodyTest), &meta)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, bodyTest, body)
|
|
assert.Equal(t, metaTest, meta)
|
|
assert.True(t, validateMetadata(meta))
|
|
})
|
|
|
|
t.Run("NoFirstSeparator", func(t *testing.T) {
|
|
var meta structs.IssueTemplate
|
|
_, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", frontTest, sepTest, bodyTest), &meta)
|
|
assert.Error(t, err)
|
|
})
|
|
|
|
t.Run("NoLastSeparator", func(t *testing.T) {
|
|
var meta structs.IssueTemplate
|
|
_, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, bodyTest), &meta)
|
|
assert.Error(t, err)
|
|
})
|
|
|
|
t.Run("NoBody", func(t *testing.T) {
|
|
var meta structs.IssueTemplate
|
|
body, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, sepTest), &meta)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, "", body)
|
|
assert.Equal(t, metaTest, meta)
|
|
assert.True(t, validateMetadata(meta))
|
|
})
|
|
}
|
|
|
|
var (
|
|
sepTest = "-----"
|
|
frontTest = `name: Test
|
|
about: "A Test"
|
|
title: "Test Title"
|
|
labels:
|
|
- bug
|
|
- "test label"`
|
|
bodyTest = "This is the body"
|
|
metaTest = structs.IssueTemplate{
|
|
Name: "Test",
|
|
About: "A Test",
|
|
Title: "Test Title",
|
|
Labels: []string{"bug", "test label"},
|
|
}
|
|
)
|