|
|
@ -9,82 +9,86 @@ import ( |
|
|
|
"strings" |
|
|
|
"strings" |
|
|
|
"testing" |
|
|
|
"testing" |
|
|
|
|
|
|
|
|
|
|
|
"code.gitea.io/gitea/modules/structs" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert" |
|
|
|
"github.com/stretchr/testify/assert" |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
func validateMetadata(it structs.IssueTemplate) bool { |
|
|
|
/* |
|
|
|
/* |
|
|
|
IssueTemplate is a legacy to keep the unit tests working. |
|
|
|
A legacy to keep the unit tests working. |
|
|
|
Copied from structs.IssueTemplate, the original type has been changed a lot to support yaml template. |
|
|
|
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. |
|
|
|
type IssueTemplate struct { |
|
|
|
The new way to validate an issue template is to call the Validate in modules/issue/template, |
|
|
|
Name string `json:"name" yaml:"name"` |
|
|
|
*/ |
|
|
|
Title string `json:"title" yaml:"title"` |
|
|
|
|
|
|
|
About string `json:"about" yaml:"about"` |
|
|
|
|
|
|
|
Labels []string `json:"labels" yaml:"labels"` |
|
|
|
|
|
|
|
Ref string `json:"ref" yaml:"ref"` |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func (it *IssueTemplate) Valid() bool { |
|
|
|
return strings.TrimSpace(it.Name) != "" && strings.TrimSpace(it.About) != "" |
|
|
|
return strings.TrimSpace(it.Name) != "" && strings.TrimSpace(it.About) != "" |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func TestExtractMetadata(t *testing.T) { |
|
|
|
func TestExtractMetadata(t *testing.T) { |
|
|
|
t.Run("ValidFrontAndBody", func(t *testing.T) { |
|
|
|
t.Run("ValidFrontAndBody", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
body, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s\n%s", sepTest, frontTest, sepTest, bodyTest), &meta) |
|
|
|
body, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s\n%s", sepTest, frontTest, sepTest, bodyTest), &meta) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.Equal(t, bodyTest, body) |
|
|
|
assert.Equal(t, bodyTest, body) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.True(t, validateMetadata(meta)) |
|
|
|
assert.True(t, meta.Valid()) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
t.Run("NoFirstSeparator", func(t *testing.T) { |
|
|
|
t.Run("NoFirstSeparator", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
_, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", frontTest, sepTest, bodyTest), &meta) |
|
|
|
_, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", frontTest, sepTest, bodyTest), &meta) |
|
|
|
assert.Error(t, err) |
|
|
|
assert.Error(t, err) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
t.Run("NoLastSeparator", func(t *testing.T) { |
|
|
|
t.Run("NoLastSeparator", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
_, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, bodyTest), &meta) |
|
|
|
_, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, bodyTest), &meta) |
|
|
|
assert.Error(t, err) |
|
|
|
assert.Error(t, err) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
t.Run("NoBody", func(t *testing.T) { |
|
|
|
t.Run("NoBody", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
body, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, sepTest), &meta) |
|
|
|
body, err := ExtractMetadata(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, sepTest), &meta) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.Equal(t, "", body) |
|
|
|
assert.Equal(t, "", body) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.True(t, validateMetadata(meta)) |
|
|
|
assert.True(t, meta.Valid()) |
|
|
|
}) |
|
|
|
}) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func TestExtractMetadataBytes(t *testing.T) { |
|
|
|
func TestExtractMetadataBytes(t *testing.T) { |
|
|
|
t.Run("ValidFrontAndBody", func(t *testing.T) { |
|
|
|
t.Run("ValidFrontAndBody", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
body, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s\n%s", sepTest, frontTest, sepTest, bodyTest)), &meta) |
|
|
|
body, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s\n%s", sepTest, frontTest, sepTest, bodyTest)), &meta) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.Equal(t, bodyTest, string(body)) |
|
|
|
assert.Equal(t, bodyTest, string(body)) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.True(t, validateMetadata(meta)) |
|
|
|
assert.True(t, meta.Valid()) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
t.Run("NoFirstSeparator", func(t *testing.T) { |
|
|
|
t.Run("NoFirstSeparator", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
_, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s", frontTest, sepTest, bodyTest)), &meta) |
|
|
|
_, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s", frontTest, sepTest, bodyTest)), &meta) |
|
|
|
assert.Error(t, err) |
|
|
|
assert.Error(t, err) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
t.Run("NoLastSeparator", func(t *testing.T) { |
|
|
|
t.Run("NoLastSeparator", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
_, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, bodyTest)), &meta) |
|
|
|
_, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, bodyTest)), &meta) |
|
|
|
assert.Error(t, err) |
|
|
|
assert.Error(t, err) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
t.Run("NoBody", func(t *testing.T) { |
|
|
|
t.Run("NoBody", func(t *testing.T) { |
|
|
|
var meta structs.IssueTemplate |
|
|
|
var meta IssueTemplate |
|
|
|
body, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, sepTest)), &meta) |
|
|
|
body, err := ExtractMetadataBytes([]byte(fmt.Sprintf("%s\n%s\n%s", sepTest, frontTest, sepTest)), &meta) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.NoError(t, err) |
|
|
|
assert.Equal(t, "", string(body)) |
|
|
|
assert.Equal(t, "", string(body)) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.Equal(t, metaTest, meta) |
|
|
|
assert.True(t, validateMetadata(meta)) |
|
|
|
assert.True(t, meta.Valid()) |
|
|
|
}) |
|
|
|
}) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -97,7 +101,7 @@ labels: |
|
|
|
- bug |
|
|
|
- bug |
|
|
|
- "test label"` |
|
|
|
- "test label"` |
|
|
|
bodyTest = "This is the body" |
|
|
|
bodyTest = "This is the body" |
|
|
|
metaTest = structs.IssueTemplate{ |
|
|
|
metaTest = IssueTemplate{ |
|
|
|
Name: "Test", |
|
|
|
Name: "Test", |
|
|
|
About: "A Test", |
|
|
|
About: "A Test", |
|
|
|
Title: "Test Title", |
|
|
|
Title: "Test Title", |
|
|
|