mirror of
				https://gitea.com/actions/cache.git
				synced 2025-11-02 07:47:08 +00:00 
			
		
		
		
	Compare commits
	
		
			12 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					0865c47f36 | ||
| 
						 | 
					354a2ae15e | ||
| 
						 | 
					baed3516c3 | ||
| 
						 | 
					8829e97be1 | ||
| 
						 | 
					eec8cd3f5f | ||
| 
						 | 
					5cc84c0123 | ||
| 
						 | 
					afc669e7fc | ||
| 
						 | 
					a0efc56c52 | ||
| 
						 | 
					d25c51bbfd | ||
| 
						 | 
					a080a3bda4 | ||
| 
						 | 
					02be3a9c73 | ||
| 
						 | 
					2086306d9c | 
							
								
								
									
										2
									
								
								.github/auto_assign.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/auto_assign.yml
									
									
									
									
										vendored
									
									
								
							@@ -6,7 +6,7 @@ addAssignees: false
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# A list of reviewers to be added to pull requests (GitHub user name)
 | 
					# A list of reviewers to be added to pull requests (GitHub user name)
 | 
				
			||||||
reviewers:
 | 
					reviewers:
 | 
				
			||||||
  - phantsure
 | 
					  - kotewar
 | 
				
			||||||
  - aparna-ravindra
 | 
					  - aparna-ravindra
 | 
				
			||||||
  - tiwarishub
 | 
					  - tiwarishub
 | 
				
			||||||
  - vsvipul
 | 
					  - vsvipul
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.github/workflows/auto-assign-issues.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/auto-assign-issues.yml
									
									
									
									
										vendored
									
									
								
							@@ -11,5 +11,5 @@ jobs:
 | 
				
			|||||||
            - name: 'Auto-assign issue'
 | 
					            - name: 'Auto-assign issue'
 | 
				
			||||||
              uses: pozil/auto-assign-issue@v1.4.0
 | 
					              uses: pozil/auto-assign-issue@v1.4.0
 | 
				
			||||||
              with:
 | 
					              with:
 | 
				
			||||||
                  assignees: phantsure,tiwarishub,aparna-ravindra,vsvipul,bishal-pdmsft
 | 
					                  assignees: kotewar,tiwarishub,aparna-ravindra,vsvipul,bishal-pdmsft
 | 
				
			||||||
                  numOfAssignee: 1
 | 
					                  numOfAssignee: 1
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.github/workflows/auto-assign.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/auto-assign.yml
									
									
									
									
										vendored
									
									
								
							@@ -1,6 +1,6 @@
 | 
				
			|||||||
name: 'Auto Assign'
 | 
					name: 'Auto Assign'
 | 
				
			||||||
on:
 | 
					on:
 | 
				
			||||||
  pull_request:
 | 
					  pull_request_target:
 | 
				
			||||||
    types: [opened, ready_for_review]
 | 
					    types: [opened, ready_for_review]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
jobs:
 | 
					jobs:
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							@@ -1,6 +1,6 @@
 | 
				
			|||||||
---
 | 
					---
 | 
				
			||||||
name: "@actions/cache"
 | 
					name: "@actions/cache"
 | 
				
			||||||
version: 2.0.6
 | 
					version: 3.0.0
 | 
				
			||||||
type: npm
 | 
					type: npm
 | 
				
			||||||
summary: 
 | 
					summary: 
 | 
				
			||||||
homepage: 
 | 
					homepage: 
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										46
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								README.md
									
									
									
									
									
								
							@@ -72,6 +72,8 @@ jobs:
 | 
				
			|||||||
      run: /primes.sh -d prime-numbers
 | 
					      run: /primes.sh -d prime-numbers
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					> Note: You must use the `cache` action in your workflow before you need to use the files that might be restored from the cache. If the provided `key` doesn't match an existing cache, a new cache is automatically created if the job completes successfully.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Implementation Examples
 | 
					## Implementation Examples
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Every programming language and framework has its own way of caching.
 | 
					Every programming language and framework has its own way of caching.
 | 
				
			||||||
@@ -172,33 +174,33 @@ jobs:
 | 
				
			|||||||
  build-linux:
 | 
					  build-linux:
 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
    - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Cache Primes
 | 
					      - name: Cache Primes
 | 
				
			||||||
      id: cache-primes
 | 
					        id: cache-primes
 | 
				
			||||||
      uses: actions/cache@v3
 | 
					        uses: actions/cache@v3
 | 
				
			||||||
      with:
 | 
					        with:
 | 
				
			||||||
        path: prime-numbers
 | 
					          path: prime-numbers
 | 
				
			||||||
        key: primes
 | 
					          key: primes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Generate Prime Numbers
 | 
					      - name: Generate Prime Numbers
 | 
				
			||||||
      if: steps.cache-primes.outputs.cache-hit != 'true'
 | 
					        if: steps.cache-primes.outputs.cache-hit != 'true'
 | 
				
			||||||
      run: ./generate-primes.sh -d prime-numbers
 | 
					        run: ./generate-primes.sh -d prime-numbers
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Cache Numbers
 | 
					      - name: Cache Numbers
 | 
				
			||||||
      id: cache-numbers
 | 
					        id: cache-numbers
 | 
				
			||||||
      uses: actions/cache@v3
 | 
					        uses: actions/cache@v3
 | 
				
			||||||
      with:
 | 
					        with:
 | 
				
			||||||
        path: numbers
 | 
					          path: numbers
 | 
				
			||||||
        key: primes
 | 
					          key: primes
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Generate Numbers
 | 
					      - name: Generate Numbers
 | 
				
			||||||
      if: steps.cache-numbers.outputs.cache-hit != 'true'
 | 
					        if: steps.cache-numbers.outputs.cache-hit != 'true'
 | 
				
			||||||
      run: ./generate-primes.sh -d numbers
 | 
					        run: ./generate-primes.sh -d numbers
 | 
				
			||||||
 | 
					
 | 
				
			||||||
   build-windows:
 | 
					  build-windows:
 | 
				
			||||||
      runs-on: windows-latest
 | 
					    runs-on: windows-latest
 | 
				
			||||||
      steps:
 | 
					    steps:
 | 
				
			||||||
      - uses: actions/checkout@v3
 | 
					      - uses: actions/checkout@v3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Cache Primes
 | 
					      - name: Cache Primes
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -15,3 +15,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
### 3.0.4
 | 
					### 3.0.4
 | 
				
			||||||
- Fixed tar creation error while trying to create tar with path as `~/` home folder on `ubuntu-latest`. ([issue](https://github.com/actions/cache/issues/689))
 | 
					- Fixed tar creation error while trying to create tar with path as `~/` home folder on `ubuntu-latest`. ([issue](https://github.com/actions/cache/issues/689))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### 3.0.5
 | 
				
			||||||
 | 
					- Removed error handling by consuming actions/cache 3.0 toolkit, Now cache server error handling will be done by toolkit. ([PR](https://github.com/actions/cache/pull/834))
 | 
				
			||||||
@@ -227,40 +227,6 @@ test("restore with no cache found", async () => {
 | 
				
			|||||||
    );
 | 
					    );
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
test("restore with server error should fail", async () => {
 | 
					 | 
				
			||||||
    const path = "node_modules";
 | 
					 | 
				
			||||||
    const key = "node-test";
 | 
					 | 
				
			||||||
    testUtils.setInputs({
 | 
					 | 
				
			||||||
        path: path,
 | 
					 | 
				
			||||||
        key
 | 
					 | 
				
			||||||
    });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    const logWarningMock = jest.spyOn(actionUtils, "logWarning");
 | 
					 | 
				
			||||||
    const failedMock = jest.spyOn(core, "setFailed");
 | 
					 | 
				
			||||||
    const stateMock = jest.spyOn(core, "saveState");
 | 
					 | 
				
			||||||
    const restoreCacheMock = jest
 | 
					 | 
				
			||||||
        .spyOn(cache, "restoreCache")
 | 
					 | 
				
			||||||
        .mockImplementationOnce(() => {
 | 
					 | 
				
			||||||
            throw new Error("HTTP Error Occurred");
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
    const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    await run();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    expect(restoreCacheMock).toHaveBeenCalledTimes(1);
 | 
					 | 
				
			||||||
    expect(restoreCacheMock).toHaveBeenCalledWith([path], key, []);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    expect(logWarningMock).toHaveBeenCalledTimes(1);
 | 
					 | 
				
			||||||
    expect(logWarningMock).toHaveBeenCalledWith("HTTP Error Occurred");
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1);
 | 
					 | 
				
			||||||
    expect(setCacheHitOutputMock).toHaveBeenCalledWith(false);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    expect(failedMock).toHaveBeenCalledTimes(0);
 | 
					 | 
				
			||||||
});
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
test("restore with restore keys and no cache found", async () => {
 | 
					test("restore with restore keys and no cache found", async () => {
 | 
				
			||||||
    const path = "node_modules";
 | 
					    const path = "node_modules";
 | 
				
			||||||
    const key = "node-test";
 | 
					    const key = "node-test";
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -267,7 +267,6 @@ test("save with large cache outputs warning", async () => {
 | 
				
			|||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
test("save with reserve cache failure outputs warning", async () => {
 | 
					test("save with reserve cache failure outputs warning", async () => {
 | 
				
			||||||
    const infoMock = jest.spyOn(core, "info");
 | 
					 | 
				
			||||||
    const logWarningMock = jest.spyOn(actionUtils, "logWarning");
 | 
					    const logWarningMock = jest.spyOn(actionUtils, "logWarning");
 | 
				
			||||||
    const failedMock = jest.spyOn(core, "setFailed");
 | 
					    const failedMock = jest.spyOn(core, "setFailed");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -306,10 +305,10 @@ test("save with reserve cache failure outputs warning", async () => {
 | 
				
			|||||||
        expect.anything()
 | 
					        expect.anything()
 | 
				
			||||||
    );
 | 
					    );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    expect(infoMock).toHaveBeenCalledWith(
 | 
					    expect(logWarningMock).toHaveBeenCalledWith(
 | 
				
			||||||
        `Unable to reserve cache with key ${primaryKey}, another job may be creating this cache.`
 | 
					        `Unable to reserve cache with key ${primaryKey}, another job may be creating this cache.`
 | 
				
			||||||
    );
 | 
					    );
 | 
				
			||||||
    expect(logWarningMock).toHaveBeenCalledTimes(0);
 | 
					    expect(logWarningMock).toHaveBeenCalledTimes(1);
 | 
				
			||||||
    expect(failedMock).toHaveBeenCalledTimes(0);
 | 
					    expect(failedMock).toHaveBeenCalledTimes(0);
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										84
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										84
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							@@ -46850,17 +46850,18 @@ function restoreCache(paths, primaryKey, restoreKeys, options) {
 | 
				
			|||||||
            checkKey(key);
 | 
					            checkKey(key);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        const compressionMethod = yield utils.getCompressionMethod();
 | 
					        const compressionMethod = yield utils.getCompressionMethod();
 | 
				
			||||||
        // path are needed to compute version
 | 
					        let archivePath = '';
 | 
				
			||||||
        const cacheEntry = yield cacheHttpClient.getCacheEntry(keys, paths, {
 | 
					 | 
				
			||||||
            compressionMethod
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
        if (!(cacheEntry === null || cacheEntry === void 0 ? void 0 : cacheEntry.archiveLocation)) {
 | 
					 | 
				
			||||||
            // Cache not found
 | 
					 | 
				
			||||||
            return undefined;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        const archivePath = path.join(yield utils.createTempDirectory(), utils.getCacheFileName(compressionMethod));
 | 
					 | 
				
			||||||
        core.debug(`Archive Path: ${archivePath}`);
 | 
					 | 
				
			||||||
        try {
 | 
					        try {
 | 
				
			||||||
 | 
					            // path are needed to compute version
 | 
				
			||||||
 | 
					            const cacheEntry = yield cacheHttpClient.getCacheEntry(keys, paths, {
 | 
				
			||||||
 | 
					                compressionMethod
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					            if (!(cacheEntry === null || cacheEntry === void 0 ? void 0 : cacheEntry.archiveLocation)) {
 | 
				
			||||||
 | 
					                // Cache not found
 | 
				
			||||||
 | 
					                return undefined;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            archivePath = path.join(yield utils.createTempDirectory(), utils.getCacheFileName(compressionMethod));
 | 
				
			||||||
 | 
					            core.debug(`Archive Path: ${archivePath}`);
 | 
				
			||||||
            // Download the cache from the cache entry
 | 
					            // Download the cache from the cache entry
 | 
				
			||||||
            yield cacheHttpClient.downloadCache(cacheEntry.archiveLocation, archivePath, options);
 | 
					            yield cacheHttpClient.downloadCache(cacheEntry.archiveLocation, archivePath, options);
 | 
				
			||||||
            if (core.isDebug()) {
 | 
					            if (core.isDebug()) {
 | 
				
			||||||
@@ -46870,6 +46871,17 @@ function restoreCache(paths, primaryKey, restoreKeys, options) {
 | 
				
			|||||||
            core.info(`Cache Size: ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B)`);
 | 
					            core.info(`Cache Size: ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B)`);
 | 
				
			||||||
            yield tar_1.extractTar(archivePath, compressionMethod);
 | 
					            yield tar_1.extractTar(archivePath, compressionMethod);
 | 
				
			||||||
            core.info('Cache restored successfully');
 | 
					            core.info('Cache restored successfully');
 | 
				
			||||||
 | 
					            return cacheEntry.cacheKey;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        catch (error) {
 | 
				
			||||||
 | 
					            const typedError = error;
 | 
				
			||||||
 | 
					            if (typedError.name === ValidationError.name) {
 | 
				
			||||||
 | 
					                throw error;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            else {
 | 
				
			||||||
 | 
					                // Supress all non-validation cache related errors because caching should be optional
 | 
				
			||||||
 | 
					                core.warning(`Failed to restore: ${error.message}`);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        finally {
 | 
					        finally {
 | 
				
			||||||
            // Try to delete the archive to save space
 | 
					            // Try to delete the archive to save space
 | 
				
			||||||
@@ -46880,7 +46892,7 @@ function restoreCache(paths, primaryKey, restoreKeys, options) {
 | 
				
			|||||||
                core.debug(`Failed to delete archive: ${error}`);
 | 
					                core.debug(`Failed to delete archive: ${error}`);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        return cacheEntry.cacheKey;
 | 
					        return undefined;
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
exports.restoreCache = restoreCache;
 | 
					exports.restoreCache = restoreCache;
 | 
				
			||||||
@@ -46898,7 +46910,7 @@ function saveCache(paths, key, options) {
 | 
				
			|||||||
        checkPaths(paths);
 | 
					        checkPaths(paths);
 | 
				
			||||||
        checkKey(key);
 | 
					        checkKey(key);
 | 
				
			||||||
        const compressionMethod = yield utils.getCompressionMethod();
 | 
					        const compressionMethod = yield utils.getCompressionMethod();
 | 
				
			||||||
        let cacheId = null;
 | 
					        let cacheId = -1;
 | 
				
			||||||
        const cachePaths = yield utils.resolvePaths(paths);
 | 
					        const cachePaths = yield utils.resolvePaths(paths);
 | 
				
			||||||
        core.debug('Cache Paths:');
 | 
					        core.debug('Cache Paths:');
 | 
				
			||||||
        core.debug(`${JSON.stringify(cachePaths)}`);
 | 
					        core.debug(`${JSON.stringify(cachePaths)}`);
 | 
				
			||||||
@@ -46937,6 +46949,18 @@ function saveCache(paths, key, options) {
 | 
				
			|||||||
            core.debug(`Saving Cache (ID: ${cacheId})`);
 | 
					            core.debug(`Saving Cache (ID: ${cacheId})`);
 | 
				
			||||||
            yield cacheHttpClient.saveCache(cacheId, archivePath, options);
 | 
					            yield cacheHttpClient.saveCache(cacheId, archivePath, options);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					        catch (error) {
 | 
				
			||||||
 | 
					            const typedError = error;
 | 
				
			||||||
 | 
					            if (typedError.name === ValidationError.name) {
 | 
				
			||||||
 | 
					                throw error;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            else if (typedError.name === ReserveCacheError.name) {
 | 
				
			||||||
 | 
					                core.info(`Failed to save: ${typedError.message}`);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            else {
 | 
				
			||||||
 | 
					                core.warning(`Failed to save: ${typedError.message}`);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        finally {
 | 
					        finally {
 | 
				
			||||||
            // Try to delete the archive to save space
 | 
					            // Try to delete the archive to save space
 | 
				
			||||||
            try {
 | 
					            try {
 | 
				
			||||||
@@ -48996,31 +49020,19 @@ function run() {
 | 
				
			|||||||
            const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, {
 | 
					            const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, {
 | 
				
			||||||
                required: true
 | 
					                required: true
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
            try {
 | 
					            const cacheKey = yield cache.restoreCache(cachePaths, primaryKey, restoreKeys);
 | 
				
			||||||
                const cacheKey = yield cache.restoreCache(cachePaths, primaryKey, restoreKeys);
 | 
					            if (!cacheKey) {
 | 
				
			||||||
                if (!cacheKey) {
 | 
					                core.info(`Cache not found for input keys: ${[
 | 
				
			||||||
                    core.info(`Cache not found for input keys: ${[
 | 
					                    primaryKey,
 | 
				
			||||||
                        primaryKey,
 | 
					                    ...restoreKeys
 | 
				
			||||||
                        ...restoreKeys
 | 
					                ].join(", ")}`);
 | 
				
			||||||
                    ].join(", ")}`);
 | 
					                return;
 | 
				
			||||||
                    return;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                // Store the matched cache key
 | 
					 | 
				
			||||||
                utils.setCacheState(cacheKey);
 | 
					 | 
				
			||||||
                const isExactKeyMatch = utils.isExactKeyMatch(primaryKey, cacheKey);
 | 
					 | 
				
			||||||
                utils.setCacheHitOutput(isExactKeyMatch);
 | 
					 | 
				
			||||||
                core.info(`Cache restored from key: ${cacheKey}`);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            catch (error) {
 | 
					 | 
				
			||||||
                const typedError = error;
 | 
					 | 
				
			||||||
                if (typedError.name === cache.ValidationError.name) {
 | 
					 | 
				
			||||||
                    throw error;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                else {
 | 
					 | 
				
			||||||
                    utils.logWarning(typedError.message);
 | 
					 | 
				
			||||||
                    utils.setCacheHitOutput(false);
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					            // Store the matched cache key
 | 
				
			||||||
 | 
					            utils.setCacheState(cacheKey);
 | 
				
			||||||
 | 
					            const isExactKeyMatch = utils.isExactKeyMatch(primaryKey, cacheKey);
 | 
				
			||||||
 | 
					            utils.setCacheHitOutput(isExactKeyMatch);
 | 
				
			||||||
 | 
					            core.info(`Cache restored from key: ${cacheKey}`);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        catch (error) {
 | 
					        catch (error) {
 | 
				
			||||||
            core.setFailed(error.message);
 | 
					            core.setFailed(error.message);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										68
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										68
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							@@ -46792,24 +46792,12 @@ function run() {
 | 
				
			|||||||
            const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, {
 | 
					            const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, {
 | 
				
			||||||
                required: true
 | 
					                required: true
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
            try {
 | 
					            const cacheId = yield cache.saveCache(cachePaths, primaryKey, {
 | 
				
			||||||
                yield cache.saveCache(cachePaths, primaryKey, {
 | 
					                uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize)
 | 
				
			||||||
                    uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize)
 | 
					            });
 | 
				
			||||||
                });
 | 
					            if (cacheId != -1) {
 | 
				
			||||||
                core.info(`Cache saved with key: ${primaryKey}`);
 | 
					                core.info(`Cache saved with key: ${primaryKey}`);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            catch (error) {
 | 
					 | 
				
			||||||
                const typedError = error;
 | 
					 | 
				
			||||||
                if (typedError.name === cache.ValidationError.name) {
 | 
					 | 
				
			||||||
                    throw error;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                else if (typedError.name === cache.ReserveCacheError.name) {
 | 
					 | 
				
			||||||
                    core.info(typedError.message);
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                else {
 | 
					 | 
				
			||||||
                    utils.logWarning(typedError.message);
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        catch (error) {
 | 
					        catch (error) {
 | 
				
			||||||
            utils.logWarning(error.message);
 | 
					            utils.logWarning(error.message);
 | 
				
			||||||
@@ -46948,17 +46936,18 @@ function restoreCache(paths, primaryKey, restoreKeys, options) {
 | 
				
			|||||||
            checkKey(key);
 | 
					            checkKey(key);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        const compressionMethod = yield utils.getCompressionMethod();
 | 
					        const compressionMethod = yield utils.getCompressionMethod();
 | 
				
			||||||
        // path are needed to compute version
 | 
					        let archivePath = '';
 | 
				
			||||||
        const cacheEntry = yield cacheHttpClient.getCacheEntry(keys, paths, {
 | 
					 | 
				
			||||||
            compressionMethod
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
        if (!(cacheEntry === null || cacheEntry === void 0 ? void 0 : cacheEntry.archiveLocation)) {
 | 
					 | 
				
			||||||
            // Cache not found
 | 
					 | 
				
			||||||
            return undefined;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        const archivePath = path.join(yield utils.createTempDirectory(), utils.getCacheFileName(compressionMethod));
 | 
					 | 
				
			||||||
        core.debug(`Archive Path: ${archivePath}`);
 | 
					 | 
				
			||||||
        try {
 | 
					        try {
 | 
				
			||||||
 | 
					            // path are needed to compute version
 | 
				
			||||||
 | 
					            const cacheEntry = yield cacheHttpClient.getCacheEntry(keys, paths, {
 | 
				
			||||||
 | 
					                compressionMethod
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					            if (!(cacheEntry === null || cacheEntry === void 0 ? void 0 : cacheEntry.archiveLocation)) {
 | 
				
			||||||
 | 
					                // Cache not found
 | 
				
			||||||
 | 
					                return undefined;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            archivePath = path.join(yield utils.createTempDirectory(), utils.getCacheFileName(compressionMethod));
 | 
				
			||||||
 | 
					            core.debug(`Archive Path: ${archivePath}`);
 | 
				
			||||||
            // Download the cache from the cache entry
 | 
					            // Download the cache from the cache entry
 | 
				
			||||||
            yield cacheHttpClient.downloadCache(cacheEntry.archiveLocation, archivePath, options);
 | 
					            yield cacheHttpClient.downloadCache(cacheEntry.archiveLocation, archivePath, options);
 | 
				
			||||||
            if (core.isDebug()) {
 | 
					            if (core.isDebug()) {
 | 
				
			||||||
@@ -46968,6 +46957,17 @@ function restoreCache(paths, primaryKey, restoreKeys, options) {
 | 
				
			|||||||
            core.info(`Cache Size: ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B)`);
 | 
					            core.info(`Cache Size: ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B)`);
 | 
				
			||||||
            yield tar_1.extractTar(archivePath, compressionMethod);
 | 
					            yield tar_1.extractTar(archivePath, compressionMethod);
 | 
				
			||||||
            core.info('Cache restored successfully');
 | 
					            core.info('Cache restored successfully');
 | 
				
			||||||
 | 
					            return cacheEntry.cacheKey;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        catch (error) {
 | 
				
			||||||
 | 
					            const typedError = error;
 | 
				
			||||||
 | 
					            if (typedError.name === ValidationError.name) {
 | 
				
			||||||
 | 
					                throw error;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            else {
 | 
				
			||||||
 | 
					                // Supress all non-validation cache related errors because caching should be optional
 | 
				
			||||||
 | 
					                core.warning(`Failed to restore: ${error.message}`);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        finally {
 | 
					        finally {
 | 
				
			||||||
            // Try to delete the archive to save space
 | 
					            // Try to delete the archive to save space
 | 
				
			||||||
@@ -46978,7 +46978,7 @@ function restoreCache(paths, primaryKey, restoreKeys, options) {
 | 
				
			|||||||
                core.debug(`Failed to delete archive: ${error}`);
 | 
					                core.debug(`Failed to delete archive: ${error}`);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        return cacheEntry.cacheKey;
 | 
					        return undefined;
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
exports.restoreCache = restoreCache;
 | 
					exports.restoreCache = restoreCache;
 | 
				
			||||||
@@ -46996,7 +46996,7 @@ function saveCache(paths, key, options) {
 | 
				
			|||||||
        checkPaths(paths);
 | 
					        checkPaths(paths);
 | 
				
			||||||
        checkKey(key);
 | 
					        checkKey(key);
 | 
				
			||||||
        const compressionMethod = yield utils.getCompressionMethod();
 | 
					        const compressionMethod = yield utils.getCompressionMethod();
 | 
				
			||||||
        let cacheId = null;
 | 
					        let cacheId = -1;
 | 
				
			||||||
        const cachePaths = yield utils.resolvePaths(paths);
 | 
					        const cachePaths = yield utils.resolvePaths(paths);
 | 
				
			||||||
        core.debug('Cache Paths:');
 | 
					        core.debug('Cache Paths:');
 | 
				
			||||||
        core.debug(`${JSON.stringify(cachePaths)}`);
 | 
					        core.debug(`${JSON.stringify(cachePaths)}`);
 | 
				
			||||||
@@ -47035,6 +47035,18 @@ function saveCache(paths, key, options) {
 | 
				
			|||||||
            core.debug(`Saving Cache (ID: ${cacheId})`);
 | 
					            core.debug(`Saving Cache (ID: ${cacheId})`);
 | 
				
			||||||
            yield cacheHttpClient.saveCache(cacheId, archivePath, options);
 | 
					            yield cacheHttpClient.saveCache(cacheId, archivePath, options);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					        catch (error) {
 | 
				
			||||||
 | 
					            const typedError = error;
 | 
				
			||||||
 | 
					            if (typedError.name === ValidationError.name) {
 | 
				
			||||||
 | 
					                throw error;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            else if (typedError.name === ReserveCacheError.name) {
 | 
				
			||||||
 | 
					                core.info(`Failed to save: ${typedError.message}`);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            else {
 | 
				
			||||||
 | 
					                core.warning(`Failed to save: ${typedError.message}`);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        finally {
 | 
					        finally {
 | 
				
			||||||
            // Try to delete the archive to save space
 | 
					            // Try to delete the archive to save space
 | 
				
			||||||
            try {
 | 
					            try {
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										23
									
								
								examples.md
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								examples.md
									
									
									
									
									
								
							@@ -223,6 +223,8 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
## Haskell - Stack
 | 
					## Haskell - Stack
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Linux or macOS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```yaml
 | 
					```yaml
 | 
				
			||||||
- uses: actions/cache@v3
 | 
					- uses: actions/cache@v3
 | 
				
			||||||
  name: Cache ~/.stack
 | 
					  name: Cache ~/.stack
 | 
				
			||||||
@@ -240,6 +242,27 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba
 | 
				
			|||||||
      ${{ runner.os }}-stack-work-
 | 
					      ${{ runner.os }}-stack-work-
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Windows
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```yaml
 | 
				
			||||||
 | 
					- uses: actions/cache@v3
 | 
				
			||||||
 | 
					  name: Cache %APPDATA%\stack %LOCALAPPDATA%\Programs\stack
 | 
				
			||||||
 | 
					  with:
 | 
				
			||||||
 | 
					    path: |
 | 
				
			||||||
 | 
					      ~\AppData\Roaming\stack
 | 
				
			||||||
 | 
					      ~\AppData\Local\Programs\stack    
 | 
				
			||||||
 | 
					    key: ${{ runner.os }}-stack-global-${{ hashFiles('stack.yaml') }}-${{ hashFiles('package.yaml') }}
 | 
				
			||||||
 | 
					    restore-keys: |
 | 
				
			||||||
 | 
					      ${{ runner.os }}-stack-global-
 | 
				
			||||||
 | 
					- uses: actions/cache@v3
 | 
				
			||||||
 | 
					  name: Cache .stack-work
 | 
				
			||||||
 | 
					  with:
 | 
				
			||||||
 | 
					    path: .stack-work
 | 
				
			||||||
 | 
					    key: ${{ runner.os }}-stack-work-${{ hashFiles('stack.yaml') }}-${{ hashFiles('package.yaml') }}-${{ hashFiles('**/*.hs') }}
 | 
				
			||||||
 | 
					    restore-keys: |
 | 
				
			||||||
 | 
					      ${{ runner.os }}-stack-work-
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Java - Gradle
 | 
					## Java - Gradle
 | 
				
			||||||
 | 
					
 | 
				
			||||||
>Note: Ensure no Gradle daemons are running anymore when your workflow completes. Creating the cache package might fail due to locks being held by Gradle. Refer to the [Gradle Daemon documentation](https://docs.gradle.org/current/userguide/gradle_daemon.html) on how to disable or stop the Gradle Daemons.
 | 
					>Note: Ensure no Gradle daemons are running anymore when your workflow completes. Creating the cache package might fail due to locks being held by Gradle. Refer to the [Gradle Daemon documentation](https://docs.gradle.org/current/userguide/gradle_daemon.html) on how to disable or stop the Gradle Daemons.
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										18
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										18
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -1,15 +1,15 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "name": "cache",
 | 
					  "name": "cache",
 | 
				
			||||||
  "version": "3.0.4",
 | 
					  "version": "3.0.5",
 | 
				
			||||||
  "lockfileVersion": 2,
 | 
					  "lockfileVersion": 2,
 | 
				
			||||||
  "requires": true,
 | 
					  "requires": true,
 | 
				
			||||||
  "packages": {
 | 
					  "packages": {
 | 
				
			||||||
    "": {
 | 
					    "": {
 | 
				
			||||||
      "name": "cache",
 | 
					      "name": "cache",
 | 
				
			||||||
      "version": "3.0.4",
 | 
					      "version": "3.0.5",
 | 
				
			||||||
      "license": "MIT",
 | 
					      "license": "MIT",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@actions/cache": "^2.0.6",
 | 
					        "@actions/cache": "^3.0.0",
 | 
				
			||||||
        "@actions/core": "^1.7.0",
 | 
					        "@actions/core": "^1.7.0",
 | 
				
			||||||
        "@actions/exec": "^1.1.1",
 | 
					        "@actions/exec": "^1.1.1",
 | 
				
			||||||
        "@actions/io": "^1.1.2"
 | 
					        "@actions/io": "^1.1.2"
 | 
				
			||||||
@@ -36,9 +36,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "node_modules/@actions/cache": {
 | 
					    "node_modules/@actions/cache": {
 | 
				
			||||||
      "version": "2.0.6",
 | 
					      "version": "3.0.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-2.0.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.0.0.tgz",
 | 
				
			||||||
      "integrity": "sha512-Z39ZrWaTRRPaV/AOQdY7hve+Iy/HloH5prpz+k+0lZgGQs/3SeO0UYSIakVuXOk2pdMZnl0Nv0PoK1rmh9YfGQ==",
 | 
					      "integrity": "sha512-GL9CT1Fnu+pqs8TTB621q8Xa8Cilw2n9MwvbgMedetH7L1q2n6jY61gzbwGbKgtVbp3gVJ12aNMi4osSGXx3KQ==",
 | 
				
			||||||
      "dependencies": {
 | 
					      "dependencies": {
 | 
				
			||||||
        "@actions/core": "^1.2.6",
 | 
					        "@actions/core": "^1.2.6",
 | 
				
			||||||
        "@actions/exec": "^1.0.1",
 | 
					        "@actions/exec": "^1.0.1",
 | 
				
			||||||
@@ -9533,9 +9533,9 @@
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  "dependencies": {
 | 
					  "dependencies": {
 | 
				
			||||||
    "@actions/cache": {
 | 
					    "@actions/cache": {
 | 
				
			||||||
      "version": "2.0.6",
 | 
					      "version": "3.0.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-2.0.6.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@actions/cache/-/cache-3.0.0.tgz",
 | 
				
			||||||
      "integrity": "sha512-Z39ZrWaTRRPaV/AOQdY7hve+Iy/HloH5prpz+k+0lZgGQs/3SeO0UYSIakVuXOk2pdMZnl0Nv0PoK1rmh9YfGQ==",
 | 
					      "integrity": "sha512-GL9CT1Fnu+pqs8TTB621q8Xa8Cilw2n9MwvbgMedetH7L1q2n6jY61gzbwGbKgtVbp3gVJ12aNMi4osSGXx3KQ==",
 | 
				
			||||||
      "requires": {
 | 
					      "requires": {
 | 
				
			||||||
        "@actions/core": "^1.2.6",
 | 
					        "@actions/core": "^1.2.6",
 | 
				
			||||||
        "@actions/exec": "^1.0.1",
 | 
					        "@actions/exec": "^1.0.1",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
  "name": "cache",
 | 
					  "name": "cache",
 | 
				
			||||||
  "version": "3.0.4",
 | 
					  "version": "3.0.5",
 | 
				
			||||||
  "private": true,
 | 
					  "private": true,
 | 
				
			||||||
  "description": "Cache dependencies and build outputs",
 | 
					  "description": "Cache dependencies and build outputs",
 | 
				
			||||||
  "main": "dist/restore/index.js",
 | 
					  "main": "dist/restore/index.js",
 | 
				
			||||||
@@ -23,7 +23,7 @@
 | 
				
			|||||||
  "author": "GitHub",
 | 
					  "author": "GitHub",
 | 
				
			||||||
  "license": "MIT",
 | 
					  "license": "MIT",
 | 
				
			||||||
  "dependencies": {
 | 
					  "dependencies": {
 | 
				
			||||||
    "@actions/cache": "^2.0.6",
 | 
					    "@actions/cache": "^3.0.0",
 | 
				
			||||||
    "@actions/core": "^1.7.0",
 | 
					    "@actions/core": "^1.7.0",
 | 
				
			||||||
    "@actions/exec": "^1.1.1",
 | 
					    "@actions/exec": "^1.1.1",
 | 
				
			||||||
    "@actions/io": "^1.1.2"
 | 
					    "@actions/io": "^1.1.2"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -29,38 +29,29 @@ async function run(): Promise<void> {
 | 
				
			|||||||
            required: true
 | 
					            required: true
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        try {
 | 
					        const cacheKey = await cache.restoreCache(
 | 
				
			||||||
            const cacheKey = await cache.restoreCache(
 | 
					            cachePaths,
 | 
				
			||||||
                cachePaths,
 | 
					            primaryKey,
 | 
				
			||||||
                primaryKey,
 | 
					            restoreKeys
 | 
				
			||||||
                restoreKeys
 | 
					        );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (!cacheKey) {
 | 
				
			||||||
 | 
					            core.info(
 | 
				
			||||||
 | 
					                `Cache not found for input keys: ${[
 | 
				
			||||||
 | 
					                    primaryKey,
 | 
				
			||||||
 | 
					                    ...restoreKeys
 | 
				
			||||||
 | 
					                ].join(", ")}`
 | 
				
			||||||
            );
 | 
					            );
 | 
				
			||||||
            if (!cacheKey) {
 | 
					 | 
				
			||||||
                core.info(
 | 
					 | 
				
			||||||
                    `Cache not found for input keys: ${[
 | 
					 | 
				
			||||||
                        primaryKey,
 | 
					 | 
				
			||||||
                        ...restoreKeys
 | 
					 | 
				
			||||||
                    ].join(", ")}`
 | 
					 | 
				
			||||||
                );
 | 
					 | 
				
			||||||
                return;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
            // Store the matched cache key
 | 
					            return;
 | 
				
			||||||
            utils.setCacheState(cacheKey);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            const isExactKeyMatch = utils.isExactKeyMatch(primaryKey, cacheKey);
 | 
					 | 
				
			||||||
            utils.setCacheHitOutput(isExactKeyMatch);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
            core.info(`Cache restored from key: ${cacheKey}`);
 | 
					 | 
				
			||||||
        } catch (error: unknown) {
 | 
					 | 
				
			||||||
            const typedError = error as Error;
 | 
					 | 
				
			||||||
            if (typedError.name === cache.ValidationError.name) {
 | 
					 | 
				
			||||||
                throw error;
 | 
					 | 
				
			||||||
            } else {
 | 
					 | 
				
			||||||
                utils.logWarning(typedError.message);
 | 
					 | 
				
			||||||
                utils.setCacheHitOutput(false);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // Store the matched cache key
 | 
				
			||||||
 | 
					        utils.setCacheState(cacheKey);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        const isExactKeyMatch = utils.isExactKeyMatch(primaryKey, cacheKey);
 | 
				
			||||||
 | 
					        utils.setCacheHitOutput(isExactKeyMatch);
 | 
				
			||||||
 | 
					        core.info(`Cache restored from key: ${cacheKey}`);
 | 
				
			||||||
    } catch (error: unknown) {
 | 
					    } catch (error: unknown) {
 | 
				
			||||||
        core.setFailed((error as Error).message);
 | 
					        core.setFailed((error as Error).message);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										18
									
								
								src/save.ts
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								src/save.ts
									
									
									
									
									
								
							@@ -44,20 +44,12 @@ async function run(): Promise<void> {
 | 
				
			|||||||
            required: true
 | 
					            required: true
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        try {
 | 
					        const cacheId = await cache.saveCache(cachePaths, primaryKey, {
 | 
				
			||||||
            await cache.saveCache(cachePaths, primaryKey, {
 | 
					            uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize)
 | 
				
			||||||
                uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize)
 | 
					        });
 | 
				
			||||||
            });
 | 
					
 | 
				
			||||||
 | 
					        if (cacheId != -1) {
 | 
				
			||||||
            core.info(`Cache saved with key: ${primaryKey}`);
 | 
					            core.info(`Cache saved with key: ${primaryKey}`);
 | 
				
			||||||
        } catch (error: unknown) {
 | 
					 | 
				
			||||||
            const typedError = error as Error;
 | 
					 | 
				
			||||||
            if (typedError.name === cache.ValidationError.name) {
 | 
					 | 
				
			||||||
                throw error;
 | 
					 | 
				
			||||||
            } else if (typedError.name === cache.ReserveCacheError.name) {
 | 
					 | 
				
			||||||
                core.info(typedError.message);
 | 
					 | 
				
			||||||
            } else {
 | 
					 | 
				
			||||||
                utils.logWarning(typedError.message);
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    } catch (error: unknown) {
 | 
					    } catch (error: unknown) {
 | 
				
			||||||
        utils.logWarning((error as Error).message);
 | 
					        utils.logWarning((error as Error).message);
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user