diff --git a/lib/modules/platform/gitlab/__snapshots__/index.spec.ts.snap b/lib/modules/platform/gitlab/__snapshots__/index.spec.ts.snap index 7d0bdd4c0054856d7a1ea9ccaf9b4e8bccf67ed8..06500946e7ef65ec37e2a920856ce1bf4ec1b872 100644 --- a/lib/modules/platform/gitlab/__snapshots__/index.spec.ts.snap +++ b/lib/modules/platform/gitlab/__snapshots__/index.spec.ts.snap @@ -68,12 +68,7 @@ exports[`modules/platform/gitlab/index getBranchPr(branchName) should return the "hash": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", }, "hasAssignees": false, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, - "labels": undefined, "number": 91, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "open", "targetBranch": "master", @@ -87,13 +82,8 @@ exports[`modules/platform/gitlab/index getBranchPr(branchName) should strip depr "hash": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", }, "hasAssignees": false, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, "isDraft": true, - "labels": undefined, "number": 91, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "open", "targetBranch": "master", @@ -107,13 +97,8 @@ exports[`modules/platform/gitlab/index getBranchPr(branchName) should strip draf "hash": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", }, "hasAssignees": false, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, "isDraft": true, - "labels": undefined, "number": 91, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "open", "targetBranch": "master", @@ -127,13 +112,8 @@ exports[`modules/platform/gitlab/index getPr(prNo) removes deprecated draft pref "hash": "23f41dbec0785a6c77457dd6ebf99ae5970c5fffc9f7a8ad7f66c1b8eeba5b90", }, "hasAssignees": false, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, "isDraft": true, - "labels": undefined, "number": 12345, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "merged", "targetBranch": "master", @@ -147,13 +127,8 @@ exports[`modules/platform/gitlab/index getPr(prNo) removes draft prefix from ret "hash": "23f41dbec0785a6c77457dd6ebf99ae5970c5fffc9f7a8ad7f66c1b8eeba5b90", }, "hasAssignees": false, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, "isDraft": true, - "labels": undefined, "number": 12345, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "merged", "targetBranch": "master", @@ -167,12 +142,7 @@ exports[`modules/platform/gitlab/index getPr(prNo) returns the PR 1`] = ` "hash": "23f41dbec0785a6c77457dd6ebf99ae5970c5fffc9f7a8ad7f66c1b8eeba5b90", }, "hasAssignees": false, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, - "labels": undefined, "number": 12345, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "merged", "targetBranch": "master", @@ -186,12 +156,7 @@ exports[`modules/platform/gitlab/index getPr(prNo) returns the PR with nonexisti "hash": "23f41dbec0785a6c77457dd6ebf99ae5970c5fffc9f7a8ad7f66c1b8eeba5b90", }, "hasAssignees": true, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, - "labels": undefined, "number": 12345, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "open", "targetBranch": "master", @@ -205,12 +170,7 @@ exports[`modules/platform/gitlab/index getPr(prNo) returns the mergeable PR 1`] "hash": "23f41dbec0785a6c77457dd6ebf99ae5970c5fffc9f7a8ad7f66c1b8eeba5b90", }, "hasAssignees": true, - "headPipelineSha": undefined, - "headPipelineStatus": undefined, - "labels": undefined, "number": 12345, - "reviewers": undefined, - "sha": undefined, "sourceBranch": "some-branch", "state": "open", "targetBranch": "master", diff --git a/lib/modules/platform/gitlab/index.spec.ts b/lib/modules/platform/gitlab/index.spec.ts index 1fc1fce268550a0e05e7fa9f712da700bb2975c2..90b220ec17e0e339c9ed91e53cc9136aebc88e4e 100644 --- a/lib/modules/platform/gitlab/index.spec.ts +++ b/lib/modules/platform/gitlab/index.spec.ts @@ -2947,6 +2947,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'branch a pr', + description: 'a merge request', state: 'open', }, ]) @@ -2969,6 +2970,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'Draft: foo', + description: 'a merge request', state: 'open', }, ]) @@ -2991,6 +2993,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'WIP: foo', + description: 'a merge request', state: 'open', }, ]) @@ -3013,6 +3016,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'branch a pr', + description: 'a merge request', state: 'open', target_branch: 'branch-b', }, @@ -3042,6 +3046,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'branch a pr', + description: 'a merge request', state: 'open', }, ]) @@ -3073,6 +3078,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'branch a pr', + description: 'a merge request', state: 'open', }, ]) @@ -3100,6 +3106,7 @@ describe('modules/platform/gitlab/index', () => { iid: 1, source_branch: 'branch-a', title: 'branch a pr', + description: 'a merge request', state: 'open', }, ]) diff --git a/lib/modules/platform/gitlab/index.ts b/lib/modules/platform/gitlab/index.ts index c8ba81c0dfc89429f1ad925697d8be77d0d1870f..afc81044bcc6a75f03ab768cb51300bb67c331b8 100644 --- a/lib/modules/platform/gitlab/index.ts +++ b/lib/modules/platform/gitlab/index.ts @@ -32,7 +32,6 @@ import { getQueryString, parseUrl, } from '../../../util/url'; -import { getPrBodyStruct } from '../pr-body'; import type { AutodiscoverConfig, BranchStatusConfig, @@ -72,6 +71,7 @@ import type { MergeMethod, RepoResponse, } from './types'; +import { DRAFT_PREFIX, DRAFT_PREFIX_DEPRECATED, prInfo } from './utils'; let config: { repository: string; @@ -93,9 +93,6 @@ const defaults = { export const id = 'gitlab'; -const DRAFT_PREFIX = 'Draft: '; -const DRAFT_PREFIX_DEPRECATED = 'WIP: '; - let draftPrefix = DRAFT_PREFIX; export async function initPlatform({ @@ -560,24 +557,10 @@ async function fetchPrList(): Promise<Pr[]> { const query = getQueryString(searchParams); const urlString = `projects/${config.repository}/merge_requests?${query}`; try { - const res = await gitlabApi.getJson< - { - iid: number; - source_branch: string; - title: string; - state: string; - created_at: string; - }[] - >(urlString, { paginate: true }); - return res.body.map((pr) => - massagePr({ - number: pr.iid, - sourceBranch: pr.source_branch, - title: pr.title, - state: pr.state === 'opened' ? 'open' : pr.state, - createdAt: pr.created_at, - }), - ); + const res = await gitlabApi.getJson<GitLabMergeRequest[]>(urlString, { + paginate: true, + }); + return res.body.map((pr) => prInfo(pr)); } catch (err) /* istanbul ignore next */ { logger.debug({ err }, 'Error fetching PR list'); if (err.statusCode === 403) { @@ -800,22 +783,7 @@ export async function getPr(iid: number): Promise<GitlabPr> { const mr = await getMR(config.repository, iid); // Harmonize fields with GitHub - const pr: GitlabPr = { - sourceBranch: mr.source_branch, - targetBranch: mr.target_branch, - number: mr.iid, - bodyStruct: getPrBodyStruct(mr.description), - state: mr.state === 'opened' ? 'open' : mr.state, - headPipelineStatus: mr.head_pipeline?.status, - headPipelineSha: mr.head_pipeline?.sha, - hasAssignees: !!(mr.assignee?.id ?? mr.assignees?.[0]?.id), - reviewers: mr.reviewers?.map(({ username }) => username), - title: mr.title, - labels: mr.labels, - sha: mr.sha, - }; - - return massagePr(pr); + return prInfo(mr); } export async function updatePr({ @@ -960,18 +928,7 @@ export async function findPr({ return null; } - // return the latest merge request - const mr = mrList[0]; - - // only pass necessary info - const pr: GitlabPr = { - sourceBranch: mr.source_branch, - number: mr.iid, - state: 'open', - title: mr.title, - }; - - return massagePr(pr); + return prInfo(mrList[0]); } const prList = await getPrList(); diff --git a/lib/modules/platform/gitlab/utils.ts b/lib/modules/platform/gitlab/utils.ts new file mode 100644 index 0000000000000000000000000000000000000000..afba4ffd165d97acbaeeeea3b600b43a5cf6c53c --- /dev/null +++ b/lib/modules/platform/gitlab/utils.ts @@ -0,0 +1,41 @@ +import is from '@sindresorhus/is'; +import { getPrBodyStruct } from '../pr-body'; +import type { GitLabMergeRequest, GitlabPr } from './types'; + +export const DRAFT_PREFIX = 'Draft: '; +export const DRAFT_PREFIX_DEPRECATED = 'WIP: '; + +export function prInfo(mr: GitLabMergeRequest): GitlabPr { + const pr: GitlabPr = { + sourceBranch: mr.source_branch, + state: mr.state === 'opened' ? 'open' : mr.state, + number: mr.iid, + title: mr.title, + hasAssignees: !!(mr.assignee?.id ?? mr.assignees?.[0]?.id), + bodyStruct: getPrBodyStruct(mr.description), + + ...(mr.target_branch && { targetBranch: mr.target_branch }), + + ...(mr.head_pipeline?.status && { + headPipelineStatus: mr.head_pipeline?.status, + }), + ...(mr.head_pipeline?.sha && { headPipelineSha: mr.head_pipeline?.sha }), + + ...(is.nonEmptyArray(mr.reviewers) && { + reviewers: mr.reviewers?.map(({ username }) => username), + }), + + ...(mr.labels && { labels: mr.labels }), + ...(mr.sha && { sha: mr.sha }), + }; + + if (pr.title.startsWith(DRAFT_PREFIX)) { + pr.title = pr.title.substring(DRAFT_PREFIX.length); + pr.isDraft = true; + } else if (pr.title.startsWith(DRAFT_PREFIX_DEPRECATED)) { + pr.title = pr.title.substring(DRAFT_PREFIX_DEPRECATED.length); + pr.isDraft = true; + } + + return pr; +}