mirror of https://github.com/actions/setup-python
testing with conditions
This commit is contained in:
parent
996d9604f2
commit
6aeae83a71
|
@ -9,7 +9,7 @@ import * as tc from '@actions/tool-cache';
|
|||
jest.mock('@actions/http-client');
|
||||
jest.mock('@actions/tool-cache');
|
||||
|
||||
const mockManifest = [{version: '1.0.0'}];
|
||||
const mockManifest = [{version: '3.12.0'}];
|
||||
|
||||
describe('getManifest', () => {
|
||||
it('should return manifest from repo', async () => {
|
||||
|
|
|
@ -91651,6 +91651,10 @@ function getManifest() {
|
|||
const manifestFromRepo = yield getManifestFromRepo();
|
||||
core.info('Successfully fetched the manifest from the repo.');
|
||||
core.info(`Manifest from repo: ${JSON.stringify(manifestFromRepo)}`);
|
||||
if (!Array.isArray(manifestFromRepo) ||
|
||||
!manifestFromRepo.every(isValidManifestEntry)) {
|
||||
throw new Error('Invalid response');
|
||||
}
|
||||
return manifestFromRepo;
|
||||
}
|
||||
catch (err) {
|
||||
|
@ -91659,13 +91663,38 @@ function getManifest() {
|
|||
core.info(err.message);
|
||||
}
|
||||
}
|
||||
try {
|
||||
const manifestFromURL = yield getManifestFromURL();
|
||||
core.info('Successfully fetched the manifest from the URL.');
|
||||
core.info(`Manifest from URL: ${JSON.stringify(manifestFromURL)}`);
|
||||
return manifestFromURL;
|
||||
}
|
||||
catch (err) {
|
||||
core.info('Fetching the manifest from the URL failed.');
|
||||
if (err instanceof Error) {
|
||||
core.info(err.message);
|
||||
}
|
||||
// Rethrow the error or return a default value
|
||||
throw new Error('Failed to fetch the manifest from both the repo and the URL.');
|
||||
}
|
||||
});
|
||||
}
|
||||
exports.getManifest = getManifest;
|
||||
function isValidManifestEntry(entry) {
|
||||
return (typeof entry.version === 'string' &&
|
||||
typeof entry.stable === 'boolean' &&
|
||||
typeof entry.release_url === 'string' &&
|
||||
Array.isArray(entry.files) &&
|
||||
entry.files.every(isValidFileEntry));
|
||||
}
|
||||
function isValidFileEntry(file) {
|
||||
return (typeof file.filename === 'string' &&
|
||||
typeof file.arch === 'string' &&
|
||||
typeof file.platform === 'string' &&
|
||||
(typeof file.platform_version === 'string' ||
|
||||
file.platform_version === undefined) &&
|
||||
typeof file.download_url === 'string');
|
||||
}
|
||||
function getManifestFromRepo() {
|
||||
core.info(`Getting manifest from ${MANIFEST_REPO_OWNER}/${MANIFEST_REPO_NAME}@${MANIFEST_REPO_BRANCH}`);
|
||||
return tc.getManifestFromRepo(MANIFEST_REPO_OWNER, MANIFEST_REPO_NAME, AUTH, MANIFEST_REPO_BRANCH);
|
||||
|
|
|
@ -38,6 +38,12 @@ export async function getManifest(): Promise<tc.IToolRelease[]> {
|
|||
const manifestFromRepo = await getManifestFromRepo();
|
||||
core.info('Successfully fetched the manifest from the repo.');
|
||||
core.info(`Manifest from repo: ${JSON.stringify(manifestFromRepo)}`);
|
||||
if (
|
||||
!Array.isArray(manifestFromRepo) ||
|
||||
!manifestFromRepo.every(isValidManifestEntry)
|
||||
) {
|
||||
throw new Error('Invalid response');
|
||||
}
|
||||
return manifestFromRepo;
|
||||
} catch (err) {
|
||||
core.info('Fetching the manifest via the API failed.');
|
||||
|
@ -45,10 +51,42 @@ export async function getManifest(): Promise<tc.IToolRelease[]> {
|
|||
core.info(err.message);
|
||||
}
|
||||
}
|
||||
try {
|
||||
const manifestFromURL = await getManifestFromURL();
|
||||
core.info('Successfully fetched the manifest from the URL.');
|
||||
core.info(`Manifest from URL: ${JSON.stringify(manifestFromURL)}`);
|
||||
return manifestFromURL;
|
||||
} catch (err) {
|
||||
core.info('Fetching the manifest from the URL failed.');
|
||||
if (err instanceof Error) {
|
||||
core.info(err.message);
|
||||
}
|
||||
// Rethrow the error or return a default value
|
||||
throw new Error(
|
||||
'Failed to fetch the manifest from both the repo and the URL.'
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
function isValidManifestEntry(entry: any): boolean {
|
||||
return (
|
||||
typeof entry.version === 'string' &&
|
||||
typeof entry.stable === 'boolean' &&
|
||||
typeof entry.release_url === 'string' &&
|
||||
Array.isArray(entry.files) &&
|
||||
entry.files.every(isValidFileEntry)
|
||||
);
|
||||
}
|
||||
|
||||
function isValidFileEntry(file: any): boolean {
|
||||
return (
|
||||
typeof file.filename === 'string' &&
|
||||
typeof file.arch === 'string' &&
|
||||
typeof file.platform === 'string' &&
|
||||
(typeof file.platform_version === 'string' ||
|
||||
file.platform_version === undefined) &&
|
||||
typeof file.download_url === 'string'
|
||||
);
|
||||
}
|
||||
|
||||
export function getManifestFromRepo(): Promise<tc.IToolRelease[]> {
|
||||
|
|
Loading…
Reference in New Issue