Issue content should not be updated when closing with comment (#2833)
This commit is contained in:
		
							parent
							
								
									8798cf4e3b
								
							
						
					
					
						commit
						240609432b
					
				|  | @ -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")) | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue