| @@ -107,7 +107,7 @@ func TestNoLoginViewIssue(t *testing.T) { | |||||
| MakeRequest(t, req, http.StatusOK) | 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")) | req := NewRequest(t, "GET", path.Join(user, repo, "issues", "new")) | ||||
| resp := session.MakeRequest(t, req, http.StatusOK) | 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") | link, exists := htmlDoc.doc.Find("form.ui.form").Attr("action") | ||||
| assert.True(t, exists, "The template has changed") | assert.True(t, exists, "The template has changed") | ||||
| req = NewRequestWithValues(t, "POST", link, map[string]string{ | 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) | resp = session.MakeRequest(t, req, http.StatusFound) | ||||
| req = NewRequest(t, "GET", RedirectURL(t, resp)) | req = NewRequest(t, "GET", RedirectURL(t, resp)) | ||||
| resp = session.MakeRequest(t, req, http.StatusOK) | 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) { | func TestNewIssue(t *testing.T) { | ||||
| prepareTestEnv(t) | prepareTestEnv(t) | ||||
| session := loginUser(t, "user2") | 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") | testPullCreate(t, session, "user1", "repo1", "feat/much_better_readme") | ||||
| // Create issues (3 new issues) | // 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) | // Create releases (1 new release) | ||||
| createNewRelease(t, session, "/user2/repo1", "v1.0.0", "v1.0.0", false, false) | 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) | return fmt.Errorf("UpdateIssueMentions [%d]: %v", c.IssueID, err) | ||||
| } | } | ||||
| content := c.Content | |||||
| switch opType { | switch opType { | ||||
| case ActionCommentIssue: | |||||
| issue.Content = c.Content | |||||
| case ActionCloseIssue: | case ActionCloseIssue: | ||||
| issue.Content = fmt.Sprintf("Closed #%d", issue.Index) | |||||
| content = fmt.Sprintf("Closed #%d", issue.Index) | |||||
| case ActionReopenIssue: | 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) | log.Error(4, "mailIssueCommentToParticipants: %v", err) | ||||
| } | } | ||||
| @@ -22,7 +22,7 @@ func (issue *Issue) mailSubject() string { | |||||
| // This function sends two list of emails: | // This function sends two list of emails: | ||||
| // 1. Repository watchers and users who are participated in comments. | // 1. Repository watchers and users who are participated in comments. | ||||
| // 2. Users who are not in 1. but get mentioned in current issue/comment. | // 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 { | if !setting.Service.EnableNotifyMail { | ||||
| return nil | return nil | ||||
| } | } | ||||
| @@ -80,7 +80,7 @@ func mailIssueCommentToParticipants(e Engine, issue *Issue, doer *User, comment | |||||
| names = append(names, participants[i].Name) | names = append(names, participants[i].Name) | ||||
| } | } | ||||
| SendIssueCommentMail(issue, doer, comment, tos) | |||||
| SendIssueCommentMail(issue, doer, content, comment, tos) | |||||
| // Mail mentioned people and exclude watchers. | // Mail mentioned people and exclude watchers. | ||||
| names = append(names, doer.Name) | names = append(names, doer.Name) | ||||
| @@ -92,7 +92,7 @@ func mailIssueCommentToParticipants(e Engine, issue *Issue, doer *User, comment | |||||
| tos = append(tos, mentions[i]) | tos = append(tos, mentions[i]) | ||||
| } | } | ||||
| SendIssueMentionMail(issue, doer, comment, getUserEmailsByNames(e, tos)) | |||||
| SendIssueMentionMail(issue, doer, content, comment, getUserEmailsByNames(e, tos)) | |||||
| return nil | return nil | ||||
| } | } | ||||
| @@ -109,7 +109,7 @@ func (issue *Issue) mailParticipants(e Engine) (err error) { | |||||
| return fmt.Errorf("UpdateIssueMentions [%d]: %v", issue.ID, err) | 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) | log.Error(4, "mailIssueCommentToParticipants: %v", err) | ||||
| } | } | ||||
| @@ -149,9 +149,9 @@ func composeTplData(subject, body, link string) map[string]interface{} { | |||||
| return data | 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() | 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) | data := make(map[string]interface{}, 10) | ||||
| if comment != nil { | if comment != nil { | ||||
| @@ -161,30 +161,30 @@ func composeIssueCommentMessage(issue *Issue, doer *User, comment *Comment, tplN | |||||
| } | } | ||||
| data["Doer"] = doer | 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) | 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) | msg.Info = fmt.Sprintf("Subject: %s, %s", subject, info) | ||||
| return msg | return msg | ||||
| } | } | ||||
| // SendIssueCommentMail composes and sends issue comment emails to target receivers. | // 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 { | if len(tos) == 0 { | ||||
| return | 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. | // 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 { | if len(tos) == 0 { | ||||
| return | return | ||||
| } | } | ||||
| mailer.SendAsync(composeIssueCommentMessage(issue, doer, comment, mailIssueMention, tos, "issue mention")) | |||||
| mailer.SendAsync(composeIssueCommentMessage(issue, doer, content, comment, mailIssueMention, tos, "issue mention")) | |||||
| } | } | ||||