mirror of
https://gitea.com/gitea/tea.git
synced 2026-06-25 22:27:39 +02:00
fix(labels): add org label for ls and pr (#1017)
Fix https://gitea.com/gitea/tea/issues/634, https://gitea.com/gitea/tea/issues/669 Reviewed-on: https://gitea.com/gitea/tea/pulls/1017 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: Minjie Fang <wingsallen@gmail.com> Co-committed-by: Minjie Fang <wingsallen@gmail.com>
This commit is contained in:
@@ -7,7 +7,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"gitea.dev/sdk"
|
gitea "gitea.dev/sdk"
|
||||||
"github.com/urfave/cli/v3"
|
"github.com/urfave/cli/v3"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
+51
-4
@@ -5,8 +5,9 @@ package labels
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
stdctx "context"
|
stdctx "context"
|
||||||
|
"log"
|
||||||
|
|
||||||
"gitea.dev/sdk"
|
gitea "gitea.dev/sdk"
|
||||||
|
|
||||||
"gitea.dev/tea/cmd/flags"
|
"gitea.dev/tea/cmd/flags"
|
||||||
"gitea.dev/tea/modules/context"
|
"gitea.dev/tea/modules/context"
|
||||||
@@ -29,6 +30,14 @@ var CmdLabelsList = cli.Command{
|
|||||||
Aliases: []string{"s"},
|
Aliases: []string{"s"},
|
||||||
Usage: "Save all the labels as a file",
|
Usage: "Save all the labels as a file",
|
||||||
},
|
},
|
||||||
|
&cli.StringFlag{
|
||||||
|
Name: "org",
|
||||||
|
Usage: "List organization labels",
|
||||||
|
},
|
||||||
|
&cli.BoolFlag{
|
||||||
|
Name: "exclude-org",
|
||||||
|
Usage: "Exclude organization labels from the list",
|
||||||
|
},
|
||||||
&flags.PaginationPageFlag,
|
&flags.PaginationPageFlag,
|
||||||
&flags.PaginationLimitFlag,
|
&flags.PaginationLimitFlag,
|
||||||
}, flags.AllDefaultFlags...),
|
}, flags.AllDefaultFlags...),
|
||||||
@@ -40,14 +49,18 @@ func RunLabelsList(requestCtx stdctx.Context, cmd *cli.Command) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
if cmd.String("org") == "" && cmd.String("repo") == "" {
|
||||||
if err := ctx.Ensure(context.CtxRequirement{RemoteRepo: true}); err != nil {
|
if err := ctx.Ensure(context.CtxRequirement{RemoteRepo: true}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if cmd.String("org") != "" && cmd.String("repo") != "" {
|
||||||
|
log.Printf("Warning: Both --org and --repo flags are set. Ignoring --org and using --repo value as owner.\n")
|
||||||
|
}
|
||||||
|
|
||||||
client := ctx.Login.Client()
|
client := ctx.Login.Client()
|
||||||
labels, _, err := client.Repositories.ListRepoLabels(requestCtx, ctx.Owner, ctx.Repo, gitea.ListLabelsOptions{
|
labels, err := collectLabels(requestCtx, client, ctx, cmd)
|
||||||
ListOptions: flags.GetListOptions(cmd),
|
|
||||||
})
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@@ -58,3 +71,37 @@ func RunLabelsList(requestCtx stdctx.Context, cmd *cli.Command) error {
|
|||||||
|
|
||||||
return print.LabelsList(labels, ctx.Output)
|
return print.LabelsList(labels, ctx.Output)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CollectLabels collects labels based on the provided command flags and context.
|
||||||
|
func collectLabels(requestCtx stdctx.Context, client *gitea.Client, ctx *context.TeaContext, cmd *cli.Command) ([]*gitea.Label, error) {
|
||||||
|
var labels []*gitea.Label
|
||||||
|
var err error
|
||||||
|
owner := ctx.Owner
|
||||||
|
|
||||||
|
// If --org is set but --repo is not, list organization labels only and skip repository labels.
|
||||||
|
if cmd.String("org") != "" && cmd.String("repo") == "" {
|
||||||
|
owner = ctx.Org
|
||||||
|
} else {
|
||||||
|
labels, _, err = client.Repositories.ListRepoLabels(requestCtx, owner, ctx.Repo, gitea.ListLabelsOptions{
|
||||||
|
ListOptions: flags.GetListOptions(cmd),
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Failed to list repository labels: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If --exclude is not set and the owner is an organization, also list organization labels and append them to the list.
|
||||||
|
if !ctx.IsSet("exclude-org") {
|
||||||
|
if _, _, err = client.Organizations.GetOrg(requestCtx, owner); err == nil {
|
||||||
|
orgLabels, _, err := client.Organizations.ListOrgLabels(requestCtx, owner, gitea.ListOrgLabelsOptions{
|
||||||
|
ListOptions: flags.GetListOptions(cmd),
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
labels = append(labels, orgLabels...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return labels, nil
|
||||||
|
}
|
||||||
|
|||||||
@@ -551,10 +551,14 @@ Unresolve a review comment on a pull request
|
|||||||
|
|
||||||
Manage issue labels
|
Manage issue labels
|
||||||
|
|
||||||
|
**--exclude-org**: Exclude organization labels from the list
|
||||||
|
|
||||||
**--limit, --lm**="": specify limit of items per page (default: 30)
|
**--limit, --lm**="": specify limit of items per page (default: 30)
|
||||||
|
|
||||||
**--login, -l**="": Use a different Gitea Login. Optional
|
**--login, -l**="": Use a different Gitea Login. Optional
|
||||||
|
|
||||||
|
**--org**="": List organization labels
|
||||||
|
|
||||||
**--output, -o**="": Output format. (simple, table, csv, tsv, yaml, json)
|
**--output, -o**="": Output format. (simple, table, csv, tsv, yaml, json)
|
||||||
|
|
||||||
**--page, -p**="": specify page (default: 1)
|
**--page, -p**="": specify page (default: 1)
|
||||||
@@ -569,10 +573,14 @@ Manage issue labels
|
|||||||
|
|
||||||
List labels
|
List labels
|
||||||
|
|
||||||
|
**--exclude-org**: Exclude organization labels from the list
|
||||||
|
|
||||||
**--limit, --lm**="": specify limit of items per page (default: 30)
|
**--limit, --lm**="": specify limit of items per page (default: 30)
|
||||||
|
|
||||||
**--login, -l**="": Use a different Gitea Login. Optional
|
**--login, -l**="": Use a different Gitea Login. Optional
|
||||||
|
|
||||||
|
**--org**="": List organization labels
|
||||||
|
|
||||||
**--output, -o**="": Output format. (simple, table, csv, tsv, yaml, json)
|
**--output, -o**="": Output format. (simple, table, csv, tsv, yaml, json)
|
||||||
|
|
||||||
**--page, -p**="": specify page (default: 1)
|
**--page, -p**="": specify page (default: 1)
|
||||||
|
|||||||
@@ -5,8 +5,9 @@ package print
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"gitea.dev/sdk"
|
gitea "gitea.dev/sdk"
|
||||||
)
|
)
|
||||||
|
|
||||||
// LabelsList prints a listing of labels
|
// LabelsList prints a listing of labels
|
||||||
@@ -16,14 +17,20 @@ func LabelsList(labels []*gitea.Label, output string) error {
|
|||||||
"Color",
|
"Color",
|
||||||
"Name",
|
"Name",
|
||||||
"Description",
|
"Description",
|
||||||
|
"Level",
|
||||||
)
|
)
|
||||||
|
|
||||||
for _, label := range labels {
|
for _, label := range labels {
|
||||||
|
level := "Repository"
|
||||||
|
if strings.Contains(label.URL, "/orgs/") {
|
||||||
|
level = "Organization"
|
||||||
|
}
|
||||||
t.addRow(
|
t.addRow(
|
||||||
strconv.FormatInt(label.ID, 10),
|
strconv.FormatInt(label.ID, 10),
|
||||||
formatLabel(label, !isMachineReadable(output), label.Color),
|
formatLabel(label, !isMachineReadable(output), label.Color),
|
||||||
label.Name,
|
label.Name,
|
||||||
label.Description,
|
label.Description,
|
||||||
|
level,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
return t.print(output)
|
return t.print(output)
|
||||||
|
|||||||
@@ -23,6 +23,16 @@ func ResolveLabelNames(requestCtx stdctx.Context, client *gitea.Client, owner, r
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
if _, _, err := client.Organizations.GetOrg(requestCtx, owner); err == nil {
|
||||||
|
orgLabels, _, err := client.Organizations.ListOrgLabels(requestCtx, owner, gitea.ListOrgLabelsOptions{
|
||||||
|
ListOptions: gitea.ListOptions{Page: page, PageSize: 50},
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
labels = append(labels, orgLabels...)
|
||||||
|
}
|
||||||
|
|
||||||
for _, l := range labels {
|
for _, l := range labels {
|
||||||
if utils.Contains(labelNames, l.Name) {
|
if utils.Contains(labelNames, l.Name) {
|
||||||
labelIDs = append(labelIDs, l.ID)
|
labelIDs = append(labelIDs, l.ID)
|
||||||
|
|||||||
@@ -0,0 +1,162 @@
|
|||||||
|
// Copyright 2026 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package integration
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
gitea "gitea.dev/sdk"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func setupOrgRepoWithLabels(t *testing.T) (org *gitea.Organization, orgRepo *gitea.Repository, orgLabel, repoLabel *gitea.Label) {
|
||||||
|
t.Helper()
|
||||||
|
|
||||||
|
login := createIntegrationLogin(t)
|
||||||
|
client := login.Client()
|
||||||
|
orgName := fmt.Sprintf("labels-org-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
orgRepoName := fmt.Sprintf("labels-repo-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
// Clean up any existing test data that might interfere with the test.
|
||||||
|
_, _ = client.Repositories.DeleteRepo(ctx, orgName, orgRepoName)
|
||||||
|
_, _ = client.Organizations.DeleteOrg(ctx, orgName)
|
||||||
|
|
||||||
|
org, _, err := client.Organizations.CreateOrg(ctx, gitea.CreateOrgOption{Name: orgName})
|
||||||
|
require.NoError(t, err)
|
||||||
|
t.Cleanup(func() {
|
||||||
|
if _, delErr := client.Organizations.DeleteOrg(ctx, orgName); delErr != nil {
|
||||||
|
t.Logf("failed to delete integration test org %q: %v", orgName, delErr)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
orgRepo, _, err = client.Repositories.CreateOrgRepo(ctx, orgName, gitea.CreateRepoOption{Name: orgRepoName})
|
||||||
|
require.NoError(t, err)
|
||||||
|
t.Cleanup(func() {
|
||||||
|
if _, delErr := client.Repositories.DeleteRepo(ctx, orgName, orgRepoName); delErr != nil {
|
||||||
|
t.Logf("failed to delete integration test repo %q: %v", orgRepoName, delErr)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
orgLabelName := fmt.Sprintf("org-label-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
repoLabelName := fmt.Sprintf("repo-label-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
|
||||||
|
orgLabel, _, err = client.Organizations.CreateOrgLabel(ctx, orgName, gitea.CreateOrgLabelOption{Name: orgLabelName, Color: "ff0000"})
|
||||||
|
require.NoError(t, err)
|
||||||
|
repoLabel, _, err = client.Repositories.CreateLabel(ctx, orgName, orgRepoName, gitea.CreateLabelOption{Name: repoLabelName, Color: "00ff00"})
|
||||||
|
require.NoError(t, err)
|
||||||
|
return org, orgRepo, orgLabel, repoLabel
|
||||||
|
}
|
||||||
|
|
||||||
|
func setupRepoWithLabels(t *testing.T) (repo *gitea.Repository, repoLabel *gitea.Label) {
|
||||||
|
t.Helper()
|
||||||
|
|
||||||
|
login := createIntegrationLogin(t)
|
||||||
|
client := login.Client()
|
||||||
|
repoName := fmt.Sprintf("labels-repo-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
// Clean up any existing test data that might interfere with the test.
|
||||||
|
_, _ = client.Repositories.DeleteRepo(ctx, login.User, repoName)
|
||||||
|
|
||||||
|
repo, _, err := client.Repositories.CreateRepo(ctx, gitea.CreateRepoOption{Name: repoName})
|
||||||
|
require.NoError(t, err)
|
||||||
|
t.Cleanup(func() {
|
||||||
|
if _, delErr := client.Repositories.DeleteRepo(ctx, login.User, repoName); delErr != nil {
|
||||||
|
t.Logf("failed to delete integration test repo %q: %v", repoName, delErr)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
repoLabelName := fmt.Sprintf("repo-label-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
repoLabel, _, err = client.Repositories.CreateLabel(ctx, login.User, repoName, gitea.CreateLabelOption{Name: repoLabelName, Color: "00ff00"})
|
||||||
|
require.NoError(t, err)
|
||||||
|
return repo, repoLabel
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRunLabelsList_OrgFlagReturnsOnlyOrgLabels(t *testing.T) {
|
||||||
|
// This test verifies that when listing labels with only the --org flag set,
|
||||||
|
// only organization labels are included in the results, and repository labels are excluded.
|
||||||
|
_, orgRepo, orgLabel, _ := setupOrgRepoWithLabels(t)
|
||||||
|
|
||||||
|
labelIDs := runTeaCommand(t, "label", "ls", "--org", orgRepo.Owner.UserName, "--output", "json")
|
||||||
|
var rows []map[string]string
|
||||||
|
require.NoError(t, json.Unmarshal([]byte(labelIDs), &rows))
|
||||||
|
|
||||||
|
require.Len(t, rows, 1)
|
||||||
|
indexInt, err := strconv.ParseInt(rows[0]["index"], 10, 64)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, orgLabel.ID, indexInt)
|
||||||
|
require.Equal(t, orgLabel.Name, rows[0]["name"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRunLabelsList_RepoReturnsNoOrgLabels(t *testing.T) {
|
||||||
|
// This test verifies that when listing labels for a repository with no organization,
|
||||||
|
// organization labels are not included in the results.
|
||||||
|
repo, repoLabel := setupRepoWithLabels(t)
|
||||||
|
|
||||||
|
labelIDs := runTeaCommand(t, "label", "ls", "--repo", repo.FullName, "--output", "json")
|
||||||
|
var rows []map[string]string
|
||||||
|
require.NoError(t, json.Unmarshal([]byte(labelIDs), &rows))
|
||||||
|
|
||||||
|
require.Len(t, rows, 1)
|
||||||
|
indexInt, err := strconv.ParseInt(rows[0]["index"], 10, 64)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, repoLabel.ID, indexInt)
|
||||||
|
require.Equal(t, repoLabel.Name, rows[0]["name"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRunLabelsList_UseRepoFlagOverOrgFlag(t *testing.T) {
|
||||||
|
// This test verifies that when both --org and --repo flags are set,
|
||||||
|
// the command prioritizes the --repo flag and lists labels for the repository, ignoring the --org flag.
|
||||||
|
repo, repoLabel := setupRepoWithLabels(t)
|
||||||
|
|
||||||
|
labelIDs := runTeaCommand(t, "label", "ls", "--repo", repo.FullName, "--org", "some-other-org", "--output", "json")
|
||||||
|
var rows []map[string]string
|
||||||
|
require.NoError(t, json.Unmarshal([]byte(labelIDs), &rows))
|
||||||
|
|
||||||
|
require.Len(t, rows, 1)
|
||||||
|
indexInt, err := strconv.ParseInt(rows[0]["index"], 10, 64)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, repoLabel.ID, indexInt)
|
||||||
|
require.Equal(t, repoLabel.Name, rows[0]["name"])
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRunLabelsList_OrgRepoReturnsRepoAndOrgLabels(t *testing.T) {
|
||||||
|
// This test verifies that when listing labels for a repository that belongs to an organization,
|
||||||
|
// both repository and organization labels are included in the results.
|
||||||
|
_, orgRepo, orgLabel, repoLabel := setupOrgRepoWithLabels(t)
|
||||||
|
|
||||||
|
labelIDs := runTeaCommand(t, "label", "ls", "--repo", orgRepo.FullName, "--output", "json")
|
||||||
|
var rows []map[string]string
|
||||||
|
require.NoError(t, json.Unmarshal([]byte(labelIDs), &rows))
|
||||||
|
|
||||||
|
require.Len(t, rows, 2)
|
||||||
|
require.ElementsMatch(t, []string{rows[0]["name"], rows[1]["name"]}, []string{orgLabel.Name, repoLabel.Name})
|
||||||
|
require.ElementsMatch(
|
||||||
|
t,
|
||||||
|
[]string{rows[0]["index"], rows[1]["index"]},
|
||||||
|
[]string{strconv.FormatInt(orgLabel.ID, 10), strconv.FormatInt(repoLabel.ID, 10)},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestRunLabelsList_OrgRepoWithExcludeReturnsOnlyRepoLabels(t *testing.T) {
|
||||||
|
// This test verifies that when listing labels for a repository that belongs to an organization with the --exclude flag,
|
||||||
|
// only repository labels are included in the results, and organization labels are excluded.
|
||||||
|
_, orgRepo, _, repoLabel := setupOrgRepoWithLabels(t)
|
||||||
|
|
||||||
|
labelIDs := runTeaCommand(t, "label", "ls", "--repo", orgRepo.FullName, "--exclude-org", "--output", "json")
|
||||||
|
var rows []map[string]string
|
||||||
|
require.NoError(t, json.Unmarshal([]byte(labelIDs), &rows))
|
||||||
|
|
||||||
|
require.Len(t, rows, 1)
|
||||||
|
indexInt, err := strconv.ParseInt(rows[0]["index"], 10, 64)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, repoLabel.ID, indexInt)
|
||||||
|
require.Equal(t, repoLabel.Name, rows[0]["name"])
|
||||||
|
}
|
||||||
@@ -0,0 +1,124 @@
|
|||||||
|
// Copyright 2026 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package integration
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
gitea "gitea.dev/sdk"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestResolveLabelNames_ReturnsRepoAndOrgLabels(t *testing.T) {
|
||||||
|
// This test verifies that ResolveLabelNames correctly returns both repository and organization labels.
|
||||||
|
// It sets up a test repository and organization with known labels, then calls ResolveLabelNames and checks the results.
|
||||||
|
login := createIntegrationLogin(t)
|
||||||
|
client := login.Client()
|
||||||
|
orgName := fmt.Sprintf("labels-org-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
orgRepoName := fmt.Sprintf("labels-repo-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
// Clean up any existing test data that might interfere with the test.
|
||||||
|
_, _ = client.Repositories.DeleteRepo(ctx, orgName, orgRepoName)
|
||||||
|
_, _ = client.Organizations.DeleteOrg(ctx, orgName)
|
||||||
|
|
||||||
|
_, _, err := client.Admin.CreateOrg(ctx, integrationUsername, gitea.CreateOrgOption{Name: orgName})
|
||||||
|
require.NoError(t, err)
|
||||||
|
t.Cleanup(func() {
|
||||||
|
if _, delErr := client.Organizations.DeleteOrg(ctx, orgName); delErr != nil {
|
||||||
|
t.Logf("failed to delete integration test org %q: %v", orgName, delErr)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
orgRepo, _, err := client.Repositories.CreateOrgRepo(ctx, orgName, gitea.CreateRepoOption{Name: orgRepoName})
|
||||||
|
require.NoError(t, err)
|
||||||
|
t.Cleanup(func() {
|
||||||
|
if _, delErr := client.Repositories.DeleteRepo(ctx, orgName, orgRepoName); delErr != nil {
|
||||||
|
t.Logf("failed to delete integration test repo %q: %v", orgRepoName, delErr)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
orgLabelName := fmt.Sprintf("org-label-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
repoLabelName := fmt.Sprintf("repo-label-%d", time.Now().UnixNano()%1_000_000)
|
||||||
|
|
||||||
|
orgLabel, _, err := client.Organizations.CreateOrgLabel(ctx, orgName, gitea.CreateOrgLabelOption{Name: orgLabelName, Color: "ff0000"})
|
||||||
|
require.NoError(t, err)
|
||||||
|
repoLabel, _, err := client.Repositories.CreateLabel(ctx, orgName, orgRepoName, gitea.CreateLabelOption{Name: repoLabelName, Color: "00ff00"})
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
tmpDir := t.TempDir()
|
||||||
|
|
||||||
|
runGit := func(args ...string) {
|
||||||
|
cmd := exec.Command("git", args...)
|
||||||
|
cmd.Dir = tmpDir
|
||||||
|
require.NoError(t, cmd.Run())
|
||||||
|
}
|
||||||
|
|
||||||
|
runGit("init")
|
||||||
|
runGit("config", "user.email", "test@test.com")
|
||||||
|
runGit("config", "user.name", "test")
|
||||||
|
httpsURL := fmt.Sprintf("%s/%s.git", login.URL, orgRepo.FullName)
|
||||||
|
httpsURL = strings.Replace(httpsURL, "://", fmt.Sprintf("://%s:%s@", login.Name, login.Token), 1)
|
||||||
|
|
||||||
|
runGit("remote", "add", "origin", httpsURL)
|
||||||
|
|
||||||
|
runGit("checkout", "-b", "main")
|
||||||
|
runGit("commit", "--allow-empty", "-m", "Initial commit")
|
||||||
|
runGit("push", "-u", "origin", "HEAD:main")
|
||||||
|
|
||||||
|
runGit("checkout", "-b", "branch-with-labels")
|
||||||
|
runGit("commit", "--allow-empty", "-m", "Initial commit")
|
||||||
|
runGit("push", "-u", "origin", "HEAD:branch-with-labels")
|
||||||
|
|
||||||
|
waitForBranches(t, orgRepo.FullName)
|
||||||
|
_ = runTeaCommand(
|
||||||
|
t, "pr", "create", "--repo", orgRepo.FullName,
|
||||||
|
"--login", login.Name, "--base", "main", "--head", "branch-with-labels",
|
||||||
|
"--labels", orgLabelName+","+repoLabelName,
|
||||||
|
)
|
||||||
|
|
||||||
|
pr, _, err := client.PullRequests.GetPullRequest(ctx, orgName, orgRepoName, 1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
labels := pr.Labels
|
||||||
|
require.Len(t, labels, 2)
|
||||||
|
require.ElementsMatch(t, labels, []*gitea.Label{orgLabel, repoLabel})
|
||||||
|
}
|
||||||
|
|
||||||
|
func waitForBranches(t *testing.T, repoFullName string) {
|
||||||
|
t.Helper()
|
||||||
|
url := fmt.Sprintf("%s/api/v1/repos/%s/branches", os.Getenv("GITEA_TEA_TEST_URL"), repoFullName)
|
||||||
|
|
||||||
|
// retry for ~6 seconds
|
||||||
|
for range 30 {
|
||||||
|
resp, err := http.Get(url)
|
||||||
|
if err == nil {
|
||||||
|
body, _ := io.ReadAll(resp.Body)
|
||||||
|
resp.Body.Close()
|
||||||
|
var branches []struct {
|
||||||
|
Name string `json:"name"`
|
||||||
|
}
|
||||||
|
if json.Unmarshal(body, &branches) == nil {
|
||||||
|
have := map[string]bool{}
|
||||||
|
for _, b := range branches {
|
||||||
|
have[b.Name] = true
|
||||||
|
}
|
||||||
|
if have["main"] && have["branch-with-labels"] {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
time.Sleep(200 * time.Millisecond)
|
||||||
|
}
|
||||||
|
t.Fatalf("waitForBranches: branches never appeared in API: %s", url)
|
||||||
|
}
|
||||||
@@ -14,7 +14,7 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"gitea.dev/sdk"
|
gitea "gitea.dev/sdk"
|
||||||
teacmd "gitea.dev/tea/cmd"
|
teacmd "gitea.dev/tea/cmd"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
@@ -25,10 +25,10 @@ func TestWikiCommandLifecycle(t *testing.T) {
|
|||||||
client := login.Client()
|
client := login.Client()
|
||||||
repoName := fmt.Sprintf("tea-wiki-integration-%d", time.Now().UnixNano())
|
repoName := fmt.Sprintf("tea-wiki-integration-%d", time.Now().UnixNano())
|
||||||
|
|
||||||
_, _, err := client.CreateRepo(context.Background(), gitea.CreateRepoOption{Name: repoName})
|
_, _, err := client.Repositories.CreateRepo(context.Background(), gitea.CreateRepoOption{Name: repoName})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
t.Cleanup(func() {
|
t.Cleanup(func() {
|
||||||
if _, delErr := client.DeleteRepo(context.Background(), login.User, repoName); delErr != nil {
|
if _, delErr := client.Repositories.DeleteRepo(context.Background(), login.User, repoName); delErr != nil {
|
||||||
t.Logf("failed to delete integration test repo %q: %v", repoName, delErr)
|
t.Logf("failed to delete integration test repo %q: %v", repoName, delErr)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@@ -60,10 +60,10 @@ func TestWikiCommandLifecycle(t *testing.T) {
|
|||||||
assert.Contains(t, listOutput, "\"title\": \"Home\"")
|
assert.Contains(t, listOutput, "\"title\": \"Home\"")
|
||||||
|
|
||||||
emptyRepoName := fmt.Sprintf("tea-wiki-empty-%d", time.Now().UnixNano())
|
emptyRepoName := fmt.Sprintf("tea-wiki-empty-%d", time.Now().UnixNano())
|
||||||
_, _, err = client.CreateRepo(context.Background(), gitea.CreateRepoOption{Name: emptyRepoName})
|
_, _, err = client.Repositories.CreateRepo(context.Background(), gitea.CreateRepoOption{Name: emptyRepoName})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
t.Cleanup(func() {
|
t.Cleanup(func() {
|
||||||
if _, delErr := client.DeleteRepo(context.Background(), login.User, emptyRepoName); delErr != nil {
|
if _, delErr := client.Repositories.DeleteRepo(context.Background(), login.User, emptyRepoName); delErr != nil {
|
||||||
t.Logf("failed to delete empty wiki repo %q: %v", emptyRepoName, delErr)
|
t.Logf("failed to delete empty wiki repo %q: %v", emptyRepoName, delErr)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user