Skip to content

feat(platforms/bitbucket): validate API returns using schemas#43942

Draft
secustor wants to merge 7 commits into
renovatebot:mainfrom
secustor:fix/getjsonunchecked-03-bitbucket-cloud
Draft

feat(platforms/bitbucket): validate API returns using schemas#43942
secustor wants to merge 7 commits into
renovatebot:mainfrom
secustor:fix/getjsonunchecked-03-bitbucket-cloud

Conversation

@secustor

Copy link
Copy Markdown
Member

Changes

Changes all Json requests where we read the Body to schema validated variants
This PR contains only BitBucket Cloud changes

Context

03/13

Please select one of the following:

  • This closes an existing Issue, Closes: #
  • This doesn't close an Issue, but I accept the risk that this PR may be closed if maintainers disagree with its opening or implementation

AI assistance disclosure

Did you use AI tools to create any part of this pull request?

Please select one option and, if yes, briefly describe how AI was used (e.g., code, tests, docs) and which tool(s) you used.

  • No — I did not use AI for this contribution.
  • Yes — minimal assistance (e.g., IDE autocomplete, small code completions, grammar fixes).
  • Yes — substantive assistance (AI-generated non‑trivial portions of code, tests, or documentation).
  • Yes — other (please describe):

Documentation (please check one with an [x])

  • I have updated the documentation, or
  • No documentation update is required

How I've tested my work (please select one)

I have verified these changes via:

  • Code inspection only, or
  • Newly added/modified unit tests, or
  • No unit tests, but ran on a real repository, or
  • Both unit tests + ran on a real repository

The public repository:

secustor and others added 7 commits June 11, 2026 15:31
Migrate all getJsonUnchecked calls in Bitbucket Cloud platform and
bitbucket-tags datasource to use Zod-validated getJson calls.

Added new Zod schemas to lib/modules/platform/bitbucket/schema.ts for
Account, RepoBranchingModel, BranchResponse, BitbucketStatus, PrResponse,
EffectiveReviewer, Comment, BbIssue, and a reusable PagedResult helper.

Created lib/modules/datasource/bitbucket-tags/schema.ts with BitbucketTag,
BitbucketCommit, BitbucketTagsResult, and BitbucketCommitsResult schemas.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>

# Conflicts:
#	lib/modules/datasource/bitbucket-tags/index.ts
#	lib/modules/datasource/bitbucket-tags/schema.ts
- Make `PrResponse.links` and `updated_on` optional (API field used for
  caching but not always populated in test fixtures)
- Make `Comment.id` and `Comment.user` optional to handle partial comment
  objects (not all comments have both fields in all contexts)
- Make `EffectiveReviewer.type` and `reviewer_type` optional
- Add `UserInfo` schema for the `/2.0/users/{uuid}` endpoint (only needs
  `account_status`, not the full `Account` shape)
- Make `BitbucketTag.target.hash` optional (not needed when listing tags,
  only for single-tag digest lookups)
- Update `types.ts` to mark `PrResponse.links` and `updated_on` optional
- Update `pr-cache.ts` to handle optional `updated_on` in reconcile logic
- Guard `comment.user` access in `findPr` before calling workspace check
- Update test fixtures to include `created_on`, `title` where missing
- Fix `updatePr` test mocks to return valid `PrResponse` for single PR
- Fix `createPr` local variable naming to avoid TDZ with global `pr`
- Update `getPrList > filters PR list by author` snapshot

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
@secustor secustor requested a review from setchy June 11, 2026 15:18
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant