Extend Label Test (#540)
make test coverate 53.8% Reviewed-on: https://gitea.com/gitea/go-sdk/pulls/540 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-by: Andrew Thornton <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de> Co-committed-by: 6543 <6543@obermui.de>
This commit is contained in:
parent
747c78e835
commit
4debc6ca4b
2 changed files with 121 additions and 40 deletions
|
@ -1,40 +0,0 @@
|
||||||
// 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 (
|
|
||||||
"log"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
|
||||||
)
|
|
||||||
|
|
||||||
// TestLabels test label related func
|
|
||||||
func TestLabels(t *testing.T) {
|
|
||||||
log.Println("== TestLabels ==")
|
|
||||||
c := newTestClient()
|
|
||||||
repo, err := createTestRepo(t, "LabelTestsRepo", c)
|
|
||||||
assert.NoError(t, err)
|
|
||||||
|
|
||||||
createOpts := CreateLabelOption{
|
|
||||||
Name: " ",
|
|
||||||
Description: "",
|
|
||||||
Color: "",
|
|
||||||
}
|
|
||||||
err = createOpts.Validate()
|
|
||||||
assert.Error(t, err)
|
|
||||||
assert.EqualValues(t, "invalid color format", err.Error())
|
|
||||||
createOpts.Color = "12345f"
|
|
||||||
err = createOpts.Validate()
|
|
||||||
assert.Error(t, err)
|
|
||||||
assert.EqualValues(t, "empty name not allowed", err.Error())
|
|
||||||
createOpts.Name = "label one"
|
|
||||||
|
|
||||||
label1, _, err := c.CreateLabel(repo.Owner.UserName, repo.Name, createOpts)
|
|
||||||
assert.NoError(t, err)
|
|
||||||
assert.EqualValues(t, createOpts.Name, label1.Name)
|
|
||||||
assert.EqualValues(t, createOpts.Color, label1.Color)
|
|
||||||
|
|
||||||
}
|
|
121
gitea/issue_label_test.go
Normal file
121
gitea/issue_label_test.go
Normal file
|
@ -0,0 +1,121 @@
|
||||||
|
// 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 (
|
||||||
|
"log"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
// TestLabels test label related func
|
||||||
|
func TestLabels(t *testing.T) {
|
||||||
|
log.Println("== TestLabels ==")
|
||||||
|
c := newTestClient()
|
||||||
|
repo, err := createTestRepo(t, "LabelTestsRepo", c)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
|
||||||
|
createOpts := CreateLabelOption{
|
||||||
|
Name: " ",
|
||||||
|
Description: "",
|
||||||
|
Color: "",
|
||||||
|
}
|
||||||
|
err = createOpts.Validate()
|
||||||
|
assert.Error(t, err)
|
||||||
|
assert.EqualValues(t, "invalid color format", err.Error())
|
||||||
|
createOpts.Color = "12345f"
|
||||||
|
err = createOpts.Validate()
|
||||||
|
assert.Error(t, err)
|
||||||
|
assert.EqualValues(t, "empty name not allowed", err.Error())
|
||||||
|
createOpts.Name = "label one"
|
||||||
|
|
||||||
|
labelOne, _, err := c.CreateLabel(repo.Owner.UserName, repo.Name, createOpts)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.EqualValues(t, createOpts.Name, labelOne.Name)
|
||||||
|
assert.EqualValues(t, createOpts.Color, labelOne.Color)
|
||||||
|
|
||||||
|
labelTwo, _, err := c.CreateLabel(repo.Owner.UserName, repo.Name, CreateLabelOption{
|
||||||
|
Name: "blue",
|
||||||
|
Color: "#0000FF",
|
||||||
|
Description: "CMYB(100%, 100%, 0%, 0%)",
|
||||||
|
})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
_, _, err = c.CreateLabel(repo.Owner.UserName, repo.Name, CreateLabelOption{
|
||||||
|
Name: "gray",
|
||||||
|
Color: "808080",
|
||||||
|
Description: "CMYB(0%, 0%, 0%, 50%)",
|
||||||
|
})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
_, _, err = c.CreateLabel(repo.Owner.UserName, repo.Name, CreateLabelOption{
|
||||||
|
Name: "green",
|
||||||
|
Color: "#98F76C",
|
||||||
|
Description: "CMYB(38%, 0%, 56%, 3%)",
|
||||||
|
})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
|
||||||
|
labels, resp, err := c.ListRepoLabels(repo.Owner.UserName, repo.Name, ListLabelsOptions{ListOptions: ListOptions{PageSize: 3}})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Len(t, labels, 3)
|
||||||
|
assert.NotNil(t, resp)
|
||||||
|
assert.Contains(t, labels, labelTwo)
|
||||||
|
assert.NotContains(t, labels, labelOne)
|
||||||
|
|
||||||
|
label, _, err := c.GetRepoLabel(repo.Owner.UserName, repo.Name, labelTwo.ID)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.EqualValues(t, labelTwo, label)
|
||||||
|
|
||||||
|
label, _, err = c.EditLabel(repo.Owner.UserName, repo.Name, labelTwo.ID, EditLabelOption{
|
||||||
|
Color: OptionalString("#0E0175"),
|
||||||
|
Description: OptionalString("blueish"),
|
||||||
|
})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.EqualValues(t, &Label{
|
||||||
|
ID: labelTwo.ID,
|
||||||
|
Name: labelTwo.Name,
|
||||||
|
Color: "0E0175",
|
||||||
|
Description: "blueish",
|
||||||
|
URL: labelTwo.URL,
|
||||||
|
}, label)
|
||||||
|
labels, _, _ = c.ListRepoLabels(repo.Owner.UserName, repo.Name, ListLabelsOptions{ListOptions: ListOptions{PageSize: 3}})
|
||||||
|
|
||||||
|
createTestIssue(t, c, repo.Name, "test-issue", "", nil, nil, 0, []int64{label.ID}, false, false)
|
||||||
|
issueIndex := int64(1)
|
||||||
|
|
||||||
|
issueLabels, _, err := c.GetIssueLabels(repo.Owner.UserName, repo.Name, issueIndex, ListLabelsOptions{})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Len(t, issueLabels, 1)
|
||||||
|
assert.EqualValues(t, label, issueLabels[0])
|
||||||
|
|
||||||
|
_, _, err = c.AddIssueLabels(repo.Owner.UserName, repo.Name, issueIndex, IssueLabelsOption{Labels: []int64{labels[0].ID}})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
|
||||||
|
issueLabels, _, err = c.AddIssueLabels(repo.Owner.UserName, repo.Name, issueIndex, IssueLabelsOption{Labels: []int64{labels[1].ID, labels[2].ID}})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Len(t, issueLabels, 3)
|
||||||
|
assert.EqualValues(t, labels, issueLabels)
|
||||||
|
|
||||||
|
labels, _, _ = c.ListRepoLabels(repo.Owner.UserName, repo.Name, ListLabelsOptions{})
|
||||||
|
assert.Len(t, labels, 11)
|
||||||
|
|
||||||
|
issueLabels, _, err = c.ReplaceIssueLabels(repo.Owner.UserName, repo.Name, issueIndex, IssueLabelsOption{Labels: []int64{labels[0].ID, labels[1].ID}})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Len(t, issueLabels, 2)
|
||||||
|
|
||||||
|
_, err = c.DeleteIssueLabel(repo.Owner.UserName, repo.Name, issueIndex, labels[0].ID)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
issueLabels, _, _ = c.GetIssueLabels(repo.Owner.UserName, repo.Name, issueIndex, ListLabelsOptions{})
|
||||||
|
assert.Len(t, issueLabels, 1)
|
||||||
|
|
||||||
|
_, err = c.ClearIssueLabels(repo.Owner.UserName, repo.Name, issueIndex)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
issueLabels, _, _ = c.GetIssueLabels(repo.Owner.UserName, repo.Name, issueIndex, ListLabelsOptions{})
|
||||||
|
assert.Len(t, issueLabels, 0)
|
||||||
|
|
||||||
|
_, err = c.DeleteLabel(repo.Owner.UserName, repo.Name, labelTwo.ID)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
labels, _, _ = c.ListRepoLabels(repo.Owner.UserName, repo.Name, ListLabelsOptions{})
|
||||||
|
assert.Len(t, labels, 10)
|
||||||
|
}
|
Loading…
Reference in a new issue