@@ -107,7 +107,7 @@ func TestNoLoginViewIssue(t *testing.T) { | |||
MakeRequest(t, req, http.StatusOK) | |||
} | |||
func testNewIssue(t *testing.T, session *TestSession, user, repo, title string) { | |||
func testNewIssue(t *testing.T, session *TestSession, user, repo, title, content string) string { | |||
req := NewRequest(t, "GET", path.Join(user, repo, "issues", "new")) | |||
resp := session.MakeRequest(t, req, http.StatusOK) | |||
@@ -116,17 +116,70 @@ func testNewIssue(t *testing.T, session *TestSession, user, repo, title string) | |||
link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action") | |||
assert.True(t, exists, "The template has changed") | |||
req = NewRequestWithValues(t, "POST", link, map[string]string{ | |||
"_csrf": htmlDoc.GetCSRF(), | |||
"title": title, | |||
"_csrf": htmlDoc.GetCSRF(), | |||
"title": title, | |||
"content": content, | |||
}) | |||
resp = session.MakeRequest(t, req, http.StatusFound) | |||
issueURL := RedirectURL(t, resp) | |||
req = NewRequest(t, "GET", issueURL) | |||
resp = session.MakeRequest(t, req, http.StatusOK) | |||
htmlDoc = NewHTMLParser(t, resp.Body) | |||
val := htmlDoc.doc.Find("#issue-title").Text() | |||
assert.Equal(t, title, val) | |||
val = htmlDoc.doc.Find(".comment-list .comments .comment .render-content p").First().Text() | |||
assert.Equal(t, content, val) | |||
return issueURL | |||
} | |||
func testIssueAddComment(t *testing.T, session *TestSession, issueURL, content, status string) { | |||
req := NewRequest(t, "GET", issueURL) | |||
resp := session.MakeRequest(t, req, http.StatusOK) | |||
htmlDoc := NewHTMLParser(t, resp.Body) | |||
link, exists := htmlDoc.doc.Find("#comment-form").Attr("action") | |||
assert.True(t, exists, "The template has changed") | |||
commentCount := htmlDoc.doc.Find(".comment-list .comments .comment .render-content").Length() | |||
req = NewRequestWithValues(t, "POST", link, map[string]string{ | |||
"_csrf": htmlDoc.GetCSRF(), | |||
"content": content, | |||
"status": status, | |||
}) | |||
resp = session.MakeRequest(t, req, http.StatusFound) | |||
req = NewRequest(t, "GET", RedirectURL(t, resp)) | |||
resp = session.MakeRequest(t, req, http.StatusOK) | |||
htmlDoc = NewHTMLParser(t, resp.Body) | |||
val := htmlDoc.doc.Find(".comment-list .comments .comment .render-content p").Eq(commentCount).Text() | |||
assert.Equal(t, content, val) | |||
} | |||
func TestNewIssue(t *testing.T) { | |||
prepareTestEnv(t) | |||
session := loginUser(t, "user2") | |||
testNewIssue(t, session, "user2", "repo1", "Title") | |||
testNewIssue(t, session, "user2", "repo1", "Title", "Description") | |||
} | |||
func TestIssueCommentClose(t *testing.T) { | |||
prepareTestEnv(t) | |||
session := loginUser(t, "user2") | |||
issueURL := testNewIssue(t, session, "user2", "repo1", "Title", "Description") | |||
testIssueAddComment(t, session, issueURL, "Test comment 1", "") | |||
testIssueAddComment(t, session, issueURL, "Test comment 2", "") | |||
testIssueAddComment(t, session, issueURL, "Test comment 3", "close") | |||
// Validate that issue content has not been updated | |||
req := NewRequest(t, "GET", issueURL) | |||
resp := session.MakeRequest(t, req, http.StatusOK) | |||
htmlDoc := NewHTMLParser(t, resp.Body) | |||
val := htmlDoc.doc.Find(".comment-list .comments .comment .render-content p").First().Text() | |||
assert.Equal(t, "Description", val) | |||
} |
@@ -31,9 +31,9 @@ func TestRepoActivity(t *testing.T) { | |||
testPullCreate(t, session, "user1", "repo1", "feat/much_better_readme") | |||
// Create issues (3 new issues) | |||
testNewIssue(t, session, "user2", "repo1", "Issue 1") | |||
testNewIssue(t, session, "user2", "repo1", "Issue 2") | |||
testNewIssue(t, session, "user2", "repo1", "Issue 3") | |||
testNewIssue(t, session, "user2", "repo1", "Issue 1", "Description 1") | |||
testNewIssue(t, session, "user2", "repo1", "Issue 2", "Description 2") | |||
testNewIssue(t, session, "user2", "repo1", "Issue 3", "Description 3") | |||
// Create releases (1 new release) | |||
createNewRelease(t, session, "/user2/repo1", "v1.0.0", "v1.0.0", false, false) | |||
@@ -272,15 +272,15 @@ func (c *Comment) MailParticipants(e Engine, opType ActionType, issue *Issue) (e | |||
return fmt.Errorf("UpdateIssueMentions [%d]: %v", c.IssueID, err) | |||
} | |||
content := c.Content | |||
switch opType { | |||
case ActionCommentIssue: | |||
issue.Content = c.Content | |||
case ActionCloseIssue: | |||
issue.Content = fmt.Sprintf("Closed #%d", issue.Index) | |||
content = fmt.Sprintf("Closed #%d", issue.Index) | |||
case ActionReopenIssue: | |||
issue.Content = fmt.Sprintf("Reopened #%d", issue.Index) | |||
content = fmt.Sprintf("Reopened #%d", issue.Index) | |||
} | |||
if err = mailIssueCommentToParticipants(e, issue, c.Poster, c, mentions); err != nil { | |||
if err = mailIssueCommentToParticipants(e, issue, c.Poster, content, c, mentions); err != nil { | |||
log.Error(4, "mailIssueCommentToParticipants: %v", err) | |||
} | |||
@@ -22,7 +22,7 @@ func (issue *Issue) mailSubject() string { | |||
// This function sends two list of emails: | |||
// 1. Repository watchers and users who are participated in comments. | |||
// 2. Users who are not in 1. but get mentioned in current issue/comment. | |||
func mailIssueCommentToParticipants(e Engine, issue *Issue, doer *User, comment *Comment, mentions []string) error { | |||
func mailIssueCommentToParticipants(e Engine, issue *Issue, doer *User, content string, comment *Comment, mentions []string) error { | |||
if !setting.Service.EnableNotifyMail { | |||
return nil | |||
} | |||
@@ -80,7 +80,7 @@ func mailIssueCommentToParticipants(e Engine, issue *Issue, doer *User, comment | |||
names = append(names, participants[i].Name) | |||
} | |||
SendIssueCommentMail(issue, doer, comment, tos) | |||
SendIssueCommentMail(issue, doer, content, comment, tos) | |||
// Mail mentioned people and exclude watchers. | |||
names = append(names, doer.Name) | |||
@@ -92,7 +92,7 @@ func mailIssueCommentToParticipants(e Engine, issue *Issue, doer *User, comment | |||
tos = append(tos, mentions[i]) | |||
} | |||
SendIssueMentionMail(issue, doer, comment, getUserEmailsByNames(e, tos)) | |||
SendIssueMentionMail(issue, doer, content, comment, getUserEmailsByNames(e, tos)) | |||
return nil | |||
} | |||
@@ -109,7 +109,7 @@ func (issue *Issue) mailParticipants(e Engine) (err error) { | |||
return fmt.Errorf("UpdateIssueMentions [%d]: %v", issue.ID, err) | |||
} | |||
if err = mailIssueCommentToParticipants(e, issue, issue.Poster, nil, mentions); err != nil { | |||
if err = mailIssueCommentToParticipants(e, issue, issue.Poster, issue.Content, nil, mentions); err != nil { | |||
log.Error(4, "mailIssueCommentToParticipants: %v", err) | |||
} | |||
@@ -149,9 +149,9 @@ func composeTplData(subject, body, link string) map[string]interface{} { | |||
return data | |||
} | |||
func composeIssueCommentMessage(issue *Issue, doer *User, comment *Comment, tplName base.TplName, tos []string, info string) *mailer.Message { | |||
func composeIssueCommentMessage(issue *Issue, doer *User, content string, comment *Comment, tplName base.TplName, tos []string, info string) *mailer.Message { | |||
subject := issue.mailSubject() | |||
body := string(markup.RenderByType(markdown.MarkupName, []byte(issue.Content), issue.Repo.HTMLURL(), issue.Repo.ComposeMetas())) | |||
body := string(markup.RenderByType(markdown.MarkupName, []byte(content), issue.Repo.HTMLURL(), issue.Repo.ComposeMetas())) | |||
data := make(map[string]interface{}, 10) | |||
if comment != nil { | |||
@@ -161,30 +161,30 @@ func composeIssueCommentMessage(issue *Issue, doer *User, comment *Comment, tplN | |||
} | |||
data["Doer"] = doer | |||
var content bytes.Buffer | |||
var mailBody bytes.Buffer | |||
if err := templates.ExecuteTemplate(&content, string(tplName), data); err != nil { | |||
if err := templates.ExecuteTemplate(&mailBody, string(tplName), data); err != nil { | |||
log.Error(3, "Template: %v", err) | |||
} | |||
msg := mailer.NewMessageFrom(tos, doer.DisplayName(), setting.MailService.FromEmail, subject, content.String()) | |||
msg := mailer.NewMessageFrom(tos, doer.DisplayName(), setting.MailService.FromEmail, subject, mailBody.String()) | |||
msg.Info = fmt.Sprintf("Subject: %s, %s", subject, info) | |||
return msg | |||
} | |||
// SendIssueCommentMail composes and sends issue comment emails to target receivers. | |||
func SendIssueCommentMail(issue *Issue, doer *User, comment *Comment, tos []string) { | |||
func SendIssueCommentMail(issue *Issue, doer *User, content string, comment *Comment, tos []string) { | |||
if len(tos) == 0 { | |||
return | |||
} | |||
mailer.SendAsync(composeIssueCommentMessage(issue, doer, comment, mailIssueComment, tos, "issue comment")) | |||
mailer.SendAsync(composeIssueCommentMessage(issue, doer, content, comment, mailIssueComment, tos, "issue comment")) | |||
} | |||
// SendIssueMentionMail composes and sends issue mention emails to target receivers. | |||
func SendIssueMentionMail(issue *Issue, doer *User, comment *Comment, tos []string) { | |||
func SendIssueMentionMail(issue *Issue, doer *User, content string, comment *Comment, tos []string) { | |||
if len(tos) == 0 { | |||
return | |||
} | |||
mailer.SendAsync(composeIssueCommentMessage(issue, doer, comment, mailIssueMention, tos, "issue mention")) | |||
mailer.SendAsync(composeIssueCommentMessage(issue, doer, content, comment, mailIssueMention, tos, "issue mention")) | |||
} |