mirror of
				https://github.com/actions/setup-dotnet.git
				synced 2025-10-31 23:13:45 +00:00 
			
		
		
		
	* 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>
		
			
				
	
	
		
			88 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import * as cache from '@actions/cache';
 | |
| import * as core from '@actions/core';
 | |
| import fs from 'node:fs';
 | |
| import {run} from '../src/cache-save';
 | |
| import {getNuGetFolderPath} from '../src/cache-utils';
 | |
| 
 | |
| jest.mock('@actions/cache');
 | |
| jest.mock('@actions/core');
 | |
| jest.mock('node:fs');
 | |
| jest.mock('../src/cache-utils');
 | |
| 
 | |
| describe('cache-save tests', () => {
 | |
|   beforeAll(() => {
 | |
|     jest.mocked(getNuGetFolderPath).mockResolvedValue({
 | |
|       'global-packages': 'global-packages',
 | |
|       'http-cache': 'http-cache',
 | |
|       temp: 'temp',
 | |
|       'plugins-cache': 'plugins-cache'
 | |
|     });
 | |
|   });
 | |
|   beforeEach(() => {
 | |
|     jest.mocked(core.setFailed).mockClear();
 | |
|     jest.mocked(core.getState).mockClear();
 | |
|     jest.mocked(core.setOutput).mockClear();
 | |
|     jest.mocked(cache.saveCache).mockClear();
 | |
|     jest.mocked(fs.existsSync).mockClear();
 | |
|   });
 | |
| 
 | |
|   it('does not save cache when inputs:cache === false', async () => {
 | |
|     jest.mocked(core.getBooleanInput).mockReturnValue(false);
 | |
| 
 | |
|     await run();
 | |
| 
 | |
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(core.getState)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(fs.existsSync)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled();
 | |
|   });
 | |
| 
 | |
|   it('does not save cache when core.getState("CACHE_KEY") returns ""', async () => {
 | |
|     jest.mocked(core.getBooleanInput).mockReturnValue(true);
 | |
|     jest.mocked(core.getState).mockReturnValue('');
 | |
| 
 | |
|     await run();
 | |
| 
 | |
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2);
 | |
|     expect(jest.mocked(fs.existsSync)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled();
 | |
|   });
 | |
| 
 | |
|   it('throws Error when cachePath not exists', async () => {
 | |
|     jest.mocked(core.getBooleanInput).mockReturnValue(true);
 | |
|     jest.mocked(core.getState).mockReturnValue('cache-key');
 | |
|     jest.mocked(fs.existsSync).mockReturnValue(false);
 | |
| 
 | |
|     await run();
 | |
| 
 | |
|     expect(jest.mocked(core.setFailed)).toHaveBeenCalled();
 | |
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2);
 | |
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled();
 | |
|   });
 | |
| 
 | |
|   it('does not save cache when state.CACHE_KEY === state.CACHE_RESULT', async () => {
 | |
|     jest.mocked(core.getBooleanInput).mockReturnValue(true);
 | |
|     jest.mocked(core.getState).mockReturnValue('cache-key');
 | |
|     jest.mocked(fs.existsSync).mockReturnValue(true);
 | |
| 
 | |
|     await run();
 | |
| 
 | |
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2);
 | |
|     expect(jest.mocked(cache.saveCache)).not.toHaveBeenCalled();
 | |
|   });
 | |
| 
 | |
|   it('saves cache when state.CACHE_KEY !== state.CACHE_RESULT', async () => {
 | |
|     jest.mocked(core.getBooleanInput).mockReturnValue(true);
 | |
|     jest.mocked(core.getState).mockImplementation(s => s);
 | |
|     jest.mocked(fs.existsSync).mockReturnValue(true);
 | |
| 
 | |
|     await run();
 | |
| 
 | |
|     expect(jest.mocked(core.setFailed)).not.toHaveBeenCalled();
 | |
|     expect(jest.mocked(core.getState)).toHaveBeenCalledTimes(2);
 | |
|     expect(jest.mocked(cache.saveCache)).toHaveBeenCalled();
 | |
|   });
 | |
| });
 |