mirror of
https://github.com/actions/setup-dotnet.git
synced 2024-11-25 21:03:06 +07:00
3447fd6a9f
* feat: cache NuGet global-packages folder * fix: remove unused files * docs: fix incorrect action * ci: add e2e test for cache * docs: accept suggested changes on README * docs: add simple cache example * build: change main script path * fix: change relative path to install scripts * fix: change relative path to problem matcher * refactor: accept changes on cache-utils * fix: revert main script path changes * test: fix cache-utils unit test * test: fix cache-utils unit test * feat: add `cache-dependency-path` variables * build: change main script dist path * ci: add `cache-dependency-path` e2e test & missing lock file * fix: accept change suggestions * ci: copy NuGet lock file to root to pass "test-setup-with-cache" e2e test * docs: change README guide * fix: apply suggestions from code review Co-authored-by: Ivan <98037481+IvanZosimov@users.noreply.github.com> * test: fix some failed unit tests - fix `restoreCache()` test for 9703c8 - update installer script * build: rebuild dist * Update unit-tests - Additional unit test were added to setup-dotnet.test.ts * Update unit tests for unix systems * Format and lint unit tests * fix: avoid use '/' on `path.join` * fix: rebuild dist * fix: apply suggestions from code review Co-authored-by: Ivan <98037481+IvanZosimov@users.noreply.github.com> * build: add `DisableImplicitNuGetFallbackFolder` option also add guide on README * docs: highlight warnings and notes * docs: update note about handling NU1403 --------- Co-authored-by: Ivan <98037481+IvanZosimov@users.noreply.github.com> Co-authored-by: IvanZosimov <ivanzosimov@github.com>
58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
import * as core from '@actions/core';
|
|
import * as cache from '@actions/cache';
|
|
import fs from 'node:fs';
|
|
import {getNuGetFolderPath} from './cache-utils';
|
|
import {State} from './constants';
|
|
|
|
// Catch and log any unhandled exceptions. These exceptions can leak out of the uploadChunk method in
|
|
// @actions/toolkit when a failed upload closes the file descriptor causing any in-process reads to
|
|
// throw an uncaught exception. Instead of failing this action, just warn.
|
|
process.on('uncaughtException', e => {
|
|
const warningPrefix = '[warning]';
|
|
core.info(`${warningPrefix}${e.message}`);
|
|
});
|
|
|
|
export async function run() {
|
|
try {
|
|
if (core.getBooleanInput('cache')) {
|
|
await cachePackages();
|
|
}
|
|
} catch (error) {
|
|
core.setFailed(error.message);
|
|
}
|
|
}
|
|
|
|
const cachePackages = async () => {
|
|
const state = core.getState(State.CacheMatchedKey);
|
|
const primaryKey = core.getState(State.CachePrimaryKey);
|
|
|
|
if (!primaryKey) {
|
|
core.info('Primary key was not generated, not saving cache.');
|
|
return;
|
|
}
|
|
|
|
const {'global-packages': cachePath} = await getNuGetFolderPath();
|
|
|
|
if (!fs.existsSync(cachePath)) {
|
|
throw new Error(
|
|
`Cache folder path is retrieved for .NET CLI but doesn't exist on disk: ${cachePath}`
|
|
);
|
|
}
|
|
|
|
if (primaryKey === state) {
|
|
core.info(
|
|
`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`
|
|
);
|
|
return;
|
|
}
|
|
|
|
const cacheId = await cache.saveCache([cachePath], primaryKey);
|
|
if (cacheId == -1) {
|
|
return;
|
|
}
|
|
|
|
core.info(`Cache saved with the key: ${primaryKey}`);
|
|
};
|
|
|
|
run();
|