mirror of
				https://gitea.com/actions/cache.git
				synced 2025-10-31 07:47:07 +00:00 
			
		
		
		
	Compare commits
	
		
			53 Commits
		
	
	
		
			master
			...
			bishal/out
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 657c52f11e | ||
|   | 34e917cb7d | ||
|   | ac8fc97c06 | ||
|   | 86712a0733 | ||
|   | d6e98d9302 | ||
|   | a76826ef46 | ||
|   | e02e5113ed | ||
|   | 85ae5bbcea | ||
|   | cce93fb2c7 | ||
|   | e3d8fb0b34 | ||
|   | d95c048983 | ||
|   | 706c369cf1 | ||
|   | a57932faba | ||
|   | 04b13caea4 | ||
|   | 941bc71a24 | ||
|   | 08d8639046 | ||
|   | a2f324eeb7 | ||
|   | 11ab7ccfa2 | ||
|   | 35f4702f6c | ||
|   | 4b5f33df54 | ||
|   | e050ebdd63 | ||
|   | 0d47d164e9 | ||
|   | 56a0133650 | ||
|   | 19446b165a | ||
|   | e2d614414f | ||
|   | 532752012e | ||
|   | 8a88690a20 | ||
|   | b26da1fc31 | ||
|   | ce61cc4d24 | ||
|   | 6e2c6a5916 | ||
|   | 2c9fb32186 | ||
|   | 01d96636a0 | ||
|   | 268ae08cbc | ||
|   | 9c5a42a7c9 | ||
|   | b4ac56fa43 | ||
|   | 24f54d74c0 | ||
|   | 8d99052cbc | ||
|   | 58a0402e7d | ||
|   | 7920f570b8 | ||
|   | a172494938 | ||
|   | f8717682fb | ||
|   | af1210e2a3 | ||
|   | ab0e7714ce | ||
|   | fb4a5dce60 | ||
|   | 71334c58b2 | ||
|   | 888d454557 | ||
|   | dddd7ce07c | ||
|   | abddc4dd44 | ||
|   | 921c58ee44 | ||
|   | 7f45813c72 | ||
|   | 5fe0b944ef | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cfa1b7695d | ||
|   | 69b8227b27 | 
							
								
								
									
										14
									
								
								.devcontainer/devcontainer.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.devcontainer/devcontainer.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | { | ||||||
|  | 	"name": "Node.js & TypeScript", | ||||||
|  | 	"image": "mcr.microsoft.com/devcontainers/typescript-node:16-bullseye", | ||||||
|  | 	// Features to add to the dev container. More info: https://containers.dev/implementors/features. | ||||||
|  | 	// "features": {}, | ||||||
|  | 	// Use 'forwardPorts' to make a list of ports inside the container available locally. | ||||||
|  | 	// "forwardPorts": [], | ||||||
|  | 	// Use 'postCreateCommand' to run commands after the container is created. | ||||||
|  | 	"postCreateCommand": "npm install && npm run build" | ||||||
|  | 	// Configure tool-specific properties. | ||||||
|  | 	// "customizations": {}, | ||||||
|  | 	// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root. | ||||||
|  | 	// "remoteUser": "root" | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							| @@ -27,6 +27,7 @@ jobs: | |||||||
|         uses: actions/setup-node@v3 |         uses: actions/setup-node@v3 | ||||||
|         with: |         with: | ||||||
|           node-version: 16.x |           node-version: 16.x | ||||||
|  |           cache: npm | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: npm ci |         run: npm ci | ||||||
|       - name: Rebuild the dist/ directory |       - name: Rebuild the dist/ directory | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @@ -25,17 +25,7 @@ jobs: | |||||||
|       uses: actions/setup-node@v3 |       uses: actions/setup-node@v3 | ||||||
|       with: |       with: | ||||||
|         node-version: 16.x |         node-version: 16.x | ||||||
|     - name: Determine npm cache directory |         cache: npm | ||||||
|       id: npm-cache |  | ||||||
|       run: | |  | ||||||
|         echo "::set-output name=dir::$(npm config get cache)" |  | ||||||
|     - name: Restore npm cache |  | ||||||
|       uses: actions/cache@v3 |  | ||||||
|       with: |  | ||||||
|         path: ${{ steps.npm-cache.outputs.dir }} |  | ||||||
|         key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} |  | ||||||
|         restore-keys: | |  | ||||||
|           ${{ runner.os }}-node- |  | ||||||
|     - run: npm ci |     - run: npm ci | ||||||
|     - name: Prettier Format Check |     - name: Prettier Format Check | ||||||
|       run: npm run format-check |       run: npm run format-check | ||||||
|   | |||||||
| @@ -102,7 +102,7 @@ test("restore on GHES with AC available ", async () => { | |||||||
|     const infoMock = jest.spyOn(core, "info"); |     const infoMock = jest.spyOn(core, "info"); | ||||||
|     const failedMock = jest.spyOn(core, "setFailed"); |     const failedMock = jest.spyOn(core, "setFailed"); | ||||||
|     const stateMock = jest.spyOn(core, "saveState"); |     const stateMock = jest.spyOn(core, "saveState"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(core, "setOutput"); | ||||||
|     const restoreCacheMock = jest |     const restoreCacheMock = jest | ||||||
|         .spyOn(cache, "restoreCache") |         .spyOn(cache, "restoreCache") | ||||||
|         .mockImplementationOnce(() => { |         .mockImplementationOnce(() => { | ||||||
| @@ -116,7 +116,7 @@ test("restore on GHES with AC available ", async () => { | |||||||
|  |  | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(true); |     expect(setCacheHitOutputMock).toHaveBeenCalledWith("cache-hit", "true"); | ||||||
|  |  | ||||||
|     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); |     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); | ||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
| @@ -270,7 +270,7 @@ test("restore with cache found for key", async () => { | |||||||
|     const infoMock = jest.spyOn(core, "info"); |     const infoMock = jest.spyOn(core, "info"); | ||||||
|     const failedMock = jest.spyOn(core, "setFailed"); |     const failedMock = jest.spyOn(core, "setFailed"); | ||||||
|     const stateMock = jest.spyOn(core, "saveState"); |     const stateMock = jest.spyOn(core, "saveState"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(core, "setOutput"); | ||||||
|     const restoreCacheMock = jest |     const restoreCacheMock = jest | ||||||
|         .spyOn(cache, "restoreCache") |         .spyOn(cache, "restoreCache") | ||||||
|         .mockImplementationOnce(() => { |         .mockImplementationOnce(() => { | ||||||
| @@ -284,7 +284,7 @@ test("restore with cache found for key", async () => { | |||||||
|  |  | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(true); |     expect(setCacheHitOutputMock).toHaveBeenCalledWith("cache-hit", "true"); | ||||||
|  |  | ||||||
|     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); |     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); | ||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
| @@ -303,7 +303,7 @@ test("restore with cache found for restore key", async () => { | |||||||
|     const infoMock = jest.spyOn(core, "info"); |     const infoMock = jest.spyOn(core, "info"); | ||||||
|     const failedMock = jest.spyOn(core, "setFailed"); |     const failedMock = jest.spyOn(core, "setFailed"); | ||||||
|     const stateMock = jest.spyOn(core, "saveState"); |     const stateMock = jest.spyOn(core, "saveState"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(core, "setOutput"); | ||||||
|     const restoreCacheMock = jest |     const restoreCacheMock = jest | ||||||
|         .spyOn(cache, "restoreCache") |         .spyOn(cache, "restoreCache") | ||||||
|         .mockImplementationOnce(() => { |         .mockImplementationOnce(() => { | ||||||
| @@ -317,8 +317,7 @@ test("restore with cache found for restore key", async () => { | |||||||
|  |  | ||||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); |     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(false); |     expect(setCacheHitOutputMock).toHaveBeenCalledWith("cache-hit", "false"); | ||||||
|  |  | ||||||
|     expect(infoMock).toHaveBeenCalledWith( |     expect(infoMock).toHaveBeenCalledWith( | ||||||
|         `Cache restored from key: ${restoreKey}` |         `Cache restored from key: ${restoreKey}` | ||||||
|     ); |     ); | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ runs: | |||||||
|   using: 'node16' |   using: 'node16' | ||||||
|   main: 'dist/restore/index.js' |   main: 'dist/restore/index.js' | ||||||
|   post: 'dist/save/index.js' |   post: 'dist/save/index.js' | ||||||
|   post-if: 'success()' |   post-if: success() | ||||||
| branding: | branding: | ||||||
|   icon: 'archive' |   icon: 'archive' | ||||||
|   color: 'gray-dark' |   color: 'gray-dark' | ||||||
|   | |||||||
							
								
								
									
										1092
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1092
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										389
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										389
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							| @@ -1892,10 +1892,10 @@ function serial(list, iterator, callback) | |||||||
| module.exports = minimatch | module.exports = minimatch | ||||||
| minimatch.Minimatch = Minimatch | minimatch.Minimatch = Minimatch | ||||||
| 
 | 
 | ||||||
| var path = { sep: '/' } | var path = (function () { try { return __webpack_require__(622) } catch (e) {}}()) || { | ||||||
| try { |   sep: '/' | ||||||
|   path = __webpack_require__(622) | } | ||||||
| } catch (er) {} | minimatch.sep = path.sep | ||||||
| 
 | 
 | ||||||
| var GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {} | var GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {} | ||||||
| var expand = __webpack_require__(306) | var expand = __webpack_require__(306) | ||||||
| @@ -1947,43 +1947,64 @@ function filter (pattern, options) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function ext (a, b) { | function ext (a, b) { | ||||||
|   a = a || {} |  | ||||||
|   b = b || {} |   b = b || {} | ||||||
|   var t = {} |   var t = {} | ||||||
|   Object.keys(b).forEach(function (k) { |  | ||||||
|     t[k] = b[k] |  | ||||||
|   }) |  | ||||||
|   Object.keys(a).forEach(function (k) { |   Object.keys(a).forEach(function (k) { | ||||||
|     t[k] = a[k] |     t[k] = a[k] | ||||||
|   }) |   }) | ||||||
|  |   Object.keys(b).forEach(function (k) { | ||||||
|  |     t[k] = b[k] | ||||||
|  |   }) | ||||||
|   return t |   return t | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| minimatch.defaults = function (def) { | minimatch.defaults = function (def) { | ||||||
|   if (!def || !Object.keys(def).length) return minimatch |   if (!def || typeof def !== 'object' || !Object.keys(def).length) { | ||||||
|  |     return minimatch | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   var orig = minimatch |   var orig = minimatch | ||||||
| 
 | 
 | ||||||
|   var m = function minimatch (p, pattern, options) { |   var m = function minimatch (p, pattern, options) { | ||||||
|     return orig.minimatch(p, pattern, ext(def, options)) |     return orig(p, pattern, ext(def, options)) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   m.Minimatch = function Minimatch (pattern, options) { |   m.Minimatch = function Minimatch (pattern, options) { | ||||||
|     return new orig.Minimatch(pattern, ext(def, options)) |     return new orig.Minimatch(pattern, ext(def, options)) | ||||||
|   } |   } | ||||||
|  |   m.Minimatch.defaults = function defaults (options) { | ||||||
|  |     return orig.defaults(ext(def, options)).Minimatch | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   m.filter = function filter (pattern, options) { | ||||||
|  |     return orig.filter(pattern, ext(def, options)) | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   m.defaults = function defaults (options) { | ||||||
|  |     return orig.defaults(ext(def, options)) | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   m.makeRe = function makeRe (pattern, options) { | ||||||
|  |     return orig.makeRe(pattern, ext(def, options)) | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   m.braceExpand = function braceExpand (pattern, options) { | ||||||
|  |     return orig.braceExpand(pattern, ext(def, options)) | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   m.match = function (list, pattern, options) { | ||||||
|  |     return orig.match(list, pattern, ext(def, options)) | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   return m |   return m | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Minimatch.defaults = function (def) { | Minimatch.defaults = function (def) { | ||||||
|   if (!def || !Object.keys(def).length) return Minimatch |  | ||||||
|   return minimatch.defaults(def).Minimatch |   return minimatch.defaults(def).Minimatch | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function minimatch (p, pattern, options) { | function minimatch (p, pattern, options) { | ||||||
|   if (typeof pattern !== 'string') { |   assertValidPattern(pattern) | ||||||
|     throw new TypeError('glob pattern string required') |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   if (!options) options = {} |   if (!options) options = {} | ||||||
| 
 | 
 | ||||||
| @@ -1992,9 +2013,6 @@ function minimatch (p, pattern, options) { | |||||||
|     return false |     return false | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // "" only matches ""
 |  | ||||||
|   if (pattern.trim() === '') return p === '' |  | ||||||
| 
 |  | ||||||
|   return new Minimatch(pattern, options).match(p) |   return new Minimatch(pattern, options).match(p) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @@ -2003,15 +2021,14 @@ function Minimatch (pattern, options) { | |||||||
|     return new Minimatch(pattern, options) |     return new Minimatch(pattern, options) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (typeof pattern !== 'string') { |   assertValidPattern(pattern) | ||||||
|     throw new TypeError('glob pattern string required') |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   if (!options) options = {} |   if (!options) options = {} | ||||||
|  | 
 | ||||||
|   pattern = pattern.trim() |   pattern = pattern.trim() | ||||||
| 
 | 
 | ||||||
|   // windows support: need to use /, not \
 |   // windows support: need to use /, not \
 | ||||||
|   if (path.sep !== '/') { |   if (!options.allowWindowsEscape && path.sep !== '/') { | ||||||
|     pattern = pattern.split(path.sep).join('/') |     pattern = pattern.split(path.sep).join('/') | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| @@ -2022,6 +2039,7 @@ function Minimatch (pattern, options) { | |||||||
|   this.negate = false |   this.negate = false | ||||||
|   this.comment = false |   this.comment = false | ||||||
|   this.empty = false |   this.empty = false | ||||||
|  |   this.partial = !!options.partial | ||||||
| 
 | 
 | ||||||
|   // make the set of regexps etc.
 |   // make the set of regexps etc.
 | ||||||
|   this.make() |   this.make() | ||||||
| @@ -2031,9 +2049,6 @@ Minimatch.prototype.debug = function () {} | |||||||
| 
 | 
 | ||||||
| Minimatch.prototype.make = make | Minimatch.prototype.make = make | ||||||
| function make () { | function make () { | ||||||
|   // don't do it more than once.
 |  | ||||||
|   if (this._made) return |  | ||||||
| 
 |  | ||||||
|   var pattern = this.pattern |   var pattern = this.pattern | ||||||
|   var options = this.options |   var options = this.options | ||||||
| 
 | 
 | ||||||
| @@ -2053,7 +2068,7 @@ function make () { | |||||||
|   // step 2: expand braces
 |   // step 2: expand braces
 | ||||||
|   var set = this.globSet = this.braceExpand() |   var set = this.globSet = this.braceExpand() | ||||||
| 
 | 
 | ||||||
|   if (options.debug) this.debug = console.error |   if (options.debug) this.debug = function debug() { console.error.apply(console, arguments) } | ||||||
| 
 | 
 | ||||||
|   this.debug(this.pattern, set) |   this.debug(this.pattern, set) | ||||||
| 
 | 
 | ||||||
| @@ -2133,12 +2148,11 @@ function braceExpand (pattern, options) { | |||||||
|   pattern = typeof pattern === 'undefined' |   pattern = typeof pattern === 'undefined' | ||||||
|     ? this.pattern : pattern |     ? this.pattern : pattern | ||||||
| 
 | 
 | ||||||
|   if (typeof pattern === 'undefined') { |   assertValidPattern(pattern) | ||||||
|     throw new TypeError('undefined pattern') |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   if (options.nobrace || |   // Thanks to Yeting Li <https://github.com/yetingli> for
 | ||||||
|     !pattern.match(/\{.*\}/)) { |   // improving this regexp to avoid a ReDOS vulnerability.
 | ||||||
|  |   if (options.nobrace || !/\{(?:(?!\{).)*\}/.test(pattern)) { | ||||||
|     // shortcut. no need to expand.
 |     // shortcut. no need to expand.
 | ||||||
|     return [pattern] |     return [pattern] | ||||||
|   } |   } | ||||||
| @@ -2146,6 +2160,17 @@ function braceExpand (pattern, options) { | |||||||
|   return expand(pattern) |   return expand(pattern) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | var MAX_PATTERN_LENGTH = 1024 * 64 | ||||||
|  | var assertValidPattern = function (pattern) { | ||||||
|  |   if (typeof pattern !== 'string') { | ||||||
|  |     throw new TypeError('invalid pattern') | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   if (pattern.length > MAX_PATTERN_LENGTH) { | ||||||
|  |     throw new TypeError('pattern is too long') | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // parse a component of the expanded set.
 | // parse a component of the expanded set.
 | ||||||
| // At this point, no pattern may contain "/" in it
 | // At this point, no pattern may contain "/" in it
 | ||||||
| // so we're going to return a 2d array, where each entry is the full
 | // so we're going to return a 2d array, where each entry is the full
 | ||||||
| @@ -2160,14 +2185,17 @@ function braceExpand (pattern, options) { | |||||||
| Minimatch.prototype.parse = parse | Minimatch.prototype.parse = parse | ||||||
| var SUBPARSE = {} | var SUBPARSE = {} | ||||||
| function parse (pattern, isSub) { | function parse (pattern, isSub) { | ||||||
|   if (pattern.length > 1024 * 64) { |   assertValidPattern(pattern) | ||||||
|     throw new TypeError('pattern is too long') |  | ||||||
|   } |  | ||||||
| 
 | 
 | ||||||
|   var options = this.options |   var options = this.options | ||||||
| 
 | 
 | ||||||
|   // shortcuts
 |   // shortcuts
 | ||||||
|   if (!options.noglobstar && pattern === '**') return GLOBSTAR |   if (pattern === '**') { | ||||||
|  |     if (!options.noglobstar) | ||||||
|  |       return GLOBSTAR | ||||||
|  |     else | ||||||
|  |       pattern = '*' | ||||||
|  |   } | ||||||
|   if (pattern === '') return '' |   if (pattern === '') return '' | ||||||
| 
 | 
 | ||||||
|   var re = '' |   var re = '' | ||||||
| @@ -2223,10 +2251,12 @@ function parse (pattern, isSub) { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     switch (c) { |     switch (c) { | ||||||
|       case '/': |       /* istanbul ignore next */ | ||||||
|  |       case '/': { | ||||||
|         // completely not allowed, even escaped.
 |         // completely not allowed, even escaped.
 | ||||||
|         // Should already be path-split by now.
 |         // Should already be path-split by now.
 | ||||||
|         return false |         return false | ||||||
|  |       } | ||||||
| 
 | 
 | ||||||
|       case '\\': |       case '\\': | ||||||
|         clearStateChar() |         clearStateChar() | ||||||
| @@ -2345,7 +2375,6 @@ function parse (pattern, isSub) { | |||||||
| 
 | 
 | ||||||
|         // handle the case where we left a class open.
 |         // handle the case where we left a class open.
 | ||||||
|         // "[z-a]" is valid, equivalent to "\[z-a\]"
 |         // "[z-a]" is valid, equivalent to "\[z-a\]"
 | ||||||
|         if (inClass) { |  | ||||||
|         // split where the last [ was, make sure we don't have
 |         // split where the last [ was, make sure we don't have
 | ||||||
|         // an invalid re. if so, re-walk the contents of the
 |         // an invalid re. if so, re-walk the contents of the
 | ||||||
|         // would-be class to re-translate any characters that
 |         // would-be class to re-translate any characters that
 | ||||||
| @@ -2364,7 +2393,6 @@ function parse (pattern, isSub) { | |||||||
|           inClass = false |           inClass = false | ||||||
|           continue |           continue | ||||||
|         } |         } | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         // finish up the class.
 |         // finish up the class.
 | ||||||
|         hasMagic = true |         hasMagic = true | ||||||
| @@ -2447,9 +2475,7 @@ function parse (pattern, isSub) { | |||||||
|   // something that could conceivably capture a dot
 |   // something that could conceivably capture a dot
 | ||||||
|   var addPatternStart = false |   var addPatternStart = false | ||||||
|   switch (re.charAt(0)) { |   switch (re.charAt(0)) { | ||||||
|     case '.': |     case '[': case '.': case '(': addPatternStart = true | ||||||
|     case '[': |  | ||||||
|     case '(': addPatternStart = true |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // Hack to work around lack of negative lookbehind in JS
 |   // Hack to work around lack of negative lookbehind in JS
 | ||||||
| @@ -2511,7 +2537,7 @@ function parse (pattern, isSub) { | |||||||
|   var flags = options.nocase ? 'i' : '' |   var flags = options.nocase ? 'i' : '' | ||||||
|   try { |   try { | ||||||
|     var regExp = new RegExp('^' + re + '$', flags) |     var regExp = new RegExp('^' + re + '$', flags) | ||||||
|   } catch (er) { |   } catch (er) /* istanbul ignore next - should be impossible */ { | ||||||
|     // If it was an invalid regular expression, then it can't match
 |     // If it was an invalid regular expression, then it can't match
 | ||||||
|     // anything.  This trick looks for a character after the end of
 |     // anything.  This trick looks for a character after the end of
 | ||||||
|     // the string, which is of course impossible, except in multi-line
 |     // the string, which is of course impossible, except in multi-line
 | ||||||
| @@ -2569,7 +2595,7 @@ function makeRe () { | |||||||
| 
 | 
 | ||||||
|   try { |   try { | ||||||
|     this.regexp = new RegExp(re, flags) |     this.regexp = new RegExp(re, flags) | ||||||
|   } catch (ex) { |   } catch (ex) /* istanbul ignore next - should be impossible */ { | ||||||
|     this.regexp = false |     this.regexp = false | ||||||
|   } |   } | ||||||
|   return this.regexp |   return this.regexp | ||||||
| @@ -2587,8 +2613,8 @@ minimatch.match = function (list, pattern, options) { | |||||||
|   return list |   return list | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Minimatch.prototype.match = match | Minimatch.prototype.match = function match (f, partial) { | ||||||
| function match (f, partial) { |   if (typeof partial === 'undefined') partial = this.partial | ||||||
|   this.debug('match', f, this.pattern) |   this.debug('match', f, this.pattern) | ||||||
|   // short-circuit in the case of busted things.
 |   // short-circuit in the case of busted things.
 | ||||||
|   // comments, etc.
 |   // comments, etc.
 | ||||||
| @@ -2670,6 +2696,7 @@ Minimatch.prototype.matchOne = function (file, pattern, partial) { | |||||||
| 
 | 
 | ||||||
|     // should be impossible.
 |     // should be impossible.
 | ||||||
|     // some invalid regexp stuff in the set.
 |     // some invalid regexp stuff in the set.
 | ||||||
|  |     /* istanbul ignore if */ | ||||||
|     if (p === false) return false |     if (p === false) return false | ||||||
| 
 | 
 | ||||||
|     if (p === GLOBSTAR) { |     if (p === GLOBSTAR) { | ||||||
| @@ -2743,6 +2770,7 @@ Minimatch.prototype.matchOne = function (file, pattern, partial) { | |||||||
|       // no match was found.
 |       // no match was found.
 | ||||||
|       // However, in partial mode, we can't say this is necessarily over.
 |       // However, in partial mode, we can't say this is necessarily over.
 | ||||||
|       // If there's more *pattern* left, then
 |       // If there's more *pattern* left, then
 | ||||||
|  |       /* istanbul ignore if */ | ||||||
|       if (partial) { |       if (partial) { | ||||||
|         // ran out of file
 |         // ran out of file
 | ||||||
|         this.debug('\n>>> no match, partial?', file, fr, pattern, pr) |         this.debug('\n>>> no match, partial?', file, fr, pattern, pr) | ||||||
| @@ -2756,11 +2784,7 @@ Minimatch.prototype.matchOne = function (file, pattern, partial) { | |||||||
|     // patterns with magic have been turned into regexps.
 |     // patterns with magic have been turned into regexps.
 | ||||||
|     var hit |     var hit | ||||||
|     if (typeof p === 'string') { |     if (typeof p === 'string') { | ||||||
|       if (options.nocase) { |  | ||||||
|         hit = f.toLowerCase() === p.toLowerCase() |  | ||||||
|       } else { |  | ||||||
|       hit = f === p |       hit = f === p | ||||||
|       } |  | ||||||
|       this.debug('string match', p, f, hit) |       this.debug('string match', p, f, hit) | ||||||
|     } else { |     } else { | ||||||
|       hit = f.match(p) |       hit = f.match(p) | ||||||
| @@ -2791,16 +2815,16 @@ Minimatch.prototype.matchOne = function (file, pattern, partial) { | |||||||
|     // this is ok if we're doing the match as part of
 |     // this is ok if we're doing the match as part of
 | ||||||
|     // a glob fs traversal.
 |     // a glob fs traversal.
 | ||||||
|     return partial |     return partial | ||||||
|   } else if (pi === pl) { |   } else /* istanbul ignore else */ if (pi === pl) { | ||||||
|     // ran out of pattern, still have file left.
 |     // ran out of pattern, still have file left.
 | ||||||
|     // this is only acceptable if we're on the very last
 |     // this is only acceptable if we're on the very last
 | ||||||
|     // empty segment of a file with a trailing slash.
 |     // empty segment of a file with a trailing slash.
 | ||||||
|     // a/* should match a/b/
 |     // a/* should match a/b/
 | ||||||
|     var emptyFileEnd = (fi === fl - 1) && (file[fi] === '') |     return (fi === fl - 1) && (file[fi] === '') | ||||||
|     return emptyFileEnd |  | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // should be unreachable.
 |   // should be unreachable.
 | ||||||
|  |   /* istanbul ignore next */ | ||||||
|   throw new Error('wtf?') |   throw new Error('wtf?') | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @@ -9320,7 +9344,76 @@ function expand(str, isTop) { | |||||||
| /***/ }), | /***/ }), | ||||||
| /* 307 */, | /* 307 */, | ||||||
| /* 308 */, | /* 308 */, | ||||||
| /* 309 */, | /* 309 */ | ||||||
|  | /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||||
|  | 
 | ||||||
|  | "use strict"; | ||||||
|  | 
 | ||||||
|  | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|  |     if (k2 === undefined) k2 = k; | ||||||
|  |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
|  | }) : (function(o, m, k, k2) { | ||||||
|  |     if (k2 === undefined) k2 = k; | ||||||
|  |     o[k2] = m[k]; | ||||||
|  | })); | ||||||
|  | var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { | ||||||
|  |     Object.defineProperty(o, "default", { enumerable: true, value: v }); | ||||||
|  | }) : function(o, v) { | ||||||
|  |     o["default"] = v; | ||||||
|  | }); | ||||||
|  | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|  |     if (mod && mod.__esModule) return mod; | ||||||
|  |     var result = {}; | ||||||
|  |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|  |     __setModuleDefault(result, mod); | ||||||
|  |     return result; | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | exports.NullStateProvider = exports.StateProvider = void 0; | ||||||
|  | const core = __importStar(__webpack_require__(470)); | ||||||
|  | const constants_1 = __webpack_require__(196); | ||||||
|  | class StateProviderBase { | ||||||
|  |     constructor() { | ||||||
|  |         // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function
 | ||||||
|  |         this.setState = (key, value) => { }; | ||||||
|  |         // eslint-disable-next-line @typescript-eslint/no-unused-vars
 | ||||||
|  |         this.getState = (key) => ""; | ||||||
|  |     } | ||||||
|  |     getCacheState() { | ||||||
|  |         const cacheKey = this.getState(constants_1.State.CacheMatchedKey); | ||||||
|  |         if (cacheKey) { | ||||||
|  |             core.debug(`Cache state/key: ${cacheKey}`); | ||||||
|  |             return cacheKey; | ||||||
|  |         } | ||||||
|  |         return undefined; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | class StateProvider extends StateProviderBase { | ||||||
|  |     constructor() { | ||||||
|  |         super(...arguments); | ||||||
|  |         //setOutput = core.setOutput;
 | ||||||
|  |         this.setState = core.saveState; | ||||||
|  |         this.getState = core.getState; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | exports.StateProvider = StateProvider; | ||||||
|  | class NullStateProvider extends StateProviderBase { | ||||||
|  |     constructor() { | ||||||
|  |         super(...arguments); | ||||||
|  |         //setOutput = core.setOutput;
 | ||||||
|  |         this.setState = core.setOutput; | ||||||
|  |         // eslint-disable-next-line @typescript-eslint/no-unused-vars
 | ||||||
|  |         this.getState = (key) => ""; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | exports.NullStateProvider = NullStateProvider; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /***/ }), | ||||||
| /* 310 */, | /* 310 */, | ||||||
| /* 311 */, | /* 311 */, | ||||||
| /* 312 */ | /* 312 */ | ||||||
| @@ -38398,7 +38491,7 @@ var __importStar = (this && this.__importStar) || function (mod) { | |||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.isCacheFeatureAvailable = exports.getInputAsInt = exports.getInputAsArray = exports.isValidEvent = exports.logWarning = exports.getCacheState = exports.setOutputAndState = exports.setCacheHitOutput = exports.setCacheState = exports.isExactKeyMatch = exports.isGhes = void 0; | exports.isCacheFeatureAvailable = exports.getInputAsInt = exports.getInputAsArray = exports.isValidEvent = exports.logWarning = exports.setCacheHitOutput = exports.isExactKeyMatch = exports.isGhes = void 0; | ||||||
| const cache = __importStar(__webpack_require__(692)); | const cache = __importStar(__webpack_require__(692)); | ||||||
| const core = __importStar(__webpack_require__(470)); | const core = __importStar(__webpack_require__(470)); | ||||||
| const constants_1 = __webpack_require__(196); | const constants_1 = __webpack_require__(196); | ||||||
| @@ -38414,29 +38507,10 @@ function isExactKeyMatch(key, cacheKey) { | |||||||
|         }) === 0); |         }) === 0); | ||||||
| } | } | ||||||
| exports.isExactKeyMatch = isExactKeyMatch; | exports.isExactKeyMatch = isExactKeyMatch; | ||||||
| function setCacheState(state) { |  | ||||||
|     core.saveState(constants_1.State.CacheMatchedKey, state); |  | ||||||
| } |  | ||||||
| exports.setCacheState = setCacheState; |  | ||||||
| function setCacheHitOutput(isCacheHit) { | function setCacheHitOutput(isCacheHit) { | ||||||
|     core.setOutput(constants_1.Outputs.CacheHit, isCacheHit.toString()); |     core.setOutput(constants_1.Outputs.CacheHit, isCacheHit.toString()); | ||||||
| } | } | ||||||
| exports.setCacheHitOutput = setCacheHitOutput; | exports.setCacheHitOutput = setCacheHitOutput; | ||||||
| function setOutputAndState(key, cacheKey) { |  | ||||||
|     setCacheHitOutput(isExactKeyMatch(key, cacheKey)); |  | ||||||
|     // Store the matched cache key if it exists
 |  | ||||||
|     cacheKey && setCacheState(cacheKey); |  | ||||||
| } |  | ||||||
| exports.setOutputAndState = setOutputAndState; |  | ||||||
| function getCacheState() { |  | ||||||
|     const cacheKey = core.getState(constants_1.State.CacheMatchedKey); |  | ||||||
|     if (cacheKey) { |  | ||||||
|         core.debug(`Cache state/key: ${cacheKey}`); |  | ||||||
|         return cacheKey; |  | ||||||
|     } |  | ||||||
|     return undefined; |  | ||||||
| } |  | ||||||
| exports.getCacheState = getCacheState; |  | ||||||
| function logWarning(message) { | function logWarning(message) { | ||||||
|     const warningPrefix = "[warning]"; |     const warningPrefix = "[warning]"; | ||||||
|     core.info(`${warningPrefix}${message}`); |     core.info(`${warningPrefix}${message}`); | ||||||
| @@ -38465,17 +38539,16 @@ function getInputAsInt(name, options) { | |||||||
| } | } | ||||||
| exports.getInputAsInt = getInputAsInt; | exports.getInputAsInt = getInputAsInt; | ||||||
| function isCacheFeatureAvailable() { | function isCacheFeatureAvailable() { | ||||||
|     if (!cache.isFeatureAvailable()) { |     if (cache.isFeatureAvailable()) { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|     if (isGhes()) { |     if (isGhes()) { | ||||||
|         logWarning(`Cache action is only supported on GHES version >= 3.5. If you are on version >=3.5 Please check with GHES admin if Actions cache service is enabled or not.
 |         logWarning(`Cache action is only supported on GHES version >= 3.5. If you are on version >=3.5 Please check with GHES admin if Actions cache service is enabled or not.
 | ||||||
| Otherwise please upgrade to GHES version >= 3.5 and If you are also using Github Connect, please unretire the actions/cache namespace before upgrade (see https://docs.github.com/en/enterprise-server@3.5/admin/github-actions/managing-access-to-actions-from-githubcom/enabling-automatic-access-to-githubcom-actions-using-github-connect#automatic-retirement-of-namespaces-for-actions-accessed-on-githubcom)`);
 | Otherwise please upgrade to GHES version >= 3.5 and If you are also using Github Connect, please unretire the actions/cache namespace before upgrade (see https://docs.github.com/en/enterprise-server@3.5/admin/github-actions/managing-access-to-actions-from-githubcom/enabling-automatic-access-to-githubcom-actions-using-github-connect#automatic-retirement-of-namespaces-for-actions-accessed-on-githubcom)`);
 | ||||||
|         } |  | ||||||
|         else { |  | ||||||
|             logWarning("An internal error has occurred in cache backend. Please check https://www.githubstatus.com/ for any ongoing issue in actions."); |  | ||||||
|         } |  | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|     return true; |     logWarning("An internal error has occurred in cache backend. Please check https://www.githubstatus.com/ for any ongoing issue in actions."); | ||||||
|  |     return false; | ||||||
| } | } | ||||||
| exports.isCacheFeatureAvailable = isCacheFeatureAvailable; | exports.isCacheFeatureAvailable = isCacheFeatureAvailable; | ||||||
| 
 | 
 | ||||||
| @@ -40869,7 +40942,96 @@ Object.defineProperty(exports, "toPlatformPath", { enumerable: true, get: functi | |||||||
| //# sourceMappingURL=core.js.map
 | //# sourceMappingURL=core.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| /* 471 */, | /* 471 */ | ||||||
|  | /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||||
|  | 
 | ||||||
|  | "use strict"; | ||||||
|  | 
 | ||||||
|  | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|  |     if (k2 === undefined) k2 = k; | ||||||
|  |     var desc = Object.getOwnPropertyDescriptor(m, k); | ||||||
|  |     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { | ||||||
|  |       desc = { enumerable: true, get: function() { return m[k]; } }; | ||||||
|  |     } | ||||||
|  |     Object.defineProperty(o, k2, desc); | ||||||
|  | }) : (function(o, m, k, k2) { | ||||||
|  |     if (k2 === undefined) k2 = k; | ||||||
|  |     o[k2] = m[k]; | ||||||
|  | })); | ||||||
|  | var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { | ||||||
|  |     Object.defineProperty(o, "default", { enumerable: true, value: v }); | ||||||
|  | }) : function(o, v) { | ||||||
|  |     o["default"] = v; | ||||||
|  | }); | ||||||
|  | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|  |     if (mod && mod.__esModule) return mod; | ||||||
|  |     var result = {}; | ||||||
|  |     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||||
|  |     __setModuleDefault(result, mod); | ||||||
|  |     return result; | ||||||
|  | }; | ||||||
|  | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|  |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|  |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
|  |         function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||||||
|  |         function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||||||
|  |         function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||||||
|  |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
|  | const cache = __importStar(__webpack_require__(692)); | ||||||
|  | const core = __importStar(__webpack_require__(470)); | ||||||
|  | const constants_1 = __webpack_require__(196); | ||||||
|  | const utils = __importStar(__webpack_require__(443)); | ||||||
|  | // 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 => utils.logWarning(e.message)); | ||||||
|  | function saveImpl(stateProvider) { | ||||||
|  |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|  |         try { | ||||||
|  |             if (!utils.isCacheFeatureAvailable()) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             if (!utils.isValidEvent()) { | ||||||
|  |                 utils.logWarning(`Event Validation Error: The event type ${process.env[constants_1.Events.Key]} is not supported because it's not tied to a branch or tag ref.`); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // If restore has stored a primary key in state, reuse that
 | ||||||
|  |             // Else re-evaluate from inputs
 | ||||||
|  |             const primaryKey = stateProvider.getState(constants_1.State.CachePrimaryKey) || | ||||||
|  |                 core.getInput(constants_1.Inputs.Key); | ||||||
|  |             if (!primaryKey) { | ||||||
|  |                 utils.logWarning(`Error retrieving key from state.`); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // If matched restore key is same as primary key, then do not save cache
 | ||||||
|  |             // NO-OP in case of SaveOnly action
 | ||||||
|  |             const state = stateProvider.getCacheState(); | ||||||
|  |             if (utils.isExactKeyMatch(primaryKey, state)) { | ||||||
|  |                 core.info(`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, { | ||||||
|  |                 required: true | ||||||
|  |             }); | ||||||
|  |             const cacheId = yield cache.saveCache(cachePaths, primaryKey, { | ||||||
|  |                 uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize) | ||||||
|  |             }); | ||||||
|  |             if (cacheId != -1) { | ||||||
|  |                 core.info(`Cache saved with key: ${primaryKey}`); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         catch (error) { | ||||||
|  |             utils.logWarning(error.message); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | exports.default = saveImpl; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /***/ }), | ||||||
| /* 472 */, | /* 472 */, | ||||||
| /* 473 */, | /* 473 */, | ||||||
| /* 474 */, | /* 474 */, | ||||||
| @@ -47245,29 +47407,6 @@ exports.default = _default; | |||||||
| 
 | 
 | ||||||
| "use strict"; | "use strict"; | ||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { |  | ||||||
|     if (k2 === undefined) k2 = k; |  | ||||||
|     var desc = Object.getOwnPropertyDescriptor(m, k); |  | ||||||
|     if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { |  | ||||||
|       desc = { enumerable: true, get: function() { return m[k]; } }; |  | ||||||
|     } |  | ||||||
|     Object.defineProperty(o, k2, desc); |  | ||||||
| }) : (function(o, m, k, k2) { |  | ||||||
|     if (k2 === undefined) k2 = k; |  | ||||||
|     o[k2] = m[k]; |  | ||||||
| })); |  | ||||||
| var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { |  | ||||||
|     Object.defineProperty(o, "default", { enumerable: true, value: v }); |  | ||||||
| }) : function(o, v) { |  | ||||||
|     o["default"] = v; |  | ||||||
| }); |  | ||||||
| var __importStar = (this && this.__importStar) || function (mod) { |  | ||||||
|     if (mod && mod.__esModule) return mod; |  | ||||||
|     var result = {}; |  | ||||||
|     if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); |  | ||||||
|     __setModuleDefault(result, mod); |  | ||||||
|     return result; |  | ||||||
| }; |  | ||||||
| var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||||||
|     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } |     function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||||||
|     return new (P || (P = Promise))(function (resolve, reject) { |     return new (P || (P = Promise))(function (resolve, reject) { | ||||||
| @@ -47277,49 +47416,15 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge | |||||||
|         step((generator = generator.apply(thisArg, _arguments || [])).next()); |         step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||||||
|     }); |     }); | ||||||
| }; | }; | ||||||
|  | var __importDefault = (this && this.__importDefault) || function (mod) { | ||||||
|  |     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||||
|  | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| const cache = __importStar(__webpack_require__(692)); | const saveImpl_1 = __importDefault(__webpack_require__(471)); | ||||||
| const core = __importStar(__webpack_require__(470)); | const stateProvider_1 = __webpack_require__(309); | ||||||
| const constants_1 = __webpack_require__(196); |  | ||||||
| const utils = __importStar(__webpack_require__(443)); |  | ||||||
| // 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 => utils.logWarning(e.message)); |  | ||||||
| function run() { | function run() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         try { |         yield (0, saveImpl_1.default)(new stateProvider_1.StateProvider()); | ||||||
|             if (!utils.isCacheFeatureAvailable()) { |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if (!utils.isValidEvent()) { |  | ||||||
|                 utils.logWarning(`Event Validation Error: The event type ${process.env[constants_1.Events.Key]} is not supported because it's not tied to a branch or tag ref.`); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             const state = utils.getCacheState(); |  | ||||||
|             // Inputs are re-evaluted before the post action, so we want the original key used for restore
 |  | ||||||
|             const primaryKey = core.getState(constants_1.State.CachePrimaryKey); |  | ||||||
|             if (!primaryKey) { |  | ||||||
|                 utils.logWarning(`Error retrieving key from state.`); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if (utils.isExactKeyMatch(primaryKey, state)) { |  | ||||||
|                 core.info(`Cache hit occurred on the primary key ${primaryKey}, not saving cache.`); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             const cachePaths = utils.getInputAsArray(constants_1.Inputs.Path, { |  | ||||||
|                 required: true |  | ||||||
|             }); |  | ||||||
|             const cacheId = yield cache.saveCache(cachePaths, primaryKey, { |  | ||||||
|                 uploadChunkSize: utils.getInputAsInt(constants_1.Inputs.UploadChunkSize) |  | ||||||
|             }); |  | ||||||
|             if (cacheId != -1) { |  | ||||||
|                 core.info(`Cache saved with key: ${primaryKey}`); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         catch (error) { |  | ||||||
|             utils.logWarning(error.message); |  | ||||||
|         } |  | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| run(); | run(); | ||||||
|   | |||||||
							
								
								
									
										6514
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										6514
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										24
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								package.json
									
									
									
									
									
								
							| @@ -29,23 +29,23 @@ | |||||||
|     "@actions/io": "^1.1.2" |     "@actions/io": "^1.1.2" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/jest": "^27.5.0", |     "@types/jest": "^27.5.2", | ||||||
|     "@types/nock": "^11.1.0", |     "@types/nock": "^11.1.0", | ||||||
|     "@types/node": "^16.11.33", |     "@types/node": "^16.18.3", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.22.0", |     "@typescript-eslint/eslint-plugin": "^5.45.0", | ||||||
|     "@typescript-eslint/parser": "^5.22.0", |     "@typescript-eslint/parser": "^5.45.0", | ||||||
|     "@zeit/ncc": "^0.20.5", |     "@zeit/ncc": "^0.20.5", | ||||||
|     "eslint": "^8.14.0", |     "eslint": "^8.28.0", | ||||||
|     "eslint-config-prettier": "^8.5.0", |     "eslint-config-prettier": "^8.5.0", | ||||||
|     "eslint-plugin-import": "^2.26.0", |     "eslint-plugin-import": "^2.26.0", | ||||||
|     "eslint-plugin-jest": "^26.1.5", |     "eslint-plugin-jest": "^26.9.0", | ||||||
|     "eslint-plugin-prettier": "^4.0.0", |     "eslint-plugin-prettier": "^4.2.1", | ||||||
|     "eslint-plugin-simple-import-sort": "^7.0.0", |     "eslint-plugin-simple-import-sort": "^7.0.0", | ||||||
|     "jest": "^28.0.3", |     "jest": "^28.1.3", | ||||||
|     "jest-circus": "^27.5.1", |     "jest-circus": "^27.5.1", | ||||||
|     "nock": "^13.2.4", |     "nock": "^13.2.9", | ||||||
|     "prettier": "^2.6.2", |     "prettier": "^2.8.0", | ||||||
|     "ts-jest": "^28.0.2", |     "ts-jest": "^28.0.8", | ||||||
|     "typescript": "^4.6.4" |     "typescript": "^4.9.3" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								restore/action.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								restore/action.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | name: 'Restore Cache' | ||||||
|  | description: 'Restore Cache artifacts like dependencies and build outputs to improve workflow execution time' | ||||||
|  | author: 'GitHub' | ||||||
|  | inputs: | ||||||
|  |   path: | ||||||
|  |     description: 'The same list of files, directories, and wildcard patterns to restore cache that were used while saving it' | ||||||
|  |     required: true | ||||||
|  |   key: | ||||||
|  |     description: 'An explicit key for restoring the cache' | ||||||
|  |     required: true | ||||||
|  |   restore-keys: | ||||||
|  |     description: 'An ordered list of keys to use for restoring stale cache if no cache hit occurred for key. Note `cache-hit` returns false in this case.' | ||||||
|  |     required: false | ||||||
|  | outputs: | ||||||
|  |   cache-hit: | ||||||
|  |     description: 'A boolean value to indicate an exact match was found for the primary key' | ||||||
|  | runs: | ||||||
|  |   using: 'node16' | ||||||
|  |   main: '../dist/restore/index.js' | ||||||
|  | branding: | ||||||
|  |   icon: 'archive' | ||||||
|  |   color: 'gray-dark' | ||||||
|  |    | ||||||
							
								
								
									
										19
									
								
								save/action.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								save/action.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | name: 'Save Cache' | ||||||
|  | description: 'Save Cache artifacts like dependencies and build outputs to improve workflow execution time' | ||||||
|  | author: 'GitHub' | ||||||
|  | inputs: | ||||||
|  |   path: | ||||||
|  |     description: 'A list of files, directories, and wildcard patterns to cache' | ||||||
|  |     required: true | ||||||
|  |   key: | ||||||
|  |     description: 'An explicit key for saving the cache' | ||||||
|  |     required: true | ||||||
|  |   upload-chunk-size: | ||||||
|  |     description: 'The chunk size used to split up large files during upload, in bytes' | ||||||
|  |     required: false | ||||||
|  | runs: | ||||||
|  |   using: 'node16' | ||||||
|  |   main: '../dist/save/index.js' | ||||||
|  | branding: | ||||||
|  |   icon: 'archive' | ||||||
|  |   color: 'gray-dark' | ||||||
| @@ -1,60 +1,8 @@ | |||||||
| import * as cache from "@actions/cache"; | import { StateProvider } from "./stateProvider"; | ||||||
| import * as core from "@actions/core"; | import restoreImpl from "./restoreImpl"; | ||||||
|  |  | ||||||
| import { Events, Inputs, State } from "./constants"; |  | ||||||
| import * as utils from "./utils/actionUtils"; |  | ||||||
|  |  | ||||||
| async function run(): Promise<void> { | async function run(): Promise<void> { | ||||||
|     try { |     await restoreImpl(new StateProvider()); | ||||||
|         if (!utils.isCacheFeatureAvailable()) { |  | ||||||
|             utils.setCacheHitOutput(false); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Validate inputs, this can cause task failure |  | ||||||
|         if (!utils.isValidEvent()) { |  | ||||||
|             utils.logWarning( |  | ||||||
|                 `Event Validation Error: The event type ${ |  | ||||||
|                     process.env[Events.Key] |  | ||||||
|                 } is not supported because it's not tied to a branch or tag ref.` |  | ||||||
|             ); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         const primaryKey = core.getInput(Inputs.Key, { required: true }); |  | ||||||
|         core.saveState(State.CachePrimaryKey, primaryKey); |  | ||||||
|  |  | ||||||
|         const restoreKeys = utils.getInputAsArray(Inputs.RestoreKeys); |  | ||||||
|         const cachePaths = utils.getInputAsArray(Inputs.Path, { |  | ||||||
|             required: true |  | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         const cacheKey = await cache.restoreCache( |  | ||||||
|             cachePaths, |  | ||||||
|             primaryKey, |  | ||||||
|             restoreKeys |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         if (!cacheKey) { |  | ||||||
|             core.info( |  | ||||||
|                 `Cache not found for input keys: ${[ |  | ||||||
|                     primaryKey, |  | ||||||
|                     ...restoreKeys |  | ||||||
|                 ].join(", ")}` |  | ||||||
|             ); |  | ||||||
|  |  | ||||||
|             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: unknown) { |  | ||||||
|         core.setFailed((error as Error).message); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| run(); | run(); | ||||||
|   | |||||||
							
								
								
									
										67
									
								
								src/restoreImpl.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								src/restoreImpl.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | import * as cache from "@actions/cache"; | ||||||
|  | import * as core from "@actions/core"; | ||||||
|  |  | ||||||
|  | import { Events, Inputs, Outputs, State } from "./constants"; | ||||||
|  | import { IStateProvider } from "./stateProvider"; | ||||||
|  | import * as utils from "./utils/actionUtils"; | ||||||
|  |  | ||||||
|  | async function restoreImpl(stateProvider: IStateProvider): Promise<string | undefined> { | ||||||
|  |     try { | ||||||
|  |         if (!utils.isCacheFeatureAvailable()) { | ||||||
|  |             utils.setCacheHitOutput(false); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Validate inputs, this can cause task failure | ||||||
|  |         if (!utils.isValidEvent()) { | ||||||
|  |             utils.logWarning( | ||||||
|  |                 `Event Validation Error: The event type ${ | ||||||
|  |                     process.env[Events.Key] | ||||||
|  |                 } is not supported because it's not tied to a branch or tag ref.` | ||||||
|  |             ); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         const primaryKey = core.getInput(Inputs.Key, { required: true }); | ||||||
|  |         stateProvider.setState(State.CachePrimaryKey, primaryKey); | ||||||
|  |  | ||||||
|  |         const restoreKeys = utils.getInputAsArray(Inputs.RestoreKeys); | ||||||
|  |         const cachePaths = utils.getInputAsArray(Inputs.Path, { | ||||||
|  |             required: true | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         const cacheKey = await cache.restoreCache( | ||||||
|  |             cachePaths, | ||||||
|  |             primaryKey, | ||||||
|  |             restoreKeys | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         if (!cacheKey) { | ||||||
|  |             core.info( | ||||||
|  |                 `Cache not found for input keys: ${[ | ||||||
|  |                     primaryKey, | ||||||
|  |                     ...restoreKeys | ||||||
|  |                 ].join(", ")}` | ||||||
|  |             ); | ||||||
|  |  | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // Store the matched cache key in states | ||||||
|  |         stateProvider.setState(State.CacheMatchedKey, cacheKey); | ||||||
|  |  | ||||||
|  |         const isExactKeyMatch = utils.isExactKeyMatch( | ||||||
|  |             core.getInput(Inputs.Key, { required: true }), | ||||||
|  |             cacheKey | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         core.setOutput(Outputs.CacheHit, isExactKeyMatch.toString()); | ||||||
|  |         core.info(`Cache restored from key: ${cacheKey}`); | ||||||
|  |  | ||||||
|  |         return cacheKey; | ||||||
|  |     } catch (error: unknown) { | ||||||
|  |         core.setFailed((error as Error).message); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export default restoreImpl; | ||||||
							
								
								
									
										10
									
								
								src/restoreOnly.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/restoreOnly.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | import restoreImpl from "./restoreImpl"; | ||||||
|  | import { NullStateProvider } from "./stateProvider"; | ||||||
|  |  | ||||||
|  | async function run(): Promise<void> { | ||||||
|  |     await restoreImpl(new NullStateProvider()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | run(); | ||||||
|  |  | ||||||
|  | export default run; | ||||||
							
								
								
									
										57
									
								
								src/save.ts
									
									
									
									
									
								
							
							
						
						
									
										57
									
								
								src/save.ts
									
									
									
									
									
								
							| @@ -1,59 +1,8 @@ | |||||||
| import * as cache from "@actions/cache"; | import saveImpl from "./saveImpl"; | ||||||
| import * as core from "@actions/core"; | import { StateProvider } from "./stateProvider"; | ||||||
|  |  | ||||||
| import { Events, Inputs, State } from "./constants"; |  | ||||||
| import * as utils from "./utils/actionUtils"; |  | ||||||
|  |  | ||||||
| // 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 => utils.logWarning(e.message)); |  | ||||||
|  |  | ||||||
| async function run(): Promise<void> { | async function run(): Promise<void> { | ||||||
|     try { |     await saveImpl(new StateProvider()); | ||||||
|         if (!utils.isCacheFeatureAvailable()) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (!utils.isValidEvent()) { |  | ||||||
|             utils.logWarning( |  | ||||||
|                 `Event Validation Error: The event type ${ |  | ||||||
|                     process.env[Events.Key] |  | ||||||
|                 } is not supported because it's not tied to a branch or tag ref.` |  | ||||||
|             ); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         const state = utils.getCacheState(); |  | ||||||
|  |  | ||||||
|         // Inputs are re-evaluted before the post action, so we want the original key used for restore |  | ||||||
|         const primaryKey = core.getState(State.CachePrimaryKey); |  | ||||||
|         if (!primaryKey) { |  | ||||||
|             utils.logWarning(`Error retrieving key from state.`); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (utils.isExactKeyMatch(primaryKey, state)) { |  | ||||||
|             core.info( |  | ||||||
|                 `Cache hit occurred on the primary key ${primaryKey}, not saving cache.` |  | ||||||
|             ); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         const cachePaths = utils.getInputAsArray(Inputs.Path, { |  | ||||||
|             required: true |  | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         const cacheId = await cache.saveCache(cachePaths, primaryKey, { |  | ||||||
|             uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) |  | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         if (cacheId != -1) { |  | ||||||
|             core.info(`Cache saved with key: ${primaryKey}`); |  | ||||||
|         } |  | ||||||
|     } catch (error: unknown) { |  | ||||||
|         utils.logWarning((error as Error).message); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| run(); | run(); | ||||||
|   | |||||||
							
								
								
									
										65
									
								
								src/saveImpl.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/saveImpl.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | import * as cache from "@actions/cache"; | ||||||
|  | import * as core from "@actions/core"; | ||||||
|  |  | ||||||
|  | import { Events, Inputs, State } from "./constants"; | ||||||
|  | import { IStateProvider } from "./stateProvider"; | ||||||
|  | import * as utils from "./utils/actionUtils"; | ||||||
|  |  | ||||||
|  | // 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 => utils.logWarning(e.message)); | ||||||
|  |  | ||||||
|  | async function saveImpl(stateProvider: IStateProvider): Promise<void> { | ||||||
|  |     try { | ||||||
|  |         if (!utils.isCacheFeatureAvailable()) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (!utils.isValidEvent()) { | ||||||
|  |             utils.logWarning( | ||||||
|  |                 `Event Validation Error: The event type ${ | ||||||
|  |                     process.env[Events.Key] | ||||||
|  |                 } is not supported because it's not tied to a branch or tag ref.` | ||||||
|  |             ); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // If restore has stored a primary key in state, reuse that | ||||||
|  |         // Else re-evaluate from inputs | ||||||
|  |         const primaryKey = | ||||||
|  |             stateProvider.getState(State.CachePrimaryKey) || | ||||||
|  |             core.getInput(Inputs.Key); | ||||||
|  |  | ||||||
|  |         if (!primaryKey) { | ||||||
|  |             utils.logWarning(`Error retrieving key from state.`); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         // If matched restore key is same as primary key, then do not save cache | ||||||
|  |         // NO-OP in case of SaveOnly action | ||||||
|  |         const state = stateProvider.getCacheState(); | ||||||
|  |         if (utils.isExactKeyMatch(primaryKey, state)) { | ||||||
|  |             core.info( | ||||||
|  |                 `Cache hit occurred on the primary key ${primaryKey}, not saving cache.` | ||||||
|  |             ); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         const cachePaths = utils.getInputAsArray(Inputs.Path, { | ||||||
|  |             required: true | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         const cacheId = await cache.saveCache(cachePaths, primaryKey, { | ||||||
|  |             uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         if (cacheId != -1) { | ||||||
|  |             core.info(`Cache saved with key: ${primaryKey}`); | ||||||
|  |         } | ||||||
|  |     } catch (error: unknown) { | ||||||
|  |         utils.logWarning((error as Error).message); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export default saveImpl; | ||||||
							
								
								
									
										10
									
								
								src/saveOnly.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								src/saveOnly.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | import saveImpl from "./saveImpl"; | ||||||
|  | import { NullStateProvider } from "./stateProvider"; | ||||||
|  |  | ||||||
|  | async function run(): Promise<void> { | ||||||
|  |     await saveImpl(new NullStateProvider()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | run(); | ||||||
|  |  | ||||||
|  | export default run; | ||||||
							
								
								
									
										42
									
								
								src/stateProvider.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								src/stateProvider.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | import * as core from "@actions/core"; | ||||||
|  |  | ||||||
|  | import { State } from "./constants"; | ||||||
|  |  | ||||||
|  | export interface IStateProvider { | ||||||
|  |     //setOutput(key: string, value: string): void; | ||||||
|  |     setState(key: string, value: string): void; | ||||||
|  |     getState(key: string): string; | ||||||
|  |  | ||||||
|  |     getCacheState(): string | undefined; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class StateProviderBase implements IStateProvider { | ||||||
|  |     getCacheState(): string | undefined { | ||||||
|  |         const cacheKey = this.getState(State.CacheMatchedKey); | ||||||
|  |         if (cacheKey) { | ||||||
|  |             core.debug(`Cache state/key: ${cacheKey}`); | ||||||
|  |             return cacheKey; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return undefined; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-empty-function | ||||||
|  |     setState = (key: string, value: string) => {}; | ||||||
|  |  | ||||||
|  |     // eslint-disable-next-line @typescript-eslint/no-unused-vars | ||||||
|  |     getState = (key: string) => ""; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export class StateProvider extends StateProviderBase { | ||||||
|  |     //setOutput = core.setOutput; | ||||||
|  |     setState = core.saveState; | ||||||
|  |     getState = core.getState; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export class NullStateProvider extends StateProviderBase { | ||||||
|  |     //setOutput = core.setOutput; | ||||||
|  |     setState = core.setOutput; | ||||||
|  |     // eslint-disable-next-line @typescript-eslint/no-unused-vars | ||||||
|  |     getState = (key: string) => ""; | ||||||
|  | } | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| import * as cache from "@actions/cache"; | import * as cache from "@actions/cache"; | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
|  |  | ||||||
| import { Outputs, RefKey, State } from "../constants"; | import { Outputs, RefKey } from "../constants"; | ||||||
|  |  | ||||||
| export function isGhes(): boolean { | export function isGhes(): boolean { | ||||||
|     const ghUrl = new URL( |     const ghUrl = new URL( | ||||||
| @@ -19,30 +19,10 @@ export function isExactKeyMatch(key: string, cacheKey?: string): boolean { | |||||||
|     ); |     ); | ||||||
| } | } | ||||||
|  |  | ||||||
| export function setCacheState(state: string): void { |  | ||||||
|     core.saveState(State.CacheMatchedKey, state); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export function setCacheHitOutput(isCacheHit: boolean): void { | export function setCacheHitOutput(isCacheHit: boolean): void { | ||||||
|     core.setOutput(Outputs.CacheHit, isCacheHit.toString()); |     core.setOutput(Outputs.CacheHit, isCacheHit.toString()); | ||||||
| } | } | ||||||
|  |  | ||||||
| export function setOutputAndState(key: string, cacheKey?: string): void { |  | ||||||
|     setCacheHitOutput(isExactKeyMatch(key, cacheKey)); |  | ||||||
|     // Store the matched cache key if it exists |  | ||||||
|     cacheKey && setCacheState(cacheKey); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export function getCacheState(): string | undefined { |  | ||||||
|     const cacheKey = core.getState(State.CacheMatchedKey); |  | ||||||
|     if (cacheKey) { |  | ||||||
|         core.debug(`Cache state/key: ${cacheKey}`); |  | ||||||
|         return cacheKey; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return undefined; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| export function logWarning(message: string): void { | export function logWarning(message: string): void { | ||||||
|     const warningPrefix = "[warning]"; |     const warningPrefix = "[warning]"; | ||||||
|     core.info(`${warningPrefix}${message}`); |     core.info(`${warningPrefix}${message}`); | ||||||
| @@ -77,19 +57,20 @@ export function getInputAsInt( | |||||||
| } | } | ||||||
|  |  | ||||||
| export function isCacheFeatureAvailable(): boolean { | export function isCacheFeatureAvailable(): boolean { | ||||||
|     if (!cache.isFeatureAvailable()) { |     if (cache.isFeatureAvailable()) { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (isGhes()) { |     if (isGhes()) { | ||||||
|         logWarning( |         logWarning( | ||||||
|             `Cache action is only supported on GHES version >= 3.5. If you are on version >=3.5 Please check with GHES admin if Actions cache service is enabled or not. |             `Cache action is only supported on GHES version >= 3.5. If you are on version >=3.5 Please check with GHES admin if Actions cache service is enabled or not. | ||||||
| Otherwise please upgrade to GHES version >= 3.5 and If you are also using Github Connect, please unretire the actions/cache namespace before upgrade (see https://docs.github.com/en/enterprise-server@3.5/admin/github-actions/managing-access-to-actions-from-githubcom/enabling-automatic-access-to-githubcom-actions-using-github-connect#automatic-retirement-of-namespaces-for-actions-accessed-on-githubcom)` | Otherwise please upgrade to GHES version >= 3.5 and If you are also using Github Connect, please unretire the actions/cache namespace before upgrade (see https://docs.github.com/en/enterprise-server@3.5/admin/github-actions/managing-access-to-actions-from-githubcom/enabling-automatic-access-to-githubcom-actions-using-github-connect#automatic-retirement-of-namespaces-for-actions-accessed-on-githubcom)` | ||||||
|         ); |         ); | ||||||
|         } else { |  | ||||||
|             logWarning( |  | ||||||
|                 "An internal error has occurred in cache backend. Please check https://www.githubstatus.com/ for any ongoing issue in actions." |  | ||||||
|             ); |  | ||||||
|         } |  | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return true; |     logWarning( | ||||||
|  |         "An internal error has occurred in cache backend. Please check https://www.githubstatus.com/ for any ongoing issue in actions." | ||||||
|  |     ); | ||||||
|  |     return false; | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user