mirror of
https://github.com/actions/github-script.git
synced 2025-12-08 16:16:21 +00:00
`core.getInput()` always returns a string, so testing for 'not null' is always true. This then leads to previews set to an array with a single empty string, breaking accept-header output. Updated eslint rules should help avoid this issue in future, and new integration tests verify that the github client configuration now reflects the intended configuration options.
54 lines
1.4 KiB
TypeScript
54 lines
1.4 KiB
TypeScript
import * as core from '@actions/core'
|
|
import {OctokitOptions} from '@octokit/core/dist-types/types'
|
|
import {RequestRequestOptions} from '@octokit/types'
|
|
|
|
export type RetryOptions = {
|
|
doNotRetry?: number[]
|
|
enabled?: boolean
|
|
}
|
|
|
|
export function getRetryOptions(
|
|
retries: number,
|
|
exemptStatusCodes: number[],
|
|
defaultOptions: OctokitOptions
|
|
): [RetryOptions, RequestRequestOptions | undefined] {
|
|
if (retries <= 0) {
|
|
return [{enabled: false}, defaultOptions.request]
|
|
}
|
|
|
|
const retryOptions: RetryOptions = {
|
|
enabled: true
|
|
}
|
|
|
|
if (exemptStatusCodes.length > 0) {
|
|
retryOptions.doNotRetry = exemptStatusCodes
|
|
}
|
|
|
|
// The GitHub type has some defaults for `options.request`
|
|
// see: https://github.com/actions/toolkit/blob/4fbc5c941a57249b19562015edbd72add14be93d/packages/github/src/utils.ts#L15
|
|
// We pass these in here so they are not overidden.
|
|
const requestOptions: RequestRequestOptions = {
|
|
...defaultOptions.request,
|
|
retries
|
|
}
|
|
|
|
core.debug(
|
|
`GitHub client configured with: (retries: ${
|
|
requestOptions.retries
|
|
}, retry-exempt-status-code: ${
|
|
retryOptions.doNotRetry ?? 'octokit default: [400, 401, 403, 404, 422]'
|
|
})`
|
|
)
|
|
|
|
return [retryOptions, requestOptions]
|
|
}
|
|
|
|
export function parseNumberArray(listString: string): number[] {
|
|
if (!listString) {
|
|
return []
|
|
}
|
|
|
|
const split = listString.trim().split(',')
|
|
return split.map(x => parseInt(x))
|
|
}
|