mirror of https://github.com/actions/cache.git
				
				
				
			Merge pull request #1284 from takost/update-to-node-20
Update action to node20
This commit is contained in:
		
						commit
						65b8989fab
					
				|  | @ -15,3 +15,5 @@ jobs: | ||||||
|   call-check-dist: |   call-check-dist: | ||||||
|     name: Check dist/ |     name: Check dist/ | ||||||
|     uses: actions/reusable-workflows/.github/workflows/check-dist.yml@main |     uses: actions/reusable-workflows/.github/workflows/check-dist.yml@main | ||||||
|  |     with: | ||||||
|  |       node-version: "20.x" | ||||||
|  |  | ||||||
|  | @ -21,10 +21,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |     - name: Checkout | ||||||
|       uses: actions/checkout@v3 |       uses: actions/checkout@v3 | ||||||
|     - name: Setup Node.js 16.x |     - name: Setup Node.js 20.x | ||||||
|       uses: actions/setup-node@v3 |       uses: actions/setup-node@v3 | ||||||
|       with: |       with: | ||||||
|         node-version: 16.x |         node-version: 20.x | ||||||
|         cache: npm |         cache: npm | ||||||
|     - run: npm ci |     - run: npm ci | ||||||
|     - name: Prettier Format Check |     - name: Prettier Format Check | ||||||
|  |  | ||||||
|  | @ -116,3 +116,7 @@ | ||||||
| 
 | 
 | ||||||
| - Updates @actions/cache to v3.2.3 to fix accidental mutated path arguments to `getCacheVersion` [actions/toolkit#1378](https://github.com/actions/toolkit/pull/1378) | - Updates @actions/cache to v3.2.3 to fix accidental mutated path arguments to `getCacheVersion` [actions/toolkit#1378](https://github.com/actions/toolkit/pull/1378) | ||||||
| - Additional audit fixes of npm package(s) | - Additional audit fixes of npm package(s) | ||||||
|  | 
 | ||||||
|  | ### 4.0.0 | ||||||
|  | 
 | ||||||
|  | - Updated minimum runner version support from node 12 -> node 20 | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import * as cache from "@actions/cache"; | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
| 
 | 
 | ||||||
| import { Events, Inputs, RefKey } from "../src/constants"; | import { Events, Inputs, RefKey } from "../src/constants"; | ||||||
| import run from "../src/save"; | import { saveRun } from "../src/saveImpl"; | ||||||
| import * as actionUtils from "../src/utils/actionUtils"; | import * as actionUtils from "../src/utils/actionUtils"; | ||||||
| import * as testUtils from "../src/utils/testUtils"; | import * as testUtils from "../src/utils/testUtils"; | ||||||
| 
 | 
 | ||||||
|  | @ -100,7 +100,7 @@ test("save with valid inputs uploads a cache", async () => { | ||||||
|             return Promise.resolve(cacheId); |             return Promise.resolve(cacheId); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(); |     await saveRun(); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import * as cache from "@actions/cache"; | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
| 
 | 
 | ||||||
| import { Events, Inputs, RefKey } from "../src/constants"; | import { Events, Inputs, RefKey } from "../src/constants"; | ||||||
| import run from "../src/saveImpl"; | import { saveImpl } from "../src/saveImpl"; | ||||||
| import { StateProvider } from "../src/stateProvider"; | import { StateProvider } from "../src/stateProvider"; | ||||||
| import * as actionUtils from "../src/utils/actionUtils"; | import * as actionUtils from "../src/utils/actionUtils"; | ||||||
| import * as testUtils from "../src/utils/testUtils"; | import * as testUtils from "../src/utils/testUtils"; | ||||||
|  | @ -77,7 +77,7 @@ test("save with invalid event outputs warning", async () => { | ||||||
|     const invalidEvent = "commit_comment"; |     const invalidEvent = "commit_comment"; | ||||||
|     process.env[Events.Key] = invalidEvent; |     process.env[Events.Key] = invalidEvent; | ||||||
|     delete process.env[RefKey]; |     delete process.env[RefKey]; | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
|     expect(logWarningMock).toHaveBeenCalledWith( |     expect(logWarningMock).toHaveBeenCalledWith( | ||||||
|         `Event Validation Error: The event type ${invalidEvent} is not supported because it's not tied to a branch or tag ref.` |         `Event Validation Error: The event type ${invalidEvent} is not supported because it's not tied to a branch or tag ref.` | ||||||
|     ); |     ); | ||||||
|  | @ -100,7 +100,7 @@ test("save with no primary key in state outputs warning", async () => { | ||||||
|         }); |         }); | ||||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||||
|     expect(logWarningMock).toHaveBeenCalledWith(`Key is not specified.`); |     expect(logWarningMock).toHaveBeenCalledWith(`Key is not specified.`); | ||||||
|  | @ -115,7 +115,7 @@ test("save without AC available should no-op", async () => { | ||||||
| 
 | 
 | ||||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||||
| }); | }); | ||||||
|  | @ -128,7 +128,7 @@ test("save on ghes without AC available should no-op", async () => { | ||||||
| 
 | 
 | ||||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||||
| }); | }); | ||||||
|  | @ -161,7 +161,7 @@ test("save on GHES with AC available", async () => { | ||||||
|             return Promise.resolve(cacheId); |             return Promise.resolve(cacheId); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -194,7 +194,7 @@ test("save with exact match returns early", async () => { | ||||||
|         }); |         }); | ||||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||||
|     expect(infoMock).toHaveBeenCalledWith( |     expect(infoMock).toHaveBeenCalledWith( | ||||||
|  | @ -221,7 +221,7 @@ test("save with missing input outputs warning", async () => { | ||||||
|         }); |         }); | ||||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); |     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||||
|     expect(logWarningMock).toHaveBeenCalledWith( |     expect(logWarningMock).toHaveBeenCalledWith( | ||||||
|  | @ -259,7 +259,7 @@ test("save with large cache outputs warning", async () => { | ||||||
|             ); |             ); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -306,7 +306,7 @@ test("save with reserve cache failure outputs warning", async () => { | ||||||
|             throw error; |             throw error; | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -349,7 +349,7 @@ test("save with server error outputs warning", async () => { | ||||||
|             throw new Error("HTTP Error Occurred"); |             throw new Error("HTTP Error Occurred"); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -392,7 +392,7 @@ test("save with valid inputs uploads a cache", async () => { | ||||||
|             return Promise.resolve(cacheId); |             return Promise.resolve(cacheId); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(new StateProvider()); |     await saveImpl(new StateProvider()); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import * as cache from "@actions/cache"; | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
| 
 | 
 | ||||||
| import { Events, Inputs, RefKey } from "../src/constants"; | import { Events, Inputs, RefKey } from "../src/constants"; | ||||||
| import run from "../src/saveOnly"; | import { saveOnlyRun } from "../src/saveImpl"; | ||||||
| import * as actionUtils from "../src/utils/actionUtils"; | import * as actionUtils from "../src/utils/actionUtils"; | ||||||
| import * as testUtils from "../src/utils/testUtils"; | import * as testUtils from "../src/utils/testUtils"; | ||||||
| 
 | 
 | ||||||
|  | @ -90,7 +90,7 @@ test("save with valid inputs uploads a cache", async () => { | ||||||
|             return Promise.resolve(cacheId); |             return Promise.resolve(cacheId); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(); |     await saveOnlyRun(); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  | @ -122,7 +122,7 @@ test("save failing logs the warning message", async () => { | ||||||
|             return Promise.resolve(cacheId); |             return Promise.resolve(cacheId); | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|     await run(); |     await saveOnlyRun(); | ||||||
| 
 | 
 | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); |     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(saveCacheMock).toHaveBeenCalledWith( |     expect(saveCacheMock).toHaveBeenCalledWith( | ||||||
|  |  | ||||||
|  | @ -30,7 +30,7 @@ outputs: | ||||||
|   cache-hit: |   cache-hit: | ||||||
|     description: 'A boolean value to indicate an exact match was found for the primary key' |     description: 'A boolean value to indicate an exact match was found for the primary key' | ||||||
| runs: | runs: | ||||||
|   using: 'node16' |   using: 'node20' | ||||||
|   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() | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -1,12 +1,12 @@ | ||||||
| { | { | ||||||
|   "name": "cache", |   "name": "cache", | ||||||
|   "version": "3.3.2", |   "version": "4.0.0", | ||||||
|   "lockfileVersion": 2, |   "lockfileVersion": 2, | ||||||
|   "requires": true, |   "requires": true, | ||||||
|   "packages": { |   "packages": { | ||||||
|     "": { |     "": { | ||||||
|       "name": "cache", |       "name": "cache", | ||||||
|       "version": "3.3.2", |       "version": "4.0.0", | ||||||
|       "license": "MIT", |       "license": "MIT", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "@actions/cache": "^3.2.3", |         "@actions/cache": "^3.2.3", | ||||||
|  | @ -20,7 +20,7 @@ | ||||||
|         "@types/node": "^16.18.3", |         "@types/node": "^16.18.3", | ||||||
|         "@typescript-eslint/eslint-plugin": "^5.45.0", |         "@typescript-eslint/eslint-plugin": "^5.45.0", | ||||||
|         "@typescript-eslint/parser": "^5.45.0", |         "@typescript-eslint/parser": "^5.45.0", | ||||||
|         "@zeit/ncc": "^0.20.5", |         "@vercel/ncc": "^0.38.1", | ||||||
|         "eslint": "^8.28.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", | ||||||
|  | @ -3135,11 +3135,10 @@ | ||||||
|         "url": "https://opencollective.com/typescript-eslint" |         "url": "https://opencollective.com/typescript-eslint" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@zeit/ncc": { |     "node_modules/@vercel/ncc": { | ||||||
|       "version": "0.20.5", |       "version": "0.38.1", | ||||||
|       "resolved": "https://registry.npmjs.org/@zeit/ncc/-/ncc-0.20.5.tgz", |       "resolved": "https://registry.npmjs.org/@vercel/ncc/-/ncc-0.38.1.tgz", | ||||||
|       "integrity": "sha512-XU6uzwvv95DqxciQx+aOLhbyBx/13ky+RK1y88Age9Du3BlA4mMPCy13BGjayOrrumOzlq1XV3SD/BWiZENXlw==", |       "integrity": "sha512-IBBb+iI2NLu4VQn3Vwldyi2QwaXt5+hTyh58ggAMoCGE6DJmPvwL3KPBWcJl1m9LYPChBLE980Jw+CS4Wokqxw==", | ||||||
|       "deprecated": "@zeit/ncc is no longer maintained. Please use @vercel/ncc instead.", |  | ||||||
|       "dev": true, |       "dev": true, | ||||||
|       "bin": { |       "bin": { | ||||||
|         "ncc": "dist/ncc/cli.js" |         "ncc": "dist/ncc/cli.js" | ||||||
|  | @ -12014,10 +12013,10 @@ | ||||||
|         "eslint-visitor-keys": "^3.3.0" |         "eslint-visitor-keys": "^3.3.0" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "@zeit/ncc": { |     "@vercel/ncc": { | ||||||
|       "version": "0.20.5", |       "version": "0.38.1", | ||||||
|       "resolved": "https://registry.npmjs.org/@zeit/ncc/-/ncc-0.20.5.tgz", |       "resolved": "https://registry.npmjs.org/@vercel/ncc/-/ncc-0.38.1.tgz", | ||||||
|       "integrity": "sha512-XU6uzwvv95DqxciQx+aOLhbyBx/13ky+RK1y88Age9Du3BlA4mMPCy13BGjayOrrumOzlq1XV3SD/BWiZENXlw==", |       "integrity": "sha512-IBBb+iI2NLu4VQn3Vwldyi2QwaXt5+hTyh58ggAMoCGE6DJmPvwL3KPBWcJl1m9LYPChBLE980Jw+CS4Wokqxw==", | ||||||
|       "dev": true |       "dev": true | ||||||
|     }, |     }, | ||||||
|     "abort-controller": { |     "abort-controller": { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| { | { | ||||||
|   "name": "cache", |   "name": "cache", | ||||||
|   "version": "3.3.3", |   "version": "4.0.0", | ||||||
|   "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", | ||||||
|  | @ -34,7 +34,7 @@ | ||||||
|     "@types/node": "^16.18.3", |     "@types/node": "^16.18.3", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.45.0", |     "@typescript-eslint/eslint-plugin": "^5.45.0", | ||||||
|     "@typescript-eslint/parser": "^5.45.0", |     "@typescript-eslint/parser": "^5.45.0", | ||||||
|     "@zeit/ncc": "^0.20.5", |     "@vercel/ncc": "^0.38.1", | ||||||
|     "eslint": "^8.28.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", | ||||||
|  |  | ||||||
|  | @ -31,7 +31,7 @@ outputs: | ||||||
|   cache-matched-key: |   cache-matched-key: | ||||||
|     description: 'Key of the cache that was restored, it could either be the primary key on cache-hit or a partial/complete match of one of the restore keys' |     description: 'Key of the cache that was restored, it could either be the primary key on cache-hit or a partial/complete match of one of the restore keys' | ||||||
| runs: | runs: | ||||||
|   using: 'node16' |   using: 'node20' | ||||||
|   main: '../dist/restore-only/index.js' |   main: '../dist/restore-only/index.js' | ||||||
| branding: | branding: | ||||||
|   icon: 'archive' |   icon: 'archive' | ||||||
|  |  | ||||||
|  | @ -16,7 +16,7 @@ inputs: | ||||||
|     default: 'false' |     default: 'false' | ||||||
|     required: false |     required: false | ||||||
| runs: | runs: | ||||||
|   using: 'node16' |   using: 'node20' | ||||||
|   main: '../dist/save-only/index.js' |   main: '../dist/save-only/index.js' | ||||||
| branding: | branding: | ||||||
|   icon: 'archive' |   icon: 'archive' | ||||||
|  |  | ||||||
							
								
								
									
										11
									
								
								src/save.ts
								
								
								
								
							
							
						
						
									
										11
									
								
								src/save.ts
								
								
								
								
							|  | @ -1,10 +1,3 @@ | ||||||
| import saveImpl from "./saveImpl"; | import { saveRun } from "./saveImpl"; | ||||||
| import { StateProvider } from "./stateProvider"; |  | ||||||
| 
 | 
 | ||||||
| async function run(): Promise<void> { | saveRun(true); | ||||||
|     await saveImpl(new StateProvider()); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| run(); |  | ||||||
| 
 |  | ||||||
| export default run; |  | ||||||
|  |  | ||||||
|  | @ -2,7 +2,11 @@ import * as cache from "@actions/cache"; | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
| 
 | 
 | ||||||
| import { Events, Inputs, State } from "./constants"; | import { Events, Inputs, State } from "./constants"; | ||||||
| import { IStateProvider } from "./stateProvider"; | import { | ||||||
|  |     IStateProvider, | ||||||
|  |     NullStateProvider, | ||||||
|  |     StateProvider | ||||||
|  | } from "./stateProvider"; | ||||||
| import * as utils from "./utils/actionUtils"; | import * as utils from "./utils/actionUtils"; | ||||||
| 
 | 
 | ||||||
| // Catch and log any unhandled exceptions.  These exceptions can leak out of the uploadChunk method in
 | // Catch and log any unhandled exceptions.  These exceptions can leak out of the uploadChunk method in
 | ||||||
|  | @ -10,7 +14,9 @@ import * as utils from "./utils/actionUtils"; | ||||||
| // throw an uncaught exception.  Instead of failing this action, just warn.
 | // throw an uncaught exception.  Instead of failing this action, just warn.
 | ||||||
| process.on("uncaughtException", e => utils.logWarning(e.message)); | process.on("uncaughtException", e => utils.logWarning(e.message)); | ||||||
| 
 | 
 | ||||||
| async function saveImpl(stateProvider: IStateProvider): Promise<number | void> { | export async function saveImpl( | ||||||
|  |     stateProvider: IStateProvider | ||||||
|  | ): Promise<number | void> { | ||||||
|     let cacheId = -1; |     let cacheId = -1; | ||||||
|     try { |     try { | ||||||
|         if (!utils.isCacheFeatureAvailable()) { |         if (!utils.isCacheFeatureAvailable()) { | ||||||
|  | @ -72,4 +78,47 @@ async function saveImpl(stateProvider: IStateProvider): Promise<number | void> { | ||||||
|     return cacheId; |     return cacheId; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export default saveImpl; | export async function saveOnlyRun( | ||||||
|  |     earlyExit?: boolean | undefined | ||||||
|  | ): Promise<void> { | ||||||
|  |     try { | ||||||
|  |         const cacheId = await saveImpl(new NullStateProvider()); | ||||||
|  |         if (cacheId === -1) { | ||||||
|  |             core.warning(`Cache save failed.`); | ||||||
|  |         } | ||||||
|  |     } catch (err) { | ||||||
|  |         console.error(err); | ||||||
|  |         if (earlyExit) { | ||||||
|  |             process.exit(1); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // node will stay alive if any promises are not resolved,
 | ||||||
|  |     // which is a possibility if HTTP requests are dangling
 | ||||||
|  |     // due to retries or timeouts. We know that if we got here
 | ||||||
|  |     // that all promises that we care about have successfully
 | ||||||
|  |     // resolved, so simply exit with success.
 | ||||||
|  |     if (earlyExit) { | ||||||
|  |         process.exit(0); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export async function saveRun(earlyExit?: boolean | undefined): Promise<void> { | ||||||
|  |     try { | ||||||
|  |         await saveImpl(new StateProvider()); | ||||||
|  |     } catch (err) { | ||||||
|  |         console.error(err); | ||||||
|  |         if (earlyExit) { | ||||||
|  |             process.exit(1); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // node will stay alive if any promises are not resolved,
 | ||||||
|  |     // which is a possibility if HTTP requests are dangling
 | ||||||
|  |     // due to retries or timeouts. We know that if we got here
 | ||||||
|  |     // that all promises that we care about have successfully
 | ||||||
|  |     // resolved, so simply exit with success.
 | ||||||
|  |     if (earlyExit) { | ||||||
|  |         process.exit(0); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -1,15 +1,3 @@ | ||||||
| import * as core from "@actions/core"; | import { saveOnlyRun } from "./saveImpl"; | ||||||
| 
 | 
 | ||||||
| import saveImpl from "./saveImpl"; | saveOnlyRun(true); | ||||||
| import { NullStateProvider } from "./stateProvider"; |  | ||||||
| 
 |  | ||||||
| async function run(): Promise<void> { |  | ||||||
|     const cacheId = await saveImpl(new NullStateProvider()); |  | ||||||
|     if (cacheId === -1) { |  | ||||||
|         core.warning(`Cache save failed.`); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| run(); |  | ||||||
| 
 |  | ||||||
| export default run; |  | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Yang Cao
						Yang Cao