1
0
Fork 0
mirror of https://gitea.com/gitea/tea.git synced 2026-04-25 08:37:48 +02:00
tea/cmd
Alain Thiffault 5103496232 fix(pagination): replace Page:-1 with explicit pagination loops (#967)
## Summary

\`Page: -1\` in the Gitea SDK calls \`setDefaults()\` which sets both \`Page=0\` and \`PageSize=0\`, resulting in \`?page=0&limit=0\` being sent to the server. The server interprets \`limit=0\` as "use server default" (typically 30 items via \`DEFAULT_PAGING_NUM\`), not "return everything". Any resource beyond the first page of results was silently invisible.

This affected 8 call sites, with the most user-visible impact being \`tea issues edit --add-labels\` and \`tea pulls edit --add-labels\` silently failing to apply labels on repositories with more than ~30 labels.

## Affected call sites

| File | API call | User-visible impact |
|---|---|---|
| \`modules/task/labels.go\` | \`ListRepoLabels\` | \`issues/pulls edit --add-labels\` fails silently |
| \`modules/interact/issue_create.go\` | \`ListRepoLabels\` | interactive label picker missing labels |
| \`modules/task/pull_review_comment.go\` | \`ListPullReviews\` | review comments truncated |
| \`modules/task/login_ssh.go\` | \`ListMyPublicKeys\` | SSH key auto-detection fails |
| \`modules/task/login_create.go\` | \`ListAccessTokens\` | token name deduplication misses existing tokens |
| \`cmd/pulls.go\` | \`ListPullReviews\` | PR detail view missing reviews |
| \`cmd/releases/utils.go\` | \`ListReleases\` | tag lookup fails on repos with many releases |
| \`cmd/attachments/delete.go\` | \`ListReleaseAttachments\` | attachment deletion fails when many attachments exist |

## Fix

Each call site is replaced with an explicit pagination loop that follows \`resp.NextPage\` until all pages are exhausted.

Reviewed-on: https://gitea.com/gitea/tea/pulls/967
Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
Co-authored-by: Alain Thiffault <athiffau@effectivemomentum.com>
Co-committed-by: Alain Thiffault <athiffau@effectivemomentum.com>
2026-04-23 17:06:42 +00:00
..
actions feat(workflows): add dispatch, view, enable and disable subcommands (#952) 2026-04-09 20:03:33 +00:00
admin/users replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
attachments fix(pagination): replace Page:-1 with explicit pagination loops (#967) 2026-04-23 17:06:42 +00:00
branches feat(branches): add rename subcommand (#939) 2026-04-15 17:27:47 +00:00
flags refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
issues replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
labels replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
login refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
milestones replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
notifications replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
organizations replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
pulls feat(pulls): add ci status field to pull request list (#956) 2026-04-10 17:29:15 +00:00
releases fix(pagination): replace Page:-1 with explicit pagination loops (#967) 2026-04-23 17:06:42 +00:00
repos refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
times refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
webhooks replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
actions.go Add tea actions runs and workflows commands (#880) 2026-02-11 00:40:06 +00:00
admin.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
api.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
api_test.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
attachments.go migrate tea to urfave v3 (#760) 2025-06-10 05:19:59 +00:00
branches.go feat(branches): add rename subcommand (#939) 2026-04-15 17:27:47 +00:00
categories.go spdx (#581) 2023-09-08 01:40:02 +00:00
clone.go refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
cmd.go Move versions/filelocker into dedicated subpackages, and consistent headers in http requests (#888) 2026-02-05 18:05:43 +00:00
comment.go refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
detail_json.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
issues.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
issues_test.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
labels.go refactor: code cleanup across codebase (#947) 2026-04-08 03:38:49 +00:00
login.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
logout.go migrate tea to urfave v3 (#760) 2025-06-10 05:19:59 +00:00
man.go generate man page (#811) 2025-09-14 00:17:28 +00:00
milestones.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
notifications.go migrate tea to urfave v3 (#760) 2025-06-10 05:19:59 +00:00
open.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
organizations.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
pulls.go fix(pagination): replace Page:-1 with explicit pagination loops (#967) 2026-04-23 17:06:42 +00:00
releases.go migrate tea to urfave v3 (#760) 2025-06-10 05:19:59 +00:00
repos.go fix(cmd): Update CmdRepos description and usage in repos.go (#946) 2026-04-20 19:50:28 +00:00
times.go migrate tea to urfave v3 (#760) 2025-06-10 05:19:59 +00:00
webhooks.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00
whoami.go replace log.Fatal/os.Exit with error returns (#941) 2026-03-27 03:36:44 +00:00