688ee1978e
All checks were successful
continuous-integration/drone/push Build is passing
Add Docs on how to deal with this breaking change doResponse should return responce in all cases, to prosses things manualy if wanted helper func return http response Co-authored-by: 6543 <6543@obermui.de> Reviewed-on: #416 Reviewed-by: Andrew Thornton <art27@cantab.net> Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
85 lines
2.8 KiB
Go
85 lines
2.8 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 gitea
|
|
|
|
import (
|
|
"github.com/stretchr/testify/assert"
|
|
"log"
|
|
"testing"
|
|
)
|
|
|
|
// TestIssueComment creat a issue and test comment creation/edit/deletion on it
|
|
func TestIssueComment(t *testing.T) {
|
|
log.Println("== TestIssueComment ==")
|
|
|
|
c := newTestClient()
|
|
|
|
user, _, err := c.GetMyUserInfo()
|
|
|
|
assert.NoError(t, err)
|
|
repo, err := createTestRepo(t, "TestIssueCommentRepo", c)
|
|
assert.NoError(t, err)
|
|
issue1, _, err := c.CreateIssue(user.UserName, repo.Name, CreateIssueOption{Title: "issue1", Body: "body", Closed: false})
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 1, issue1.Index)
|
|
issue2, _, err := c.CreateIssue(user.UserName, repo.Name, CreateIssueOption{Title: "issue1", Body: "body", Closed: false})
|
|
assert.EqualValues(t, 2, issue2.Index)
|
|
assert.NoError(t, err)
|
|
tUser2 := createTestUser(t, "Commenter2", c)
|
|
tUser3 := createTestUser(t, "Commenter3", c)
|
|
|
|
createOne := func(u *User, issue int64, text string) {
|
|
c.sudo = u.UserName
|
|
comment, _, e := c.CreateIssueComment(user.UserName, repo.Name, issue, CreateIssueCommentOption{Body: text})
|
|
c.sudo = ""
|
|
assert.NoError(t, e)
|
|
assert.NotEmpty(t, comment)
|
|
assert.EqualValues(t, text, comment.Body)
|
|
assert.EqualValues(t, u.ID, comment.Poster.ID)
|
|
}
|
|
|
|
// CreateIssue
|
|
createOne(user, 1, "what a nice issue")
|
|
createOne(tUser2, 1, "dont think so")
|
|
createOne(tUser3, 1, "weow weow")
|
|
createOne(user, 1, "spam isn't it?")
|
|
createOne(tUser3, 2, "hehe first commit")
|
|
createOne(tUser2, 2, "second")
|
|
createOne(user, 2, "3")
|
|
|
|
_, err = c.AdminDeleteUser(tUser3.UserName)
|
|
assert.NoError(t, err)
|
|
|
|
// ListRepoIssueComments
|
|
comments, _, err := c.ListRepoIssueComments(user.UserName, repo.Name, ListIssueCommentOptions{})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, comments, 7)
|
|
|
|
// ListIssueComments
|
|
comments, _, err = c.ListIssueComments(user.UserName, repo.Name, 2, ListIssueCommentOptions{})
|
|
assert.NoError(t, err)
|
|
assert.Len(t, comments, 3)
|
|
|
|
// GetIssueComment
|
|
comment, _, err := c.GetIssueComment(user.UserName, repo.Name, comments[1].ID)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, comment.Poster.ID, comments[1].Poster.ID)
|
|
assert.EqualValues(t, comment.Body, comments[1].Body)
|
|
assert.EqualValues(t, comment.Updated.Unix(), comments[1].Updated.Unix())
|
|
|
|
// EditIssueComment
|
|
comment, _, err = c.EditIssueComment(user.UserName, repo.Name, comments[1].ID, EditIssueCommentOption{
|
|
Body: "changed my mind",
|
|
})
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, "changed my mind", comment.Body)
|
|
|
|
// DeleteIssueComment
|
|
_, err = c.DeleteIssueComment(user.UserName, repo.Name, comments[1].ID)
|
|
assert.NoError(t, err)
|
|
_, _, err = c.GetIssueComment(user.UserName, repo.Name, comments[1].ID)
|
|
assert.Error(t, err)
|
|
}
|