mirror of
				https://github.com/actions/cache.git
				synced 2025-10-26 13:15:10 +07:00 
			
		
		
		
	Compare commits
	
		
			27 Commits
		
	
	
		
			v3.0.0
			...
			vsvipul/al
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| bdb21a7177 | |||
| d55d005ab0 | |||
| b44d6c5cbf | |||
| 60742c2acf | |||
| 12086c7bbf | |||
| 626c44ce85 | |||
| f2d5621efc | |||
| cab6d27614 | |||
| 69811fd677 | |||
| 887b9060fe | |||
| c6762fdd6a | |||
| 95c3ae75f4 | |||
| 797382fe42 | |||
| 36dbd93a7c | |||
| 45f362d0ca | |||
| ca0688b4ab | |||
| ef8498dcba | |||
| 8f1e2e0286 | |||
| 48af2dc4a9 | |||
| f63a711791 | |||
| 770a27cf65 | |||
| c2131abcd8 | |||
| 575160481d | |||
| 136d96b4ae | |||
| 7d4f40b464 | |||
| 2d8d0d1c9b | |||
| 7799d864d9 | 
							
								
								
									
										17
									
								
								.github/auto_assign.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								.github/auto_assign.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | ||||
| # Set to true to add reviewers to pull requests | ||||
| addReviewers: true | ||||
|  | ||||
| # Set to true to add assignees to pull requests | ||||
| addAssignees: false | ||||
|  | ||||
| # A list of reviewers to be added to pull requests (GitHub user name) | ||||
| reviewers: | ||||
|   - phantsure | ||||
|   - aparna-ravindra | ||||
|   - tiwarishub | ||||
|   - vsvipul | ||||
|   - bishal-pdmsft | ||||
|  | ||||
| # A number of reviewers added to the pull request | ||||
| # Set 0 to add all the reviewers (default: 0) | ||||
| numberOfReviewers: 1 | ||||
							
								
								
									
										15
									
								
								.github/workflows/auto-assign-issues.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								.github/workflows/auto-assign-issues.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,15 @@ | ||||
| name: Issue assignment | ||||
|  | ||||
| on: | ||||
|     issues: | ||||
|         types: [opened] | ||||
|  | ||||
| jobs: | ||||
|     auto-assign: | ||||
|         runs-on: ubuntu-latest | ||||
|         steps: | ||||
|             - name: 'Auto-assign issue' | ||||
|               uses: pozil/auto-assign-issue@v1.4.0 | ||||
|               with: | ||||
|                   assignees: phantsure,tiwarishub,aparna-ravindra,vsvipul,bishal-pdmsft | ||||
|                   numOfAssignee: 1 | ||||
							
								
								
									
										10
									
								
								.github/workflows/auto-assign.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/auto-assign.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | ||||
| name: 'Auto Assign' | ||||
| on: | ||||
|   pull_request: | ||||
|     types: [opened, ready_for_review] | ||||
|  | ||||
| jobs: | ||||
|   add-reviews: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: kentaro-m/auto-assign-action@v1.2.1 | ||||
							
								
								
									
										13
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								.github/workflows/check-dist.yml
									
									
									
									
										vendored
									
									
								
							| @ -22,16 +22,13 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|  | ||||
|       - name: Set Node.js 12.x | ||||
|         uses: actions/setup-node@v1 | ||||
|       - uses: actions/checkout@v3 | ||||
|       - name: Setup Node.js 16.x | ||||
|         uses: actions/setup-node@v3 | ||||
|         with: | ||||
|           node-version: 12.x | ||||
|  | ||||
|           node-version: 16.x | ||||
|       - name: Install dependencies | ||||
|         run: npm ci | ||||
|  | ||||
|       - name: Rebuild the dist/ directory | ||||
|         run: npm run build | ||||
|  | ||||
| @ -45,7 +42,7 @@ jobs: | ||||
|         id: diff | ||||
|  | ||||
|       # If index.js was different than expected, upload the expected version as an artifact | ||||
|       - uses: actions/upload-artifact@v2 | ||||
|       - uses: actions/upload-artifact@v3 | ||||
|         if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||
|         with: | ||||
|           name: dist | ||||
|  | ||||
							
								
								
									
										4
									
								
								.github/workflows/close-inactive-issues.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/close-inactive-issues.yml
									
									
									
									
										vendored
									
									
								
							| @ -12,10 +12,10 @@ jobs: | ||||
|     steps: | ||||
|       - uses: actions/stale@v3 | ||||
|         with: | ||||
|           days-before-issue-stale: 365 | ||||
|           days-before-issue-stale: 200 | ||||
|           days-before-issue-close: 5 | ||||
|           stale-issue-label: "stale" | ||||
|           stale-issue-message: "This issue is stale because it has been open for 365 days with no activity. Leave a comment to avoid closing this issue in 5 days." | ||||
|           stale-issue-message: "This issue is stale because it has been open for 200 days with no activity. Leave a comment to avoid closing this issue in 5 days." | ||||
|           close-issue-message: "This issue was closed because it has been inactive for 5 days since being marked as stale." | ||||
|           days-before-pr-stale: -1 | ||||
|           days-before-pr-close: -1 | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @ -14,7 +14,7 @@ jobs: | ||||
|  | ||||
|     steps: | ||||
|     - name: Checkout repository | ||||
|       uses: actions/checkout@v2 | ||||
|       uses: actions/checkout@v3 | ||||
|       with: | ||||
|         # We must fetch at least the immediate parents so that if this is | ||||
|         # a pull request then we can checkout the head. | ||||
|  | ||||
							
								
								
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/licensed.yml
									
									
									
									
										vendored
									
									
								
							| @ -13,7 +13,7 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     name: Check licenses | ||||
|     steps: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/checkout@v3 | ||||
|       - run: npm ci | ||||
|       - name: Install licensed | ||||
|         run: | | ||||
|  | ||||
							
								
								
									
										18
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @ -24,17 +24,17 @@ jobs: | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|     - name: Setup Node.js | ||||
|       uses: actions/setup-node@v1 | ||||
|       uses: actions/checkout@v3 | ||||
|     - name: Setup Node.js 16.x | ||||
|       uses: actions/setup-node@v3 | ||||
|       with: | ||||
|         node-version: '12.x' | ||||
|         node-version: 16.x | ||||
|     - name: Determine npm cache directory | ||||
|       id: npm-cache | ||||
|       run: | | ||||
|         echo "::set-output name=dir::$(npm config get cache)" | ||||
|     - name: Restore npm cache | ||||
|       uses: actions/cache@v2 | ||||
|       uses: actions/cache@v3 | ||||
|       with: | ||||
|         path: ${{ steps.npm-cache.outputs.dir }} | ||||
|         key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | ||||
| @ -57,7 +57,7 @@ jobs: | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|       uses: actions/checkout@v3 | ||||
|     - name: Generate files in working directory | ||||
|       shell: bash | ||||
|       run: __tests__/create-cache-files.sh ${{ runner.os }} test-cache | ||||
| @ -80,7 +80,7 @@ jobs: | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|       uses: actions/checkout@v3 | ||||
|     - name: Restore cache | ||||
|       uses: ./ | ||||
|       with: | ||||
| @ -110,7 +110,7 @@ jobs: | ||||
|       https_proxy: http://squid-proxy:3128 | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|       uses: actions/checkout@v3 | ||||
|     - name: Generate files | ||||
|       run: __tests__/create-cache-files.sh proxy test-cache | ||||
|     - name: Save cache | ||||
| @ -133,7 +133,7 @@ jobs: | ||||
|       https_proxy: http://squid-proxy:3128 | ||||
|     steps: | ||||
|     - name: Checkout | ||||
|       uses: actions/checkout@v2 | ||||
|       uses: actions/checkout@v3 | ||||
|     - name: Restore cache | ||||
|       uses: ./ | ||||
|       with: | ||||
|  | ||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| name: "@actions/cache" | ||||
| version: 1.0.10 | ||||
| version: 2.0.2 | ||||
| type: npm | ||||
| summary:  | ||||
| homepage:  | ||||
|  | ||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| name: "@actions/core" | ||||
| version: 1.6.0 | ||||
| version: 1.7.0 | ||||
| type: npm | ||||
| summary: Actions core lib | ||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/core | ||||
|  | ||||
							
								
								
									
										6
									
								
								.licenses/npm/@opentelemetry/api.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										6
									
								
								.licenses/npm/@opentelemetry/api.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,9 +1,9 @@ | ||||
| --- | ||||
| name: "@opentelemetry/api" | ||||
| version: 1.1.0 | ||||
| version: 1.0.4 | ||||
| type: npm | ||||
| summary:  | ||||
| homepage:  | ||||
| summary: Public API for OpenTelemetry | ||||
| homepage: https://github.com/open-telemetry/opentelemetry-js-api#readme | ||||
| license: apache-2.0 | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|  | ||||
							
								
								
									
										6
									
								
								.licenses/npm/@types/node.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										6
									
								
								.licenses/npm/@types/node.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,9 +1,9 @@ | ||||
| --- | ||||
| name: "@types/node" | ||||
| version: 16.11.26 | ||||
| version: 16.11.33 | ||||
| type: npm | ||||
| summary:  | ||||
| homepage:  | ||||
| summary: TypeScript definitions for Node.js | ||||
| homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node | ||||
| license: mit | ||||
| licenses: | ||||
| - sources: LICENSE | ||||
|  | ||||
							
								
								
									
										26
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								README.md
									
									
									
									
									
								
							| @ -9,12 +9,18 @@ This action allows caching dependencies and build outputs to improve workflow ex | ||||
| See ["Caching dependencies to speed up workflows"](https://help.github.com/github/automating-your-workflow-with-github-actions/caching-dependencies-to-speed-up-workflows). | ||||
|  | ||||
| ## What's New | ||||
| ### v3 | ||||
| * Added support for caching from GHES 3.5. | ||||
| * Fixed download issue for files > 2GB during restore. | ||||
| * Updated the minimum runner version support from node 12 -> node 16. | ||||
|  | ||||
| ### v2 | ||||
| * Increased the cache size limit to 10 GB. | ||||
| * Added support for multiple paths, [glob patterns](https://github.com/actions/toolkit/tree/main/packages/glob), and single file caches. | ||||
|  | ||||
| ```yaml | ||||
| - name: Cache multiple paths | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/cache | ||||
| @ -65,11 +71,11 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|     - uses: actions/checkout@v3 | ||||
|  | ||||
|     - name: Cache Primes | ||||
|       id: cache-primes | ||||
|       uses: actions/cache@v2 | ||||
|       uses: actions/cache@v3 | ||||
|       with: | ||||
|         path: prime-numbers | ||||
|         key: ${{ runner.os }}-primes | ||||
| @ -119,7 +125,7 @@ A cache key can include any of the contexts, functions, literals, and operators | ||||
| For example, using the [`hashFiles`](https://help.github.com/en/actions/reference/context-and-expression-syntax-for-github-actions#hashfiles) function allows you to create a new cache when dependencies change. | ||||
|  | ||||
| ```yaml | ||||
|   - uses: actions/cache@v2 | ||||
|   - uses: actions/cache@v3 | ||||
|     with: | ||||
|       path: | | ||||
|         path/to/dependencies | ||||
| @ -137,7 +143,7 @@ Additionally, you can use arbitrary command output in a cache key, such as a dat | ||||
|       echo "::set-output name=date::$(/bin/date -u "+%Y%m%d")" | ||||
|     shell: bash | ||||
|  | ||||
|   - uses: actions/cache@v2 | ||||
|   - uses: actions/cache@v3 | ||||
|     with: | ||||
|       path: path/to/dependencies | ||||
|       key: ${{ runner.os }}-${{ steps.get-date.outputs.date }}-${{ hashFiles('**/lockfiles') }} | ||||
| @ -156,9 +162,9 @@ Using the `cache-hit` output, subsequent steps (such as install or build) can be | ||||
| Example: | ||||
| ```yaml | ||||
| steps: | ||||
|   - uses: actions/checkout@v2 | ||||
|   - uses: actions/checkout@v3 | ||||
|  | ||||
|   - uses: actions/cache@v2 | ||||
|   - uses: actions/cache@v3 | ||||
|     id: cache | ||||
|     with: | ||||
|       path: path/to/dependencies | ||||
| @ -171,12 +177,6 @@ steps: | ||||
|  | ||||
| > Note: The `id` defined in `actions/cache` must match the `id` in the `if` statement (i.e. `steps.[ID].outputs.cache-hit`) | ||||
|  | ||||
| ## Known limitation | ||||
|  | ||||
| - `action/cache` is currently not supported on GitHub Enterprise Server. <https://github.com/github/roadmap/issues/273> is tracking this. | ||||
|  | ||||
| Since GitHub Enterprise Server uses self-hosted runners, dependencies are typically cached on the runner by whatever dependency management tool is being used (npm, maven, etc.).  This eliminates the need for explicit caching in some scenarios. | ||||
|  | ||||
| ## Contributing | ||||
| We would love for you to contribute to `actions/cache`, pull requests are welcome! Please see the [CONTRIBUTING.md](CONTRIBUTING.md) for more information. | ||||
|  | ||||
|  | ||||
							
								
								
									
										8
									
								
								RELEASES.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								RELEASES.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | ||||
| # Releases | ||||
|  | ||||
| ### 3.0.0 | ||||
| - Updated minimum runner version support from node 12 -> node 16 | ||||
|  | ||||
| ### 3.0.1 | ||||
| - Added support for caching from GHES 3.5. | ||||
| - Fixed download issue for files > 2GB during restore. | ||||
| @ -1,3 +1,4 @@ | ||||
| import * as cache from "@actions/cache"; | ||||
| import * as core from "@actions/core"; | ||||
|  | ||||
| import { Events, Outputs, RefKey, State } from "../src/constants"; | ||||
| @ -5,6 +6,7 @@ import * as actionUtils from "../src/utils/actionUtils"; | ||||
| import * as testUtils from "../src/utils/testUtils"; | ||||
|  | ||||
| jest.mock("@actions/core"); | ||||
| jest.mock("@actions/cache"); | ||||
|  | ||||
| beforeAll(() => { | ||||
|     jest.spyOn(core, "getInput").mockImplementation((name, options) => { | ||||
| @ -232,3 +234,41 @@ test("getInputAsInt throws if required and value missing", () => { | ||||
|         actionUtils.getInputAsInt("undefined", { required: true }) | ||||
|     ).toThrowError(); | ||||
| }); | ||||
|  | ||||
| test("isCacheFeatureAvailable for ac enabled", () => { | ||||
|     jest.spyOn(cache, "isFeatureAvailable").mockImplementation(() => true); | ||||
|  | ||||
|     expect(actionUtils.isCacheFeatureAvailable()).toBe(true); | ||||
| }); | ||||
|  | ||||
| test("isCacheFeatureAvailable for ac disabled on GHES", () => { | ||||
|     jest.spyOn(cache, "isFeatureAvailable").mockImplementation(() => false); | ||||
|  | ||||
|     const message = | ||||
|         "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."; | ||||
|     const infoMock = jest.spyOn(core, "info"); | ||||
|  | ||||
|     try { | ||||
|         process.env["GITHUB_SERVER_URL"] = "http://example.com"; | ||||
|         expect(actionUtils.isCacheFeatureAvailable()).toBe(false); | ||||
|         expect(infoMock).toHaveBeenCalledWith(`[warning]${message}`); | ||||
|     } finally { | ||||
|         delete process.env["GITHUB_SERVER_URL"]; | ||||
|     } | ||||
| }); | ||||
|  | ||||
| test("isCacheFeatureAvailable for ac disabled on dotcom", () => { | ||||
|     jest.spyOn(cache, "isFeatureAvailable").mockImplementation(() => false); | ||||
|  | ||||
|     const message = | ||||
|         "An internal error has occurred in cache backend. Please check https://www.githubstatus.com/ for any ongoing issue in actions."; | ||||
|     const infoMock = jest.spyOn(core, "info"); | ||||
|  | ||||
|     try { | ||||
|         process.env["GITHUB_SERVER_URL"] = "http://github.com"; | ||||
|         expect(actionUtils.isCacheFeatureAvailable()).toBe(false); | ||||
|         expect(infoMock).toHaveBeenCalledWith(`[warning]${message}`); | ||||
|     } finally { | ||||
|         delete process.env["GITHUB_SERVER_URL"]; | ||||
|     } | ||||
| }); | ||||
|  | ||||
| @ -34,6 +34,9 @@ beforeEach(() => { | ||||
|     process.env[RefKey] = "refs/heads/feature-branch"; | ||||
|  | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); | ||||
|     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||
|         () => true | ||||
|     ); | ||||
| }); | ||||
|  | ||||
| afterEach(() => { | ||||
| @ -55,10 +58,12 @@ test("restore with invalid event outputs warning", async () => { | ||||
|     expect(failedMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|  | ||||
| test("restore on GHES should no-op", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | ||||
| test("restore without AC available should no-op", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); | ||||
|     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||
|         () => false | ||||
|     ); | ||||
|  | ||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | ||||
|     const restoreCacheMock = jest.spyOn(cache, "restoreCache"); | ||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); | ||||
|  | ||||
| @ -67,9 +72,54 @@ test("restore on GHES should no-op", async () => { | ||||
|     expect(restoreCacheMock).toHaveBeenCalledTimes(0); | ||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(false); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         "Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details" | ||||
| }); | ||||
|  | ||||
| test("restore on GHES without AC available should no-op", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | ||||
|     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||
|         () => false | ||||
|     ); | ||||
|  | ||||
|     const restoreCacheMock = jest.spyOn(cache, "restoreCache"); | ||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); | ||||
|  | ||||
|     await run(); | ||||
|  | ||||
|     expect(restoreCacheMock).toHaveBeenCalledTimes(0); | ||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(false); | ||||
| }); | ||||
|  | ||||
| test("restore on GHES with AC available ", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | ||||
|     const path = "node_modules"; | ||||
|     const key = "node-test"; | ||||
|     testUtils.setInputs({ | ||||
|         path: path, | ||||
|         key | ||||
|     }); | ||||
|  | ||||
|     const infoMock = jest.spyOn(core, "info"); | ||||
|     const failedMock = jest.spyOn(core, "setFailed"); | ||||
|     const stateMock = jest.spyOn(core, "saveState"); | ||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); | ||||
|     const restoreCacheMock = jest | ||||
|         .spyOn(cache, "restoreCache") | ||||
|         .mockImplementationOnce(() => { | ||||
|             return Promise.resolve(key); | ||||
|         }); | ||||
|  | ||||
|     await run(); | ||||
|  | ||||
|     expect(restoreCacheMock).toHaveBeenCalledTimes(1); | ||||
|     expect(restoreCacheMock).toHaveBeenCalledWith([path], key, []); | ||||
|  | ||||
|     expect(stateMock).toHaveBeenCalledWith("CACHE_KEY", key); | ||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(true); | ||||
|  | ||||
|     expect(infoMock).toHaveBeenCalledWith(`Cache restored from key: ${key}`); | ||||
|     expect(failedMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|  | ||||
| test("restore with no path should fail", async () => { | ||||
|  | ||||
| @ -54,6 +54,9 @@ beforeEach(() => { | ||||
|     process.env[RefKey] = "refs/heads/feature-branch"; | ||||
|  | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); | ||||
|     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||
|         () => true | ||||
|     ); | ||||
| }); | ||||
|  | ||||
| afterEach(() => { | ||||
| @ -101,18 +104,67 @@ test("save with no primary key in state outputs warning", async () => { | ||||
|     expect(failedMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|  | ||||
| test("save on GHES should no-op", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | ||||
| test("save without AC available should no-op", async () => { | ||||
|     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||
|         () => false | ||||
|     ); | ||||
|  | ||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); | ||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||
|  | ||||
|     await run(); | ||||
|  | ||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||
|     expect(logWarningMock).toHaveBeenCalledWith( | ||||
|         "Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details" | ||||
| }); | ||||
|  | ||||
| test("save on ghes without AC available should no-op", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | ||||
|     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||
|         () => false | ||||
|     ); | ||||
|  | ||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||
|  | ||||
|     await run(); | ||||
|  | ||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|  | ||||
| test("save on GHES with AC available", async () => { | ||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); | ||||
|     const failedMock = jest.spyOn(core, "setFailed"); | ||||
|  | ||||
|     const primaryKey = "Linux-node-bb828da54c148048dd17899ba9fda624811cfb43"; | ||||
|     const savedCacheKey = "Linux-node-"; | ||||
|  | ||||
|     jest.spyOn(core, "getState") | ||||
|         // Cache Entry State | ||||
|         .mockImplementationOnce(() => { | ||||
|             return savedCacheKey; | ||||
|         }) | ||||
|         // Cache Key State | ||||
|         .mockImplementationOnce(() => { | ||||
|             return primaryKey; | ||||
|         }); | ||||
|  | ||||
|     const inputPath = "node_modules"; | ||||
|     testUtils.setInput(Inputs.Path, inputPath); | ||||
|     testUtils.setInput(Inputs.UploadChunkSize, "4000000"); | ||||
|  | ||||
|     const cacheId = 4; | ||||
|     const saveCacheMock = jest | ||||
|         .spyOn(cache, "saveCache") | ||||
|         .mockImplementationOnce(() => { | ||||
|             return Promise.resolve(cacheId); | ||||
|         }); | ||||
|  | ||||
|     await run(); | ||||
|  | ||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(1); | ||||
|     expect(saveCacheMock).toHaveBeenCalledWith([inputPath], primaryKey, { | ||||
|         uploadChunkSize: 4000000 | ||||
|     }); | ||||
|  | ||||
|     expect(failedMock).toHaveBeenCalledTimes(0); | ||||
| }); | ||||
|  | ||||
| test("save with exact match returns early", async () => { | ||||
|  | ||||
							
								
								
									
										658
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										658
									
								
								dist/restore/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1199,6 +1199,11 @@ function assertDefined(name, value) { | ||||
|     return value; | ||||
| } | ||||
| exports.assertDefined = assertDefined; | ||||
| function isGhes() { | ||||
|     const ghUrl = new URL(process.env['GITHUB_SERVER_URL'] || 'https://github.com'); | ||||
|     return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; | ||||
| } | ||||
| exports.isGhes = isGhes; | ||||
| //# sourceMappingURL=cacheUtils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -1405,36 +1410,7 @@ exports.default = _default; | ||||
| /* 39 */, | ||||
| /* 40 */, | ||||
| /* 41 */, | ||||
| /* 42 */ | ||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.createTraceState = void 0; | ||||
| var tracestate_impl_1 = __webpack_require__(756); | ||||
| function createTraceState(rawTraceState) { | ||||
|     return new tracestate_impl_1.TraceStateImpl(rawTraceState); | ||||
| } | ||||
| exports.createTraceState = createTraceState; | ||||
| //# sourceMappingURL=utils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 42 */, | ||||
| /* 43 */, | ||||
| /* 44 */, | ||||
| /* 45 */, | ||||
| @ -3221,10 +3197,7 @@ const options_1 = __webpack_require__(538); | ||||
| const requestUtils_1 = __webpack_require__(899); | ||||
| const versionSalt = '1.0'; | ||||
| function getCacheApiUrl(resource) { | ||||
|     // Ideally we just use ACTIONS_CACHE_URL
 | ||||
|     const baseUrl = (process.env['ACTIONS_CACHE_URL'] || | ||||
|         process.env['ACTIONS_RUNTIME_URL'] || | ||||
|         '').replace('pipelines', 'artifactcache'); | ||||
|     const baseUrl = process.env['ACTIONS_CACHE_URL'] || ''; | ||||
|     if (!baseUrl) { | ||||
|         throw new Error('Cache Service Url not found, unable to restore cache.'); | ||||
|     } | ||||
| @ -3302,18 +3275,18 @@ function downloadCache(archiveLocation, archivePath, options) { | ||||
| exports.downloadCache = downloadCache; | ||||
| // Reserve Cache
 | ||||
| function reserveCache(key, paths, options) { | ||||
|     var _a, _b; | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         const httpClient = createHttpClient(); | ||||
|         const version = getCacheVersion(paths, options === null || options === void 0 ? void 0 : options.compressionMethod); | ||||
|         const reserveCacheRequest = { | ||||
|             key, | ||||
|             version | ||||
|             version, | ||||
|             cacheSize: options === null || options === void 0 ? void 0 : options.cacheSize | ||||
|         }; | ||||
|         const response = yield requestUtils_1.retryTypedResponse('reserveCache', () => __awaiter(this, void 0, void 0, function* () { | ||||
|             return httpClient.postJson(getCacheApiUrl('caches'), reserveCacheRequest); | ||||
|         })); | ||||
|         return (_b = (_a = response === null || response === void 0 ? void 0 : response.result) === null || _a === void 0 ? void 0 : _a.cacheId) !== null && _b !== void 0 ? _b : -1; | ||||
|         return response; | ||||
|     }); | ||||
| } | ||||
| exports.reserveCache = reserveCache; | ||||
| @ -4470,7 +4443,7 @@ var NoopTracer_1 = __webpack_require__(151); | ||||
| var NoopTracerProvider = /** @class */ (function () { | ||||
|     function NoopTracerProvider() { | ||||
|     } | ||||
|     NoopTracerProvider.prototype.getTracer = function (_name, _version, _options) { | ||||
|     NoopTracerProvider.prototype.getTracer = function (_name, _version) { | ||||
|         return new NoopTracer_1.NoopTracer(); | ||||
|     }; | ||||
|     return NoopTracerProvider; | ||||
| @ -5519,7 +5492,8 @@ function downloadCacheStorageSDK(archiveLocation, archivePath, options) { | ||||
|             //
 | ||||
|             // If the file exceeds the buffer maximum length (~1 GB on 32-bit systems and ~2 GB
 | ||||
|             // on 64-bit systems), split the download into multiple segments
 | ||||
|             const maxSegmentSize = buffer.constants.MAX_LENGTH; | ||||
|             // ~2 GB = 2147483647, beyond this, we start getting out of range error. So, capping it accordingly.
 | ||||
|             const maxSegmentSize = Math.min(2147483647, buffer.constants.MAX_LENGTH); | ||||
|             const downloadProgress = new DownloadProgress(contentLength); | ||||
|             const fd = fs.openSync(archivePath, 'w'); | ||||
|             try { | ||||
| @ -36293,9 +36267,9 @@ var ProxyTracerProvider = /** @class */ (function () { | ||||
|     /** | ||||
|      * Get a {@link ProxyTracer} | ||||
|      */ | ||||
|     ProxyTracerProvider.prototype.getTracer = function (name, version, options) { | ||||
|     ProxyTracerProvider.prototype.getTracer = function (name, version) { | ||||
|         var _a; | ||||
|         return ((_a = this.getDelegateTracer(name, version, options)) !== null && _a !== void 0 ? _a : new ProxyTracer_1.ProxyTracer(this, name, version, options)); | ||||
|         return ((_a = this.getDelegateTracer(name, version)) !== null && _a !== void 0 ? _a : new ProxyTracer_1.ProxyTracer(this, name, version)); | ||||
|     }; | ||||
|     ProxyTracerProvider.prototype.getDelegate = function () { | ||||
|         var _a; | ||||
| @ -36307,9 +36281,9 @@ var ProxyTracerProvider = /** @class */ (function () { | ||||
|     ProxyTracerProvider.prototype.setDelegate = function (delegate) { | ||||
|         this._delegate = delegate; | ||||
|     }; | ||||
|     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version, options) { | ||||
|     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version) { | ||||
|         var _a; | ||||
|         return (_a = this._delegate) === null || _a === void 0 ? void 0 : _a.getTracer(name, version, options); | ||||
|         return (_a = this._delegate) === null || _a === void 0 ? void 0 : _a.getTracer(name, version); | ||||
|     }; | ||||
|     return ProxyTracerProvider; | ||||
| }()); | ||||
| @ -36348,11 +36322,10 @@ var NOOP_TRACER = new NoopTracer_1.NoopTracer(); | ||||
|  * Proxy tracer provided by the proxy tracer provider | ||||
|  */ | ||||
| var ProxyTracer = /** @class */ (function () { | ||||
|     function ProxyTracer(_provider, name, version, options) { | ||||
|     function ProxyTracer(_provider, name, version) { | ||||
|         this._provider = _provider; | ||||
|         this.name = name; | ||||
|         this.version = version; | ||||
|         this.options = options; | ||||
|     } | ||||
|     ProxyTracer.prototype.startSpan = function (name, options, context) { | ||||
|         return this._getTracer().startSpan(name, options, context); | ||||
| @ -36369,7 +36342,7 @@ var ProxyTracer = /** @class */ (function () { | ||||
|         if (this._delegate) { | ||||
|             return this._delegate; | ||||
|         } | ||||
|         var tracer = this._provider.getDelegateTracer(this.name, this.version, this.options); | ||||
|         var tracer = this._provider.getDelegateTracer(this.name, this.version); | ||||
|         if (!tracer) { | ||||
|             return NOOP_TRACER; | ||||
|         } | ||||
| @ -37369,13 +37342,12 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) { | ||||
|     for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.diag = exports.propagation = exports.trace = exports.context = exports.INVALID_SPAN_CONTEXT = exports.INVALID_TRACEID = exports.INVALID_SPANID = exports.isValidSpanId = exports.isValidTraceId = exports.isSpanContextValid = exports.createTraceState = exports.baggageEntryMetadataFromString = void 0; | ||||
| exports.diag = exports.propagation = exports.trace = exports.context = exports.INVALID_SPAN_CONTEXT = exports.INVALID_TRACEID = exports.INVALID_SPANID = exports.isValidSpanId = exports.isValidTraceId = exports.isSpanContextValid = exports.baggageEntryMetadataFromString = void 0; | ||||
| __exportStar(__webpack_require__(880), exports); | ||||
| var utils_1 = __webpack_require__(112); | ||||
| Object.defineProperty(exports, "baggageEntryMetadataFromString", { enumerable: true, get: function () { return utils_1.baggageEntryMetadataFromString; } }); | ||||
| __exportStar(__webpack_require__(452), exports); | ||||
| __exportStar(__webpack_require__(158), exports); | ||||
| __exportStar(__webpack_require__(907), exports); | ||||
| __exportStar(__webpack_require__(893), exports); | ||||
| __exportStar(__webpack_require__(881), exports); | ||||
| __exportStar(__webpack_require__(906), exports); | ||||
| @ -37391,11 +37363,8 @@ __exportStar(__webpack_require__(220), exports); | ||||
| __exportStar(__webpack_require__(932), exports); | ||||
| __exportStar(__webpack_require__(975), exports); | ||||
| __exportStar(__webpack_require__(207), exports); | ||||
| var utils_2 = __webpack_require__(42); | ||||
| Object.defineProperty(exports, "createTraceState", { enumerable: true, get: function () { return utils_2.createTraceState; } }); | ||||
| __exportStar(__webpack_require__(694), exports); | ||||
| __exportStar(__webpack_require__(695), exports); | ||||
| __exportStar(__webpack_require__(743), exports); | ||||
| var spancontext_utils_1 = __webpack_require__(629); | ||||
| Object.defineProperty(exports, "isSpanContextValid", { enumerable: true, get: function () { return spancontext_utils_1.isSpanContextValid; } }); | ||||
| Object.defineProperty(exports, "isValidTraceId", { enumerable: true, get: function () { return spancontext_utils_1.isValidTraceId; } }); | ||||
| @ -37441,7 +37410,11 @@ exports.default = { | ||||
| 
 | ||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||
|     if (k2 === undefined) k2 = k; | ||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[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]; | ||||
| @ -37454,12 +37427,13 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | ||||
| 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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||
|     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.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.getCacheState = exports.setOutputAndState = exports.setCacheHitOutput = exports.setCacheState = exports.isExactKeyMatch = exports.isGhes = void 0; | ||||
| const cache = __importStar(__webpack_require__(692)); | ||||
| const core = __importStar(__webpack_require__(470)); | ||||
| const constants_1 = __webpack_require__(196); | ||||
| function isGhes() { | ||||
| @ -37524,6 +37498,19 @@ function getInputAsInt(name, options) { | ||||
|     return value; | ||||
| } | ||||
| exports.getInputAsInt = getInputAsInt; | ||||
| function isCacheFeatureAvailable() { | ||||
|     if (!cache.isFeatureAvailable()) { | ||||
|         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."); | ||||
|         } | ||||
|         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 true; | ||||
| } | ||||
| exports.isCacheFeatureAvailable = isCacheFeatureAvailable; | ||||
| 
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -39888,6 +39875,11 @@ function getIDToken(aud) { | ||||
|     }); | ||||
| } | ||||
| exports.getIDToken = getIDToken; | ||||
| /** | ||||
|  * Markdown summary exports | ||||
|  */ | ||||
| var markdown_summary_1 = __webpack_require__(548); | ||||
| Object.defineProperty(exports, "markdownSummary", { enumerable: true, get: function () { return markdown_summary_1.markdownSummary; } }); | ||||
| //# sourceMappingURL=core.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -41494,7 +41486,291 @@ CombinedStream.prototype._emitError = function(err) { | ||||
| 
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 548 */, | ||||
| /* 548 */ | ||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| 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 }); | ||||
| exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0; | ||||
| const os_1 = __webpack_require__(87); | ||||
| const fs_1 = __webpack_require__(747); | ||||
| const { access, appendFile, writeFile } = fs_1.promises; | ||||
| exports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY'; | ||||
| exports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-markdown-summary'; | ||||
| class MarkdownSummary { | ||||
|     constructor() { | ||||
|         this._buffer = ''; | ||||
|     } | ||||
|     /** | ||||
|      * Finds the summary file path from the environment, rejects if env var is not found or file does not exist | ||||
|      * Also checks r/w permissions. | ||||
|      * | ||||
|      * @returns step summary file path | ||||
|      */ | ||||
|     filePath() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             if (this._filePath) { | ||||
|                 return this._filePath; | ||||
|             } | ||||
|             const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR]; | ||||
|             if (!pathFromEnv) { | ||||
|                 throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports markdown summaries.`); | ||||
|             } | ||||
|             try { | ||||
|                 yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK); | ||||
|             } | ||||
|             catch (_a) { | ||||
|                 throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`); | ||||
|             } | ||||
|             this._filePath = pathFromEnv; | ||||
|             return this._filePath; | ||||
|         }); | ||||
|     } | ||||
|     /** | ||||
|      * Wraps content in an HTML tag, adding any HTML attributes | ||||
|      * | ||||
|      * @param {string} tag HTML tag to wrap | ||||
|      * @param {string | null} content content within the tag | ||||
|      * @param {[attribute: string]: string} attrs key-value list of HTML attributes to add | ||||
|      * | ||||
|      * @returns {string} content wrapped in HTML element | ||||
|      */ | ||||
|     wrap(tag, content, attrs = {}) { | ||||
|         const htmlAttrs = Object.entries(attrs) | ||||
|             .map(([key, value]) => ` ${key}="${value}"`) | ||||
|             .join(''); | ||||
|         if (!content) { | ||||
|             return `<${tag}${htmlAttrs}>`; | ||||
|         } | ||||
|         return `<${tag}${htmlAttrs}>${content}</${tag}>`; | ||||
|     } | ||||
|     /** | ||||
|      * Writes text in the buffer to the summary buffer file and empties buffer. Will append by default. | ||||
|      * | ||||
|      * @param {SummaryWriteOptions} [options] (optional) options for write operation | ||||
|      * | ||||
|      * @returns {Promise<MarkdownSummary>} markdown summary instance | ||||
|      */ | ||||
|     write(options) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite); | ||||
|             const filePath = yield this.filePath(); | ||||
|             const writeFunc = overwrite ? writeFile : appendFile; | ||||
|             yield writeFunc(filePath, this._buffer, { encoding: 'utf8' }); | ||||
|             return this.emptyBuffer(); | ||||
|         }); | ||||
|     } | ||||
|     /** | ||||
|      * Clears the summary buffer and wipes the summary file | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     clear() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             return this.emptyBuffer().write({ overwrite: true }); | ||||
|         }); | ||||
|     } | ||||
|     /** | ||||
|      * Returns the current summary buffer as a string | ||||
|      * | ||||
|      * @returns {string} string of summary buffer | ||||
|      */ | ||||
|     stringify() { | ||||
|         return this._buffer; | ||||
|     } | ||||
|     /** | ||||
|      * If the summary buffer is empty | ||||
|      * | ||||
|      * @returns {boolen} true if the buffer is empty | ||||
|      */ | ||||
|     isEmptyBuffer() { | ||||
|         return this._buffer.length === 0; | ||||
|     } | ||||
|     /** | ||||
|      * Resets the summary buffer without writing to summary file | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     emptyBuffer() { | ||||
|         this._buffer = ''; | ||||
|         return this; | ||||
|     } | ||||
|     /** | ||||
|      * Adds raw text to the summary buffer | ||||
|      * | ||||
|      * @param {string} text content to add | ||||
|      * @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false) | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addRaw(text, addEOL = false) { | ||||
|         this._buffer += text; | ||||
|         return addEOL ? this.addEOL() : this; | ||||
|     } | ||||
|     /** | ||||
|      * Adds the operating system-specific end-of-line marker to the buffer | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addEOL() { | ||||
|         return this.addRaw(os_1.EOL); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML codeblock to the summary buffer | ||||
|      * | ||||
|      * @param {string} code content to render within fenced code block | ||||
|      * @param {string} lang (optional) language to syntax highlight code | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addCodeBlock(code, lang) { | ||||
|         const attrs = Object.assign({}, (lang && { lang })); | ||||
|         const element = this.wrap('pre', this.wrap('code', code), attrs); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML list to the summary buffer | ||||
|      * | ||||
|      * @param {string[]} items list of items to render | ||||
|      * @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false) | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addList(items, ordered = false) { | ||||
|         const tag = ordered ? 'ol' : 'ul'; | ||||
|         const listItems = items.map(item => this.wrap('li', item)).join(''); | ||||
|         const element = this.wrap(tag, listItems); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML table to the summary buffer | ||||
|      * | ||||
|      * @param {SummaryTableCell[]} rows table rows | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addTable(rows) { | ||||
|         const tableBody = rows | ||||
|             .map(row => { | ||||
|             const cells = row | ||||
|                 .map(cell => { | ||||
|                 if (typeof cell === 'string') { | ||||
|                     return this.wrap('td', cell); | ||||
|                 } | ||||
|                 const { header, data, colspan, rowspan } = cell; | ||||
|                 const tag = header ? 'th' : 'td'; | ||||
|                 const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan })); | ||||
|                 return this.wrap(tag, data, attrs); | ||||
|             }) | ||||
|                 .join(''); | ||||
|             return this.wrap('tr', cells); | ||||
|         }) | ||||
|             .join(''); | ||||
|         const element = this.wrap('table', tableBody); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds a collapsable HTML details element to the summary buffer | ||||
|      * | ||||
|      * @param {string} label text for the closed state | ||||
|      * @param {string} content collapsable content | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addDetails(label, content) { | ||||
|         const element = this.wrap('details', this.wrap('summary', label) + content); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML image tag to the summary buffer | ||||
|      * | ||||
|      * @param {string} src path to the image you to embed | ||||
|      * @param {string} alt text description of the image | ||||
|      * @param {SummaryImageOptions} options (optional) addition image attributes | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addImage(src, alt, options) { | ||||
|         const { width, height } = options || {}; | ||||
|         const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height })); | ||||
|         const element = this.wrap('img', null, Object.assign({ src, alt }, attrs)); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML section heading element | ||||
|      * | ||||
|      * @param {string} text heading text | ||||
|      * @param {number | string} [level=1] (optional) the heading level, default: 1 | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addHeading(text, level) { | ||||
|         const tag = `h${level}`; | ||||
|         const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag) | ||||
|             ? tag | ||||
|             : 'h1'; | ||||
|         const element = this.wrap(allowedTag, text); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML thematic break (<hr>) to the summary buffer | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addSeparator() { | ||||
|         const element = this.wrap('hr', null); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML line break (<br>) to the summary buffer | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addBreak() { | ||||
|         const element = this.wrap('br', null); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML blockquote to the summary buffer | ||||
|      * | ||||
|      * @param {string} text quote text | ||||
|      * @param {string} cite (optional) citation url | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addQuote(text, cite) { | ||||
|         const attrs = Object.assign({}, (cite && { cite })); | ||||
|         const element = this.wrap('blockquote', text, attrs); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML anchor tag to the summary buffer | ||||
|      * | ||||
|      * @param {string} text link text/content | ||||
|      * @param {string} href hyperlink | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addLink(text, href) { | ||||
|         const element = this.wrap('a', text, { href }); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
| } | ||||
| // singleton export
 | ||||
| exports.markdownSummary = new MarkdownSummary(); | ||||
| //# sourceMappingURL=markdown-summary.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 549 */, | ||||
| /* 550 */, | ||||
| /* 551 */, | ||||
| @ -42117,58 +42393,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| /* 587 */, | ||||
| /* 588 */, | ||||
| /* 589 */, | ||||
| /* 590 */ | ||||
| /***/ (function(__unusedmodule, exports) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.validateValue = exports.validateKey = void 0; | ||||
| var VALID_KEY_CHAR_RANGE = '[_0-9a-z-*/]'; | ||||
| var VALID_KEY = "[a-z]" + VALID_KEY_CHAR_RANGE + "{0,255}"; | ||||
| var VALID_VENDOR_KEY = "[a-z0-9]" + VALID_KEY_CHAR_RANGE + "{0,240}@[a-z]" + VALID_KEY_CHAR_RANGE + "{0,13}"; | ||||
| var VALID_KEY_REGEX = new RegExp("^(?:" + VALID_KEY + "|" + VALID_VENDOR_KEY + ")$"); | ||||
| var VALID_VALUE_BASE_REGEX = /^[ -~]{0,255}[!-~]$/; | ||||
| var INVALID_VALUE_COMMA_EQUAL_REGEX = /,|=/; | ||||
| /** | ||||
|  * Key is opaque string up to 256 characters printable. It MUST begin with a | ||||
|  * lowercase letter, and can only contain lowercase letters a-z, digits 0-9, | ||||
|  * underscores _, dashes -, asterisks *, and forward slashes /. | ||||
|  * For multi-tenant vendor scenarios, an at sign (@) can be used to prefix the | ||||
|  * vendor name. Vendors SHOULD set the tenant ID at the beginning of the key. | ||||
|  * see https://www.w3.org/TR/trace-context/#key
 | ||||
|  */ | ||||
| function validateKey(key) { | ||||
|     return VALID_KEY_REGEX.test(key); | ||||
| } | ||||
| exports.validateKey = validateKey; | ||||
| /** | ||||
|  * Value is opaque string up to 256 characters printable ASCII RFC0020 | ||||
|  * characters (i.e., the range 0x20 to 0x7E) except comma , and =. | ||||
|  */ | ||||
| function validateValue(value) { | ||||
|     return (VALID_VALUE_BASE_REGEX.test(value) && | ||||
|         !INVALID_VALUE_COMMA_EQUAL_REGEX.test(value)); | ||||
| } | ||||
| exports.validateValue = validateValue; | ||||
| //# sourceMappingURL=tracestate-validators.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 590 */, | ||||
| /* 591 */, | ||||
| /* 592 */, | ||||
| /* 593 */, | ||||
| @ -46439,6 +46664,15 @@ function checkKey(key) { | ||||
|         throw new ValidationError(`Key Validation Error: ${key} cannot contain commas.`); | ||||
|     } | ||||
| } | ||||
| /** | ||||
|  * isFeatureAvailable to check the presence of Actions cache service | ||||
|  * | ||||
|  * @returns boolean return true if Actions cache service feature is available, otherwise false | ||||
|  */ | ||||
| function isFeatureAvailable() { | ||||
|     return !!process.env['ACTIONS_CACHE_URL']; | ||||
| } | ||||
| exports.isFeatureAvailable = isFeatureAvailable; | ||||
| /** | ||||
|  * Restores cache from keys | ||||
|  * | ||||
| @ -46505,18 +46739,12 @@ exports.restoreCache = restoreCache; | ||||
|  * @returns number returns cacheId if the cache was saved successfully and throws an error if save fails | ||||
|  */ | ||||
| function saveCache(paths, key, options) { | ||||
|     var _a, _b, _c, _d, _e; | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         checkPaths(paths); | ||||
|         checkKey(key); | ||||
|         const compressionMethod = yield utils.getCompressionMethod(); | ||||
|         core.debug('Reserving Cache'); | ||||
|         const cacheId = yield cacheHttpClient.reserveCache(key, paths, { | ||||
|             compressionMethod | ||||
|         }); | ||||
|         if (cacheId === -1) { | ||||
|             throw new ReserveCacheError(`Unable to reserve cache with key ${key}, another job may be creating this cache.`); | ||||
|         } | ||||
|         core.debug(`Cache ID: ${cacheId}`); | ||||
|         let cacheId = null; | ||||
|         const cachePaths = yield utils.resolvePaths(paths); | ||||
|         core.debug('Cache Paths:'); | ||||
|         core.debug(`${JSON.stringify(cachePaths)}`); | ||||
| @ -46531,9 +46759,24 @@ function saveCache(paths, key, options) { | ||||
|             const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit
 | ||||
|             const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); | ||||
|             core.debug(`File Size: ${archiveFileSize}`); | ||||
|             if (archiveFileSize > fileSizeLimit) { | ||||
|             // For GHES, this check will take place in ReserveCache API with enterprise file size limit
 | ||||
|             if (archiveFileSize > fileSizeLimit && !utils.isGhes()) { | ||||
|                 throw new Error(`Cache size of ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B) is over the 10GB limit, not saving cache.`); | ||||
|             } | ||||
|             core.debug('Reserving Cache'); | ||||
|             const reserveCacheResponse = yield cacheHttpClient.reserveCache(key, paths, { | ||||
|                 compressionMethod, | ||||
|                 cacheSize: archiveFileSize | ||||
|             }); | ||||
|             if ((_a = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.result) === null || _a === void 0 ? void 0 : _a.cacheId) { | ||||
|                 cacheId = (_b = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.result) === null || _b === void 0 ? void 0 : _b.cacheId; | ||||
|             } | ||||
|             else if ((reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.statusCode) === 400) { | ||||
|                 throw new Error((_d = (_c = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.error) === null || _c === void 0 ? void 0 : _c.message) !== null && _d !== void 0 ? _d : `Cache size of ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B) is over the data cap limit, not saving cache.`); | ||||
|             } | ||||
|             else { | ||||
|                 throw new ReserveCacheError(`Unable to reserve cache with key ${key}, another job may be creating this cache. More details: ${(_e = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.error) === null || _e === void 0 ? void 0 : _e.message}`); | ||||
|             } | ||||
|             core.debug(`Saving Cache (ID: ${cacheId})`); | ||||
|             yield cacheHttpClient.saveCache(cacheId, archivePath, options); | ||||
|         } | ||||
| @ -47220,30 +47463,7 @@ exports.OidcClient = OidcClient; | ||||
| //# sourceMappingURL=oidc-utils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 743 */ | ||||
| /***/ (function(__unusedmodule, exports) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=tracer_options.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 743 */, | ||||
| /* 744 */, | ||||
| /* 745 */, | ||||
| /* 746 */, | ||||
| @ -47340,117 +47560,7 @@ function async(callback) | ||||
| /* 753 */, | ||||
| /* 754 */, | ||||
| /* 755 */, | ||||
| /* 756 */ | ||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.TraceStateImpl = void 0; | ||||
| var tracestate_validators_1 = __webpack_require__(590); | ||||
| var MAX_TRACE_STATE_ITEMS = 32; | ||||
| var MAX_TRACE_STATE_LEN = 512; | ||||
| var LIST_MEMBERS_SEPARATOR = ','; | ||||
| var LIST_MEMBER_KEY_VALUE_SPLITTER = '='; | ||||
| /** | ||||
|  * TraceState must be a class and not a simple object type because of the spec | ||||
|  * requirement (https://www.w3.org/TR/trace-context/#tracestate-field).
 | ||||
|  * | ||||
|  * Here is the list of allowed mutations: | ||||
|  * - New key-value pair should be added into the beginning of the list | ||||
|  * - The value of any key can be updated. Modified keys MUST be moved to the | ||||
|  * beginning of the list. | ||||
|  */ | ||||
| var TraceStateImpl = /** @class */ (function () { | ||||
|     function TraceStateImpl(rawTraceState) { | ||||
|         this._internalState = new Map(); | ||||
|         if (rawTraceState) | ||||
|             this._parse(rawTraceState); | ||||
|     } | ||||
|     TraceStateImpl.prototype.set = function (key, value) { | ||||
|         // TODO: Benchmark the different approaches(map vs list) and
 | ||||
|         // use the faster one.
 | ||||
|         var traceState = this._clone(); | ||||
|         if (traceState._internalState.has(key)) { | ||||
|             traceState._internalState.delete(key); | ||||
|         } | ||||
|         traceState._internalState.set(key, value); | ||||
|         return traceState; | ||||
|     }; | ||||
|     TraceStateImpl.prototype.unset = function (key) { | ||||
|         var traceState = this._clone(); | ||||
|         traceState._internalState.delete(key); | ||||
|         return traceState; | ||||
|     }; | ||||
|     TraceStateImpl.prototype.get = function (key) { | ||||
|         return this._internalState.get(key); | ||||
|     }; | ||||
|     TraceStateImpl.prototype.serialize = function () { | ||||
|         var _this = this; | ||||
|         return this._keys() | ||||
|             .reduce(function (agg, key) { | ||||
|             agg.push(key + LIST_MEMBER_KEY_VALUE_SPLITTER + _this.get(key)); | ||||
|             return agg; | ||||
|         }, []) | ||||
|             .join(LIST_MEMBERS_SEPARATOR); | ||||
|     }; | ||||
|     TraceStateImpl.prototype._parse = function (rawTraceState) { | ||||
|         if (rawTraceState.length > MAX_TRACE_STATE_LEN) | ||||
|             return; | ||||
|         this._internalState = rawTraceState | ||||
|             .split(LIST_MEMBERS_SEPARATOR) | ||||
|             .reverse() // Store in reverse so new keys (.set(...)) will be placed at the beginning
 | ||||
|             .reduce(function (agg, part) { | ||||
|             var listMember = part.trim(); // Optional Whitespace (OWS) handling
 | ||||
|             var i = listMember.indexOf(LIST_MEMBER_KEY_VALUE_SPLITTER); | ||||
|             if (i !== -1) { | ||||
|                 var key = listMember.slice(0, i); | ||||
|                 var value = listMember.slice(i + 1, part.length); | ||||
|                 if (tracestate_validators_1.validateKey(key) && tracestate_validators_1.validateValue(value)) { | ||||
|                     agg.set(key, value); | ||||
|                 } | ||||
|                 else { | ||||
|                     // TODO: Consider to add warning log
 | ||||
|                 } | ||||
|             } | ||||
|             return agg; | ||||
|         }, new Map()); | ||||
|         // Because of the reverse() requirement, trunc must be done after map is created
 | ||||
|         if (this._internalState.size > MAX_TRACE_STATE_ITEMS) { | ||||
|             this._internalState = new Map(Array.from(this._internalState.entries()) | ||||
|                 .reverse() // Use reverse same as original tracestate parse chain
 | ||||
|                 .slice(0, MAX_TRACE_STATE_ITEMS)); | ||||
|         } | ||||
|     }; | ||||
|     TraceStateImpl.prototype._keys = function () { | ||||
|         return Array.from(this._internalState.keys()).reverse(); | ||||
|     }; | ||||
|     TraceStateImpl.prototype._clone = function () { | ||||
|         var traceState = new TraceStateImpl(); | ||||
|         traceState._internalState = new Map(this._internalState); | ||||
|         return traceState; | ||||
|     }; | ||||
|     return TraceStateImpl; | ||||
| }()); | ||||
| exports.TraceStateImpl = TraceStateImpl; | ||||
| //# sourceMappingURL=tracestate-impl.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 756 */, | ||||
| /* 757 */, | ||||
| /* 758 */, | ||||
| /* 759 */, | ||||
| @ -48066,7 +48176,11 @@ module.exports = function(dst, src) { | ||||
| 
 | ||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||
|     if (k2 === undefined) k2 = k; | ||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[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]; | ||||
| @ -48079,7 +48193,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | ||||
| 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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||
|     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; | ||||
| }; | ||||
| @ -48100,8 +48214,7 @@ const utils = __importStar(__webpack_require__(443)); | ||||
| function run() { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         try { | ||||
|             if (utils.isGhes()) { | ||||
|                 utils.logWarning("Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details"); | ||||
|             if (!utils.isCacheFeatureAvailable()) { | ||||
|                 utils.setCacheHitOutput(false); | ||||
|                 return; | ||||
|             } | ||||
| @ -48132,11 +48245,12 @@ function run() { | ||||
|                 core.info(`Cache restored from key: ${cacheKey}`); | ||||
|             } | ||||
|             catch (error) { | ||||
|                 if (error.name === cache.ValidationError.name) { | ||||
|                 const typedError = error; | ||||
|                 if (typedError.name === cache.ValidationError.name) { | ||||
|                     throw error; | ||||
|                 } | ||||
|                 else { | ||||
|                     utils.logWarning(error.message); | ||||
|                     utils.logWarning(typedError.message); | ||||
|                     utils.setCacheHitOutput(false); | ||||
|                 } | ||||
|             } | ||||
| @ -49634,7 +49748,7 @@ module.exports = v4; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.VERSION = void 0; | ||||
| // this is autogenerated file, see scripts/version-update.js
 | ||||
| exports.VERSION = '1.1.0'; | ||||
| exports.VERSION = '1.0.4'; | ||||
| //# sourceMappingURL=version.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -51766,7 +51880,8 @@ function retryTypedResponse(name, method, maxAttempts = constants_1.DefaultRetry | ||||
|                 return { | ||||
|                     statusCode: error.statusCode, | ||||
|                     result: null, | ||||
|                     headers: {} | ||||
|                     headers: {}, | ||||
|                     error | ||||
|                 }; | ||||
|             } | ||||
|             else { | ||||
| @ -51857,30 +51972,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=attributes.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 907 */ | ||||
| /***/ (function(__unusedmodule, exports) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=Attributes.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 907 */, | ||||
| /* 908 */, | ||||
| /* 909 */, | ||||
| /* 910 */ | ||||
|  | ||||
							
								
								
									
										662
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										662
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1199,6 +1199,11 @@ function assertDefined(name, value) { | ||||
|     return value; | ||||
| } | ||||
| exports.assertDefined = assertDefined; | ||||
| function isGhes() { | ||||
|     const ghUrl = new URL(process.env['GITHUB_SERVER_URL'] || 'https://github.com'); | ||||
|     return ghUrl.hostname.toUpperCase() !== 'GITHUB.COM'; | ||||
| } | ||||
| exports.isGhes = isGhes; | ||||
| //# sourceMappingURL=cacheUtils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -1405,36 +1410,7 @@ exports.default = _default; | ||||
| /* 39 */, | ||||
| /* 40 */, | ||||
| /* 41 */, | ||||
| /* 42 */ | ||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.createTraceState = void 0; | ||||
| var tracestate_impl_1 = __webpack_require__(756); | ||||
| function createTraceState(rawTraceState) { | ||||
|     return new tracestate_impl_1.TraceStateImpl(rawTraceState); | ||||
| } | ||||
| exports.createTraceState = createTraceState; | ||||
| //# sourceMappingURL=utils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 42 */, | ||||
| /* 43 */, | ||||
| /* 44 */, | ||||
| /* 45 */, | ||||
| @ -3221,10 +3197,7 @@ const options_1 = __webpack_require__(538); | ||||
| const requestUtils_1 = __webpack_require__(899); | ||||
| const versionSalt = '1.0'; | ||||
| function getCacheApiUrl(resource) { | ||||
|     // Ideally we just use ACTIONS_CACHE_URL
 | ||||
|     const baseUrl = (process.env['ACTIONS_CACHE_URL'] || | ||||
|         process.env['ACTIONS_RUNTIME_URL'] || | ||||
|         '').replace('pipelines', 'artifactcache'); | ||||
|     const baseUrl = process.env['ACTIONS_CACHE_URL'] || ''; | ||||
|     if (!baseUrl) { | ||||
|         throw new Error('Cache Service Url not found, unable to restore cache.'); | ||||
|     } | ||||
| @ -3302,18 +3275,18 @@ function downloadCache(archiveLocation, archivePath, options) { | ||||
| exports.downloadCache = downloadCache; | ||||
| // Reserve Cache
 | ||||
| function reserveCache(key, paths, options) { | ||||
|     var _a, _b; | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         const httpClient = createHttpClient(); | ||||
|         const version = getCacheVersion(paths, options === null || options === void 0 ? void 0 : options.compressionMethod); | ||||
|         const reserveCacheRequest = { | ||||
|             key, | ||||
|             version | ||||
|             version, | ||||
|             cacheSize: options === null || options === void 0 ? void 0 : options.cacheSize | ||||
|         }; | ||||
|         const response = yield requestUtils_1.retryTypedResponse('reserveCache', () => __awaiter(this, void 0, void 0, function* () { | ||||
|             return httpClient.postJson(getCacheApiUrl('caches'), reserveCacheRequest); | ||||
|         })); | ||||
|         return (_b = (_a = response === null || response === void 0 ? void 0 : response.result) === null || _a === void 0 ? void 0 : _a.cacheId) !== null && _b !== void 0 ? _b : -1; | ||||
|         return response; | ||||
|     }); | ||||
| } | ||||
| exports.reserveCache = reserveCache; | ||||
| @ -4470,7 +4443,7 @@ var NoopTracer_1 = __webpack_require__(151); | ||||
| var NoopTracerProvider = /** @class */ (function () { | ||||
|     function NoopTracerProvider() { | ||||
|     } | ||||
|     NoopTracerProvider.prototype.getTracer = function (_name, _version, _options) { | ||||
|     NoopTracerProvider.prototype.getTracer = function (_name, _version) { | ||||
|         return new NoopTracer_1.NoopTracer(); | ||||
|     }; | ||||
|     return NoopTracerProvider; | ||||
| @ -5519,7 +5492,8 @@ function downloadCacheStorageSDK(archiveLocation, archivePath, options) { | ||||
|             //
 | ||||
|             // If the file exceeds the buffer maximum length (~1 GB on 32-bit systems and ~2 GB
 | ||||
|             // on 64-bit systems), split the download into multiple segments
 | ||||
|             const maxSegmentSize = buffer.constants.MAX_LENGTH; | ||||
|             // ~2 GB = 2147483647, beyond this, we start getting out of range error. So, capping it accordingly.
 | ||||
|             const maxSegmentSize = Math.min(2147483647, buffer.constants.MAX_LENGTH); | ||||
|             const downloadProgress = new DownloadProgress(contentLength); | ||||
|             const fd = fs.openSync(archivePath, 'w'); | ||||
|             try { | ||||
| @ -36293,9 +36267,9 @@ var ProxyTracerProvider = /** @class */ (function () { | ||||
|     /** | ||||
|      * Get a {@link ProxyTracer} | ||||
|      */ | ||||
|     ProxyTracerProvider.prototype.getTracer = function (name, version, options) { | ||||
|     ProxyTracerProvider.prototype.getTracer = function (name, version) { | ||||
|         var _a; | ||||
|         return ((_a = this.getDelegateTracer(name, version, options)) !== null && _a !== void 0 ? _a : new ProxyTracer_1.ProxyTracer(this, name, version, options)); | ||||
|         return ((_a = this.getDelegateTracer(name, version)) !== null && _a !== void 0 ? _a : new ProxyTracer_1.ProxyTracer(this, name, version)); | ||||
|     }; | ||||
|     ProxyTracerProvider.prototype.getDelegate = function () { | ||||
|         var _a; | ||||
| @ -36307,9 +36281,9 @@ var ProxyTracerProvider = /** @class */ (function () { | ||||
|     ProxyTracerProvider.prototype.setDelegate = function (delegate) { | ||||
|         this._delegate = delegate; | ||||
|     }; | ||||
|     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version, options) { | ||||
|     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version) { | ||||
|         var _a; | ||||
|         return (_a = this._delegate) === null || _a === void 0 ? void 0 : _a.getTracer(name, version, options); | ||||
|         return (_a = this._delegate) === null || _a === void 0 ? void 0 : _a.getTracer(name, version); | ||||
|     }; | ||||
|     return ProxyTracerProvider; | ||||
| }()); | ||||
| @ -36348,11 +36322,10 @@ var NOOP_TRACER = new NoopTracer_1.NoopTracer(); | ||||
|  * Proxy tracer provided by the proxy tracer provider | ||||
|  */ | ||||
| var ProxyTracer = /** @class */ (function () { | ||||
|     function ProxyTracer(_provider, name, version, options) { | ||||
|     function ProxyTracer(_provider, name, version) { | ||||
|         this._provider = _provider; | ||||
|         this.name = name; | ||||
|         this.version = version; | ||||
|         this.options = options; | ||||
|     } | ||||
|     ProxyTracer.prototype.startSpan = function (name, options, context) { | ||||
|         return this._getTracer().startSpan(name, options, context); | ||||
| @ -36369,7 +36342,7 @@ var ProxyTracer = /** @class */ (function () { | ||||
|         if (this._delegate) { | ||||
|             return this._delegate; | ||||
|         } | ||||
|         var tracer = this._provider.getDelegateTracer(this.name, this.version, this.options); | ||||
|         var tracer = this._provider.getDelegateTracer(this.name, this.version); | ||||
|         if (!tracer) { | ||||
|             return NOOP_TRACER; | ||||
|         } | ||||
| @ -37369,13 +37342,12 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) { | ||||
|     for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.diag = exports.propagation = exports.trace = exports.context = exports.INVALID_SPAN_CONTEXT = exports.INVALID_TRACEID = exports.INVALID_SPANID = exports.isValidSpanId = exports.isValidTraceId = exports.isSpanContextValid = exports.createTraceState = exports.baggageEntryMetadataFromString = void 0; | ||||
| exports.diag = exports.propagation = exports.trace = exports.context = exports.INVALID_SPAN_CONTEXT = exports.INVALID_TRACEID = exports.INVALID_SPANID = exports.isValidSpanId = exports.isValidTraceId = exports.isSpanContextValid = exports.baggageEntryMetadataFromString = void 0; | ||||
| __exportStar(__webpack_require__(880), exports); | ||||
| var utils_1 = __webpack_require__(112); | ||||
| Object.defineProperty(exports, "baggageEntryMetadataFromString", { enumerable: true, get: function () { return utils_1.baggageEntryMetadataFromString; } }); | ||||
| __exportStar(__webpack_require__(452), exports); | ||||
| __exportStar(__webpack_require__(158), exports); | ||||
| __exportStar(__webpack_require__(907), exports); | ||||
| __exportStar(__webpack_require__(893), exports); | ||||
| __exportStar(__webpack_require__(881), exports); | ||||
| __exportStar(__webpack_require__(906), exports); | ||||
| @ -37391,11 +37363,8 @@ __exportStar(__webpack_require__(220), exports); | ||||
| __exportStar(__webpack_require__(932), exports); | ||||
| __exportStar(__webpack_require__(975), exports); | ||||
| __exportStar(__webpack_require__(207), exports); | ||||
| var utils_2 = __webpack_require__(42); | ||||
| Object.defineProperty(exports, "createTraceState", { enumerable: true, get: function () { return utils_2.createTraceState; } }); | ||||
| __exportStar(__webpack_require__(694), exports); | ||||
| __exportStar(__webpack_require__(695), exports); | ||||
| __exportStar(__webpack_require__(743), exports); | ||||
| var spancontext_utils_1 = __webpack_require__(629); | ||||
| Object.defineProperty(exports, "isSpanContextValid", { enumerable: true, get: function () { return spancontext_utils_1.isSpanContextValid; } }); | ||||
| Object.defineProperty(exports, "isValidTraceId", { enumerable: true, get: function () { return spancontext_utils_1.isValidTraceId; } }); | ||||
| @ -37441,7 +37410,11 @@ exports.default = { | ||||
| 
 | ||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||
|     if (k2 === undefined) k2 = k; | ||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[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]; | ||||
| @ -37454,12 +37427,13 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | ||||
| 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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||
|     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.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.getCacheState = exports.setOutputAndState = exports.setCacheHitOutput = exports.setCacheState = exports.isExactKeyMatch = exports.isGhes = void 0; | ||||
| const cache = __importStar(__webpack_require__(692)); | ||||
| const core = __importStar(__webpack_require__(470)); | ||||
| const constants_1 = __webpack_require__(196); | ||||
| function isGhes() { | ||||
| @ -37524,6 +37498,19 @@ function getInputAsInt(name, options) { | ||||
|     return value; | ||||
| } | ||||
| exports.getInputAsInt = getInputAsInt; | ||||
| function isCacheFeatureAvailable() { | ||||
|     if (!cache.isFeatureAvailable()) { | ||||
|         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."); | ||||
|         } | ||||
|         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 true; | ||||
| } | ||||
| exports.isCacheFeatureAvailable = isCacheFeatureAvailable; | ||||
| 
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -39888,6 +39875,11 @@ function getIDToken(aud) { | ||||
|     }); | ||||
| } | ||||
| exports.getIDToken = getIDToken; | ||||
| /** | ||||
|  * Markdown summary exports | ||||
|  */ | ||||
| var markdown_summary_1 = __webpack_require__(548); | ||||
| Object.defineProperty(exports, "markdownSummary", { enumerable: true, get: function () { return markdown_summary_1.markdownSummary; } }); | ||||
| //# sourceMappingURL=core.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -41494,7 +41486,291 @@ CombinedStream.prototype._emitError = function(err) { | ||||
| 
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 548 */, | ||||
| /* 548 */ | ||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| 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 }); | ||||
| exports.markdownSummary = exports.SUMMARY_DOCS_URL = exports.SUMMARY_ENV_VAR = void 0; | ||||
| const os_1 = __webpack_require__(87); | ||||
| const fs_1 = __webpack_require__(747); | ||||
| const { access, appendFile, writeFile } = fs_1.promises; | ||||
| exports.SUMMARY_ENV_VAR = 'GITHUB_STEP_SUMMARY'; | ||||
| exports.SUMMARY_DOCS_URL = 'https://docs.github.com/actions/using-workflows/workflow-commands-for-github-actions#adding-a-markdown-summary'; | ||||
| class MarkdownSummary { | ||||
|     constructor() { | ||||
|         this._buffer = ''; | ||||
|     } | ||||
|     /** | ||||
|      * Finds the summary file path from the environment, rejects if env var is not found or file does not exist | ||||
|      * Also checks r/w permissions. | ||||
|      * | ||||
|      * @returns step summary file path | ||||
|      */ | ||||
|     filePath() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             if (this._filePath) { | ||||
|                 return this._filePath; | ||||
|             } | ||||
|             const pathFromEnv = process.env[exports.SUMMARY_ENV_VAR]; | ||||
|             if (!pathFromEnv) { | ||||
|                 throw new Error(`Unable to find environment variable for $${exports.SUMMARY_ENV_VAR}. Check if your runtime environment supports markdown summaries.`); | ||||
|             } | ||||
|             try { | ||||
|                 yield access(pathFromEnv, fs_1.constants.R_OK | fs_1.constants.W_OK); | ||||
|             } | ||||
|             catch (_a) { | ||||
|                 throw new Error(`Unable to access summary file: '${pathFromEnv}'. Check if the file has correct read/write permissions.`); | ||||
|             } | ||||
|             this._filePath = pathFromEnv; | ||||
|             return this._filePath; | ||||
|         }); | ||||
|     } | ||||
|     /** | ||||
|      * Wraps content in an HTML tag, adding any HTML attributes | ||||
|      * | ||||
|      * @param {string} tag HTML tag to wrap | ||||
|      * @param {string | null} content content within the tag | ||||
|      * @param {[attribute: string]: string} attrs key-value list of HTML attributes to add | ||||
|      * | ||||
|      * @returns {string} content wrapped in HTML element | ||||
|      */ | ||||
|     wrap(tag, content, attrs = {}) { | ||||
|         const htmlAttrs = Object.entries(attrs) | ||||
|             .map(([key, value]) => ` ${key}="${value}"`) | ||||
|             .join(''); | ||||
|         if (!content) { | ||||
|             return `<${tag}${htmlAttrs}>`; | ||||
|         } | ||||
|         return `<${tag}${htmlAttrs}>${content}</${tag}>`; | ||||
|     } | ||||
|     /** | ||||
|      * Writes text in the buffer to the summary buffer file and empties buffer. Will append by default. | ||||
|      * | ||||
|      * @param {SummaryWriteOptions} [options] (optional) options for write operation | ||||
|      * | ||||
|      * @returns {Promise<MarkdownSummary>} markdown summary instance | ||||
|      */ | ||||
|     write(options) { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             const overwrite = !!(options === null || options === void 0 ? void 0 : options.overwrite); | ||||
|             const filePath = yield this.filePath(); | ||||
|             const writeFunc = overwrite ? writeFile : appendFile; | ||||
|             yield writeFunc(filePath, this._buffer, { encoding: 'utf8' }); | ||||
|             return this.emptyBuffer(); | ||||
|         }); | ||||
|     } | ||||
|     /** | ||||
|      * Clears the summary buffer and wipes the summary file | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     clear() { | ||||
|         return __awaiter(this, void 0, void 0, function* () { | ||||
|             return this.emptyBuffer().write({ overwrite: true }); | ||||
|         }); | ||||
|     } | ||||
|     /** | ||||
|      * Returns the current summary buffer as a string | ||||
|      * | ||||
|      * @returns {string} string of summary buffer | ||||
|      */ | ||||
|     stringify() { | ||||
|         return this._buffer; | ||||
|     } | ||||
|     /** | ||||
|      * If the summary buffer is empty | ||||
|      * | ||||
|      * @returns {boolen} true if the buffer is empty | ||||
|      */ | ||||
|     isEmptyBuffer() { | ||||
|         return this._buffer.length === 0; | ||||
|     } | ||||
|     /** | ||||
|      * Resets the summary buffer without writing to summary file | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     emptyBuffer() { | ||||
|         this._buffer = ''; | ||||
|         return this; | ||||
|     } | ||||
|     /** | ||||
|      * Adds raw text to the summary buffer | ||||
|      * | ||||
|      * @param {string} text content to add | ||||
|      * @param {boolean} [addEOL=false] (optional) append an EOL to the raw text (default: false) | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addRaw(text, addEOL = false) { | ||||
|         this._buffer += text; | ||||
|         return addEOL ? this.addEOL() : this; | ||||
|     } | ||||
|     /** | ||||
|      * Adds the operating system-specific end-of-line marker to the buffer | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addEOL() { | ||||
|         return this.addRaw(os_1.EOL); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML codeblock to the summary buffer | ||||
|      * | ||||
|      * @param {string} code content to render within fenced code block | ||||
|      * @param {string} lang (optional) language to syntax highlight code | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addCodeBlock(code, lang) { | ||||
|         const attrs = Object.assign({}, (lang && { lang })); | ||||
|         const element = this.wrap('pre', this.wrap('code', code), attrs); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML list to the summary buffer | ||||
|      * | ||||
|      * @param {string[]} items list of items to render | ||||
|      * @param {boolean} [ordered=false] (optional) if the rendered list should be ordered or not (default: false) | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addList(items, ordered = false) { | ||||
|         const tag = ordered ? 'ol' : 'ul'; | ||||
|         const listItems = items.map(item => this.wrap('li', item)).join(''); | ||||
|         const element = this.wrap(tag, listItems); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML table to the summary buffer | ||||
|      * | ||||
|      * @param {SummaryTableCell[]} rows table rows | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addTable(rows) { | ||||
|         const tableBody = rows | ||||
|             .map(row => { | ||||
|             const cells = row | ||||
|                 .map(cell => { | ||||
|                 if (typeof cell === 'string') { | ||||
|                     return this.wrap('td', cell); | ||||
|                 } | ||||
|                 const { header, data, colspan, rowspan } = cell; | ||||
|                 const tag = header ? 'th' : 'td'; | ||||
|                 const attrs = Object.assign(Object.assign({}, (colspan && { colspan })), (rowspan && { rowspan })); | ||||
|                 return this.wrap(tag, data, attrs); | ||||
|             }) | ||||
|                 .join(''); | ||||
|             return this.wrap('tr', cells); | ||||
|         }) | ||||
|             .join(''); | ||||
|         const element = this.wrap('table', tableBody); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds a collapsable HTML details element to the summary buffer | ||||
|      * | ||||
|      * @param {string} label text for the closed state | ||||
|      * @param {string} content collapsable content | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addDetails(label, content) { | ||||
|         const element = this.wrap('details', this.wrap('summary', label) + content); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML image tag to the summary buffer | ||||
|      * | ||||
|      * @param {string} src path to the image you to embed | ||||
|      * @param {string} alt text description of the image | ||||
|      * @param {SummaryImageOptions} options (optional) addition image attributes | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addImage(src, alt, options) { | ||||
|         const { width, height } = options || {}; | ||||
|         const attrs = Object.assign(Object.assign({}, (width && { width })), (height && { height })); | ||||
|         const element = this.wrap('img', null, Object.assign({ src, alt }, attrs)); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML section heading element | ||||
|      * | ||||
|      * @param {string} text heading text | ||||
|      * @param {number | string} [level=1] (optional) the heading level, default: 1 | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addHeading(text, level) { | ||||
|         const tag = `h${level}`; | ||||
|         const allowedTag = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'].includes(tag) | ||||
|             ? tag | ||||
|             : 'h1'; | ||||
|         const element = this.wrap(allowedTag, text); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML thematic break (<hr>) to the summary buffer | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addSeparator() { | ||||
|         const element = this.wrap('hr', null); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML line break (<br>) to the summary buffer | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addBreak() { | ||||
|         const element = this.wrap('br', null); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML blockquote to the summary buffer | ||||
|      * | ||||
|      * @param {string} text quote text | ||||
|      * @param {string} cite (optional) citation url | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addQuote(text, cite) { | ||||
|         const attrs = Object.assign({}, (cite && { cite })); | ||||
|         const element = this.wrap('blockquote', text, attrs); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
|     /** | ||||
|      * Adds an HTML anchor tag to the summary buffer | ||||
|      * | ||||
|      * @param {string} text link text/content | ||||
|      * @param {string} href hyperlink | ||||
|      * | ||||
|      * @returns {MarkdownSummary} markdown summary instance | ||||
|      */ | ||||
|     addLink(text, href) { | ||||
|         const element = this.wrap('a', text, { href }); | ||||
|         return this.addRaw(element).addEOL(); | ||||
|     } | ||||
| } | ||||
| // singleton export
 | ||||
| exports.markdownSummary = new MarkdownSummary(); | ||||
| //# sourceMappingURL=markdown-summary.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 549 */, | ||||
| /* 550 */, | ||||
| /* 551 */, | ||||
| @ -42117,58 +42393,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| /* 587 */, | ||||
| /* 588 */, | ||||
| /* 589 */, | ||||
| /* 590 */ | ||||
| /***/ (function(__unusedmodule, exports) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.validateValue = exports.validateKey = void 0; | ||||
| var VALID_KEY_CHAR_RANGE = '[_0-9a-z-*/]'; | ||||
| var VALID_KEY = "[a-z]" + VALID_KEY_CHAR_RANGE + "{0,255}"; | ||||
| var VALID_VENDOR_KEY = "[a-z0-9]" + VALID_KEY_CHAR_RANGE + "{0,240}@[a-z]" + VALID_KEY_CHAR_RANGE + "{0,13}"; | ||||
| var VALID_KEY_REGEX = new RegExp("^(?:" + VALID_KEY + "|" + VALID_VENDOR_KEY + ")$"); | ||||
| var VALID_VALUE_BASE_REGEX = /^[ -~]{0,255}[!-~]$/; | ||||
| var INVALID_VALUE_COMMA_EQUAL_REGEX = /,|=/; | ||||
| /** | ||||
|  * Key is opaque string up to 256 characters printable. It MUST begin with a | ||||
|  * lowercase letter, and can only contain lowercase letters a-z, digits 0-9, | ||||
|  * underscores _, dashes -, asterisks *, and forward slashes /. | ||||
|  * For multi-tenant vendor scenarios, an at sign (@) can be used to prefix the | ||||
|  * vendor name. Vendors SHOULD set the tenant ID at the beginning of the key. | ||||
|  * see https://www.w3.org/TR/trace-context/#key
 | ||||
|  */ | ||||
| function validateKey(key) { | ||||
|     return VALID_KEY_REGEX.test(key); | ||||
| } | ||||
| exports.validateKey = validateKey; | ||||
| /** | ||||
|  * Value is opaque string up to 256 characters printable ASCII RFC0020 | ||||
|  * characters (i.e., the range 0x20 to 0x7E) except comma , and =. | ||||
|  */ | ||||
| function validateValue(value) { | ||||
|     return (VALID_VALUE_BASE_REGEX.test(value) && | ||||
|         !INVALID_VALUE_COMMA_EQUAL_REGEX.test(value)); | ||||
| } | ||||
| exports.validateValue = validateValue; | ||||
| //# sourceMappingURL=tracestate-validators.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 590 */, | ||||
| /* 591 */, | ||||
| /* 592 */, | ||||
| /* 593 */, | ||||
| @ -46350,7 +46575,11 @@ exports.default = _default; | ||||
| 
 | ||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||
|     if (k2 === undefined) k2 = k; | ||||
|     Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[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]; | ||||
| @ -46363,7 +46592,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | ||||
| 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.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); | ||||
|     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; | ||||
| }; | ||||
| @ -46388,8 +46617,7 @@ process.on("uncaughtException", e => utils.logWarning(e.message)); | ||||
| function run() { | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         try { | ||||
|             if (utils.isGhes()) { | ||||
|                 utils.logWarning("Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details"); | ||||
|             if (!utils.isCacheFeatureAvailable()) { | ||||
|                 return; | ||||
|             } | ||||
|             if (!utils.isValidEvent()) { | ||||
| @ -46417,14 +46645,15 @@ function run() { | ||||
|                 core.info(`Cache saved with key: ${primaryKey}`); | ||||
|             } | ||||
|             catch (error) { | ||||
|                 if (error.name === cache.ValidationError.name) { | ||||
|                 const typedError = error; | ||||
|                 if (typedError.name === cache.ValidationError.name) { | ||||
|                     throw error; | ||||
|                 } | ||||
|                 else if (error.name === cache.ReserveCacheError.name) { | ||||
|                     core.info(error.message); | ||||
|                 else if (typedError.name === cache.ReserveCacheError.name) { | ||||
|                     core.info(typedError.message); | ||||
|                 } | ||||
|                 else { | ||||
|                     utils.logWarning(error.message); | ||||
|                     utils.logWarning(typedError.message); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| @ -46533,6 +46762,15 @@ function checkKey(key) { | ||||
|         throw new ValidationError(`Key Validation Error: ${key} cannot contain commas.`); | ||||
|     } | ||||
| } | ||||
| /** | ||||
|  * isFeatureAvailable to check the presence of Actions cache service | ||||
|  * | ||||
|  * @returns boolean return true if Actions cache service feature is available, otherwise false | ||||
|  */ | ||||
| function isFeatureAvailable() { | ||||
|     return !!process.env['ACTIONS_CACHE_URL']; | ||||
| } | ||||
| exports.isFeatureAvailable = isFeatureAvailable; | ||||
| /** | ||||
|  * Restores cache from keys | ||||
|  * | ||||
| @ -46599,18 +46837,12 @@ exports.restoreCache = restoreCache; | ||||
|  * @returns number returns cacheId if the cache was saved successfully and throws an error if save fails | ||||
|  */ | ||||
| function saveCache(paths, key, options) { | ||||
|     var _a, _b, _c, _d, _e; | ||||
|     return __awaiter(this, void 0, void 0, function* () { | ||||
|         checkPaths(paths); | ||||
|         checkKey(key); | ||||
|         const compressionMethod = yield utils.getCompressionMethod(); | ||||
|         core.debug('Reserving Cache'); | ||||
|         const cacheId = yield cacheHttpClient.reserveCache(key, paths, { | ||||
|             compressionMethod | ||||
|         }); | ||||
|         if (cacheId === -1) { | ||||
|             throw new ReserveCacheError(`Unable to reserve cache with key ${key}, another job may be creating this cache.`); | ||||
|         } | ||||
|         core.debug(`Cache ID: ${cacheId}`); | ||||
|         let cacheId = null; | ||||
|         const cachePaths = yield utils.resolvePaths(paths); | ||||
|         core.debug('Cache Paths:'); | ||||
|         core.debug(`${JSON.stringify(cachePaths)}`); | ||||
| @ -46625,9 +46857,24 @@ function saveCache(paths, key, options) { | ||||
|             const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit
 | ||||
|             const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); | ||||
|             core.debug(`File Size: ${archiveFileSize}`); | ||||
|             if (archiveFileSize > fileSizeLimit) { | ||||
|             // For GHES, this check will take place in ReserveCache API with enterprise file size limit
 | ||||
|             if (archiveFileSize > fileSizeLimit && !utils.isGhes()) { | ||||
|                 throw new Error(`Cache size of ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B) is over the 10GB limit, not saving cache.`); | ||||
|             } | ||||
|             core.debug('Reserving Cache'); | ||||
|             const reserveCacheResponse = yield cacheHttpClient.reserveCache(key, paths, { | ||||
|                 compressionMethod, | ||||
|                 cacheSize: archiveFileSize | ||||
|             }); | ||||
|             if ((_a = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.result) === null || _a === void 0 ? void 0 : _a.cacheId) { | ||||
|                 cacheId = (_b = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.result) === null || _b === void 0 ? void 0 : _b.cacheId; | ||||
|             } | ||||
|             else if ((reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.statusCode) === 400) { | ||||
|                 throw new Error((_d = (_c = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.error) === null || _c === void 0 ? void 0 : _c.message) !== null && _d !== void 0 ? _d : `Cache size of ~${Math.round(archiveFileSize / (1024 * 1024))} MB (${archiveFileSize} B) is over the data cap limit, not saving cache.`); | ||||
|             } | ||||
|             else { | ||||
|                 throw new ReserveCacheError(`Unable to reserve cache with key ${key}, another job may be creating this cache. More details: ${(_e = reserveCacheResponse === null || reserveCacheResponse === void 0 ? void 0 : reserveCacheResponse.error) === null || _e === void 0 ? void 0 : _e.message}`); | ||||
|             } | ||||
|             core.debug(`Saving Cache (ID: ${cacheId})`); | ||||
|             yield cacheHttpClient.saveCache(cacheId, archivePath, options); | ||||
|         } | ||||
| @ -47314,30 +47561,7 @@ exports.OidcClient = OidcClient; | ||||
| //# sourceMappingURL=oidc-utils.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 743 */ | ||||
| /***/ (function(__unusedmodule, exports) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=tracer_options.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 743 */, | ||||
| /* 744 */, | ||||
| /* 745 */, | ||||
| /* 746 */, | ||||
| @ -47434,117 +47658,7 @@ function async(callback) | ||||
| /* 753 */, | ||||
| /* 754 */, | ||||
| /* 755 */, | ||||
| /* 756 */ | ||||
| /***/ (function(__unusedmodule, exports, __webpack_require__) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.TraceStateImpl = void 0; | ||||
| var tracestate_validators_1 = __webpack_require__(590); | ||||
| var MAX_TRACE_STATE_ITEMS = 32; | ||||
| var MAX_TRACE_STATE_LEN = 512; | ||||
| var LIST_MEMBERS_SEPARATOR = ','; | ||||
| var LIST_MEMBER_KEY_VALUE_SPLITTER = '='; | ||||
| /** | ||||
|  * TraceState must be a class and not a simple object type because of the spec | ||||
|  * requirement (https://www.w3.org/TR/trace-context/#tracestate-field).
 | ||||
|  * | ||||
|  * Here is the list of allowed mutations: | ||||
|  * - New key-value pair should be added into the beginning of the list | ||||
|  * - The value of any key can be updated. Modified keys MUST be moved to the | ||||
|  * beginning of the list. | ||||
|  */ | ||||
| var TraceStateImpl = /** @class */ (function () { | ||||
|     function TraceStateImpl(rawTraceState) { | ||||
|         this._internalState = new Map(); | ||||
|         if (rawTraceState) | ||||
|             this._parse(rawTraceState); | ||||
|     } | ||||
|     TraceStateImpl.prototype.set = function (key, value) { | ||||
|         // TODO: Benchmark the different approaches(map vs list) and
 | ||||
|         // use the faster one.
 | ||||
|         var traceState = this._clone(); | ||||
|         if (traceState._internalState.has(key)) { | ||||
|             traceState._internalState.delete(key); | ||||
|         } | ||||
|         traceState._internalState.set(key, value); | ||||
|         return traceState; | ||||
|     }; | ||||
|     TraceStateImpl.prototype.unset = function (key) { | ||||
|         var traceState = this._clone(); | ||||
|         traceState._internalState.delete(key); | ||||
|         return traceState; | ||||
|     }; | ||||
|     TraceStateImpl.prototype.get = function (key) { | ||||
|         return this._internalState.get(key); | ||||
|     }; | ||||
|     TraceStateImpl.prototype.serialize = function () { | ||||
|         var _this = this; | ||||
|         return this._keys() | ||||
|             .reduce(function (agg, key) { | ||||
|             agg.push(key + LIST_MEMBER_KEY_VALUE_SPLITTER + _this.get(key)); | ||||
|             return agg; | ||||
|         }, []) | ||||
|             .join(LIST_MEMBERS_SEPARATOR); | ||||
|     }; | ||||
|     TraceStateImpl.prototype._parse = function (rawTraceState) { | ||||
|         if (rawTraceState.length > MAX_TRACE_STATE_LEN) | ||||
|             return; | ||||
|         this._internalState = rawTraceState | ||||
|             .split(LIST_MEMBERS_SEPARATOR) | ||||
|             .reverse() // Store in reverse so new keys (.set(...)) will be placed at the beginning
 | ||||
|             .reduce(function (agg, part) { | ||||
|             var listMember = part.trim(); // Optional Whitespace (OWS) handling
 | ||||
|             var i = listMember.indexOf(LIST_MEMBER_KEY_VALUE_SPLITTER); | ||||
|             if (i !== -1) { | ||||
|                 var key = listMember.slice(0, i); | ||||
|                 var value = listMember.slice(i + 1, part.length); | ||||
|                 if (tracestate_validators_1.validateKey(key) && tracestate_validators_1.validateValue(value)) { | ||||
|                     agg.set(key, value); | ||||
|                 } | ||||
|                 else { | ||||
|                     // TODO: Consider to add warning log
 | ||||
|                 } | ||||
|             } | ||||
|             return agg; | ||||
|         }, new Map()); | ||||
|         // Because of the reverse() requirement, trunc must be done after map is created
 | ||||
|         if (this._internalState.size > MAX_TRACE_STATE_ITEMS) { | ||||
|             this._internalState = new Map(Array.from(this._internalState.entries()) | ||||
|                 .reverse() // Use reverse same as original tracestate parse chain
 | ||||
|                 .slice(0, MAX_TRACE_STATE_ITEMS)); | ||||
|         } | ||||
|     }; | ||||
|     TraceStateImpl.prototype._keys = function () { | ||||
|         return Array.from(this._internalState.keys()).reverse(); | ||||
|     }; | ||||
|     TraceStateImpl.prototype._clone = function () { | ||||
|         var traceState = new TraceStateImpl(); | ||||
|         traceState._internalState = new Map(this._internalState); | ||||
|         return traceState; | ||||
|     }; | ||||
|     return TraceStateImpl; | ||||
| }()); | ||||
| exports.TraceStateImpl = TraceStateImpl; | ||||
| //# sourceMappingURL=tracestate-impl.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 756 */, | ||||
| /* 757 */, | ||||
| /* 758 */, | ||||
| /* 759 */, | ||||
| @ -49637,7 +49751,7 @@ module.exports = v4; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.VERSION = void 0; | ||||
| // this is autogenerated file, see scripts/version-update.js
 | ||||
| exports.VERSION = '1.1.0'; | ||||
| exports.VERSION = '1.0.4'; | ||||
| //# sourceMappingURL=version.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| @ -51769,7 +51883,8 @@ function retryTypedResponse(name, method, maxAttempts = constants_1.DefaultRetry | ||||
|                 return { | ||||
|                     statusCode: error.statusCode, | ||||
|                     result: null, | ||||
|                     headers: {} | ||||
|                     headers: {}, | ||||
|                     error | ||||
|                 }; | ||||
|             } | ||||
|             else { | ||||
| @ -51860,30 +51975,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=attributes.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 907 */ | ||||
| /***/ (function(__unusedmodule, exports) { | ||||
| 
 | ||||
| "use strict"; | ||||
| 
 | ||||
| /* | ||||
|  * Copyright The OpenTelemetry Authors | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|  * you may not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  *      https://www.apache.org/licenses/LICENSE-2.0
 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an "AS IS" BASIS, | ||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| //# sourceMappingURL=Attributes.js.map
 | ||||
| 
 | ||||
| /***/ }), | ||||
| /* 907 */, | ||||
| /* 908 */, | ||||
| /* 909 */, | ||||
| /* 910 */ | ||||
|  | ||||
							
								
								
									
										78
									
								
								examples.md
									
									
									
									
									
								
							
							
						
						
									
										78
									
								
								examples.md
									
									
									
									
									
								
							| @ -45,7 +45,7 @@ | ||||
| Using [NuGet lock files](https://docs.microsoft.com/nuget/consume-packages/package-references-in-project-files#locking-dependencies): | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.nuget/packages | ||||
|     key: ${{ runner.os }}-nuget-${{ hashFiles('**/packages.lock.json') }} | ||||
| @ -54,10 +54,10 @@ Using [NuGet lock files](https://docs.microsoft.com/nuget/consume-packages/packa | ||||
| ``` | ||||
|  | ||||
| Depending on the environment, huge packages might be pre-installed in the global cache folder. | ||||
| With `actions/cache@v2` you can now exclude unwanted packages with [exclude pattern](https://github.com/actions/toolkit/tree/main/packages/glob#exclude-patterns) | ||||
| With `actions/cache@v3` you can now exclude unwanted packages with [exclude pattern](https://github.com/actions/toolkit/tree/main/packages/glob#exclude-patterns) | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.nuget/packages | ||||
| @ -74,7 +74,7 @@ Or you could move the cache folder like below. | ||||
| env: | ||||
|   NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages | ||||
| steps: | ||||
|   - uses: actions/cache@v2 | ||||
|   - uses: actions/cache@v3 | ||||
|     with: | ||||
|       path: ${{ github.workspace }}/.nuget/packages | ||||
|       key: ${{ runner.os }}-nuget-${{ hashFiles('**/packages.lock.json') }} | ||||
| @ -87,7 +87,7 @@ steps: | ||||
| ### POSIX | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.dub | ||||
|     key: ${{ runner.os }}-dub-${{ hashFiles('**/dub.json') }} | ||||
| @ -98,7 +98,7 @@ steps: | ||||
| ### Windows | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~\AppData\Local\dub | ||||
|     key: ${{ runner.os }}-dub-${{ hashFiles('**/dub.json') }} | ||||
| @ -111,7 +111,7 @@ steps: | ||||
| ### Linux | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.deno | ||||
| @ -122,7 +122,7 @@ steps: | ||||
| ### macOS | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.deno | ||||
| @ -133,7 +133,7 @@ steps: | ||||
| ### Windows | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~\.deno | ||||
| @ -145,7 +145,7 @@ steps: | ||||
| ## Elixir - Mix | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       deps | ||||
| @ -160,7 +160,7 @@ steps: | ||||
| ### Linux | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.cache/go-build | ||||
| @ -173,7 +173,7 @@ steps: | ||||
| ### macOS | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/Library/Caches/go-build | ||||
| @ -186,7 +186,7 @@ steps: | ||||
| ### Windows | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~\AppData\Local\go-build | ||||
| @ -202,7 +202,7 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | ||||
|  | ||||
| ```yaml | ||||
| - name: Cache ~/.cabal/packages, ~/.cabal/store and dist-newstyle | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.cabal/packages | ||||
| @ -215,14 +215,14 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | ||||
| ## Haskell - Stack | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   name: Cache ~/.stack | ||||
|   with: | ||||
|     path: ~/.stack | ||||
|     key: ${{ runner.os }}-stack-global-${{ hashFiles('stack.yaml') }}-${{ hashFiles('package.yaml') }} | ||||
|     restore-keys: | | ||||
|       ${{ runner.os }}-stack-global- | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   name: Cache .stack-work | ||||
|   with: | ||||
|     path: .stack-work | ||||
| @ -236,7 +236,7 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | ||||
| >Note: Ensure no Gradle daemons are running anymore when your workflow completes. Creating the cache package might fail due to locks being held by Gradle. Refer to the [Gradle Daemon documentation](https://docs.gradle.org/current/userguide/gradle_daemon.html) on how to disable or stop the Gradle Daemons. | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.gradle/caches | ||||
| @ -250,7 +250,7 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | ||||
|  | ||||
| ```yaml | ||||
| - name: Cache local Maven repository | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.m2/repository | ||||
|     key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} | ||||
| @ -269,7 +269,7 @@ If using `npm config` to retrieve the cache directory, ensure you run [actions/s | ||||
| ### macOS and Ubuntu | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.npm | ||||
|     key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | ||||
| @ -284,7 +284,7 @@ If using `npm config` to retrieve the cache directory, ensure you run [actions/s | ||||
|   id: npm-cache | ||||
|   run: | | ||||
|     echo "::set-output name=dir::$(npm config get cache)" | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ${{ steps.npm-cache.outputs.dir }} | ||||
|     key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | ||||
| @ -299,7 +299,7 @@ If using `npm config` to retrieve the cache directory, ensure you run [actions/s | ||||
|   id: npm-cache-dir | ||||
|   run: | | ||||
|     echo "::set-output name=dir::$(npm config get cache)" | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   id: npm-cache # use this to check for `cache-hit` ==> if: steps.npm-cache.outputs.cache-hit != 'true' | ||||
|   with: | ||||
|     path: ${{ steps.npm-cache-dir.outputs.dir }} | ||||
| @ -312,7 +312,7 @@ If using `npm config` to retrieve the cache directory, ensure you run [actions/s | ||||
|  | ||||
| ```yaml | ||||
| - name: restore lerna | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: **/node_modules | ||||
|     key: ${{ runner.os }}-${{ hashFiles('**/yarn.lock') }} | ||||
| @ -326,7 +326,7 @@ The yarn cache directory will depend on your operating system and version of `ya | ||||
|   id: yarn-cache-dir-path | ||||
|   run: echo "::set-output name=dir::$(yarn cache dir)" | ||||
|  | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | ||||
|   with: | ||||
|     path: ${{ steps.yarn-cache-dir-path.outputs.dir }} | ||||
| @ -344,7 +344,7 @@ The yarn 2 cache directory will depend on your config. See https://yarnpkg.com/c | ||||
|   id: yarn-cache-dir-path | ||||
|   run: echo "::set-output name=dir::$(yarn config get cacheFolder)" | ||||
|  | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | ||||
|   with: | ||||
|     path: ${{ steps.yarn-cache-dir-path.outputs.dir }} | ||||
| @ -359,7 +359,7 @@ Esy allows you to export built dependencies and import pre-built dependencies. | ||||
| ```yaml | ||||
|     - name: Restore Cache | ||||
|       id: restore-cache | ||||
|       uses: actions/cache@v2 | ||||
|       uses: actions/cache@v3 | ||||
|       with: | ||||
|         path: _export | ||||
|         key:  ${{ runner.os }}-esy-${{ hashFiles('esy.lock/index.json') }} | ||||
| @ -388,7 +388,7 @@ Esy allows you to export built dependencies and import pre-built dependencies. | ||||
|   id: composer-cache | ||||
|   run: | | ||||
|     echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ${{ steps.composer-cache.outputs.dir }} | ||||
|     key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||
| @ -409,7 +409,7 @@ Locations: | ||||
| ### Simple example | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.cache/pip | ||||
|     key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} | ||||
| @ -422,7 +422,7 @@ Replace `~/.cache/pip` with the correct `path` if not using Ubuntu. | ||||
| ### Multiple OS's in a workflow | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   if: startsWith(runner.os, 'Linux') | ||||
|   with: | ||||
|     path: ~/.cache/pip | ||||
| @ -430,7 +430,7 @@ Replace `~/.cache/pip` with the correct `path` if not using Ubuntu. | ||||
|     restore-keys: | | ||||
|       ${{ runner.os }}-pip- | ||||
|  | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   if: startsWith(runner.os, 'macOS') | ||||
|   with: | ||||
|     path: ~/Library/Caches/pip | ||||
| @ -438,7 +438,7 @@ Replace `~/.cache/pip` with the correct `path` if not using Ubuntu. | ||||
|     restore-keys: | | ||||
|       ${{ runner.os }}-pip- | ||||
|  | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   if: startsWith(runner.os, 'Windows') | ||||
|   with: | ||||
|     path: ~\AppData\Local\pip\Cache | ||||
| @ -464,7 +464,7 @@ jobs: | ||||
|         - os: windows-latest | ||||
|           path: ~\AppData\Local\pip\Cache | ||||
|     steps: | ||||
|     - uses: actions/cache@v2 | ||||
|     - uses: actions/cache@v3 | ||||
|       with: | ||||
|         path: ${{ matrix.path }} | ||||
|         key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} | ||||
| @ -482,7 +482,7 @@ jobs: | ||||
|     echo "::set-output name=dir::$(pip cache dir)" | ||||
|  | ||||
| - name: pip cache | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ${{ steps.pip-cache.outputs.dir }} | ||||
|     key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} | ||||
| @ -500,7 +500,7 @@ jobs: | ||||
|  | ||||
|   ⋮ | ||||
|  | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ~/.local/share/virtualenvs | ||||
|     key: ${{ runner.os }}-python-${{ steps.setup-python.outputs.python-version }}-pipenv-${{ hashFiles('Pipfile.lock') }} | ||||
| @ -527,7 +527,7 @@ For renv, the cache directory will vary by OS. The `RENV_PATHS_ROOT` environment | ||||
|     cat("##[set-output name=r-version;]", R.Version()$version.string, sep = "") | ||||
|   shell: Rscript {0} | ||||
| - name: Restore Renv package cache | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: ${{ env.RENV_PATHS_ROOT }} | ||||
|     key: ${{ steps.get-version.outputs.os-version }}-${{ steps.get-version.outputs.r-version }}-${{ inputs.cache-version }}-${{ hashFiles('renv.lock') }} | ||||
| @ -553,7 +553,7 @@ whenever possible: | ||||
| ## Rust - Cargo | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.cargo/bin/ | ||||
| @ -568,7 +568,7 @@ whenever possible: | ||||
|  | ||||
| ```yaml | ||||
| - name: Cache SBT | ||||
|   uses: actions/cache@v2 | ||||
|   uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: | | ||||
|       ~/.ivy2/cache | ||||
| @ -579,7 +579,7 @@ whenever possible: | ||||
| ## Swift, Objective-C - Carthage | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: Carthage | ||||
|     key: ${{ runner.os }}-carthage-${{ hashFiles('**/Cartfile.resolved') }} | ||||
| @ -590,7 +590,7 @@ whenever possible: | ||||
| ## Swift, Objective-C - CocoaPods | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: Pods | ||||
|     key: ${{ runner.os }}-pods-${{ hashFiles('**/Podfile.lock') }} | ||||
| @ -601,7 +601,7 @@ whenever possible: | ||||
| ## Swift - Swift Package Manager | ||||
|  | ||||
| ```yaml | ||||
| - uses: actions/cache@v2 | ||||
| - uses: actions/cache@v3 | ||||
|   with: | ||||
|     path: .build | ||||
|     key: ${{ runner.os }}-spm-${{ hashFiles('**/Package.resolved') }} | ||||
|  | ||||
							
								
								
									
										13408
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										13408
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										30
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								package.json
									
									
									
									
									
								
							| @ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "cache", | ||||
|   "version": "3.0.0", | ||||
|   "version": "3.0.2", | ||||
|   "private": true, | ||||
|   "description": "Cache dependencies and build outputs", | ||||
|   "main": "dist/restore/index.js", | ||||
| @ -23,29 +23,29 @@ | ||||
|   "author": "GitHub", | ||||
|   "license": "MIT", | ||||
|   "dependencies": { | ||||
|     "@actions/cache": "^1.0.10", | ||||
|     "@actions/core": "^1.2.6", | ||||
|     "@actions/cache": "^2.0.2", | ||||
|     "@actions/core": "^1.7.0", | ||||
|     "@actions/exec": "^1.1.1", | ||||
|     "@actions/io": "^1.1.2" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@types/jest": "^27.4.1", | ||||
|     "@types/jest": "^27.5.0", | ||||
|     "@types/nock": "^11.1.0", | ||||
|     "@types/node": "^16.11.26", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.15.0", | ||||
|     "@typescript-eslint/parser": "^5.15.0", | ||||
|     "@types/node": "^16.11.33", | ||||
|     "@typescript-eslint/eslint-plugin": "^5.22.0", | ||||
|     "@typescript-eslint/parser": "^5.22.0", | ||||
|     "@zeit/ncc": "^0.20.5", | ||||
|     "eslint": "^8.11.0", | ||||
|     "eslint": "^8.14.0", | ||||
|     "eslint-config-prettier": "^8.5.0", | ||||
|     "eslint-plugin-import": "^2.25.4", | ||||
|     "eslint-plugin-jest": "^26.1.2", | ||||
|     "eslint-plugin-import": "^2.26.0", | ||||
|     "eslint-plugin-jest": "^26.1.5", | ||||
|     "eslint-plugin-prettier": "^4.0.0", | ||||
|     "eslint-plugin-simple-import-sort": "^7.0.0", | ||||
|     "jest": "^27.5.1", | ||||
|     "jest": "^28.0.3", | ||||
|     "jest-circus": "^27.5.1", | ||||
|     "nock": "^11.7.0", | ||||
|     "prettier": "^2.6.0", | ||||
|     "ts-jest": "^27.1.3", | ||||
|     "typescript": "^3.9.9" | ||||
|     "nock": "^13.2.4", | ||||
|     "prettier": "^2.6.2", | ||||
|     "ts-jest": "^28.0.2", | ||||
|     "typescript": "^4.6.4" | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -6,10 +6,7 @@ import * as utils from "./utils/actionUtils"; | ||||
|  | ||||
| async function run(): Promise<void> { | ||||
|     try { | ||||
|         if (utils.isGhes()) { | ||||
|             utils.logWarning( | ||||
|                 "Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details" | ||||
|             ); | ||||
|         if (!utils.isCacheFeatureAvailable()) { | ||||
|             utils.setCacheHitOutput(false); | ||||
|             return; | ||||
|         } | ||||
| @ -55,16 +52,17 @@ async function run(): Promise<void> { | ||||
|             utils.setCacheHitOutput(isExactKeyMatch); | ||||
|  | ||||
|             core.info(`Cache restored from key: ${cacheKey}`); | ||||
|         } catch (error) { | ||||
|             if (error.name === cache.ValidationError.name) { | ||||
|         } catch (error: unknown) { | ||||
|             const typedError = error as Error; | ||||
|             if (typedError.name === cache.ValidationError.name) { | ||||
|                 throw error; | ||||
|             } else { | ||||
|                 utils.logWarning(error.message); | ||||
|                 utils.logWarning(typedError.message); | ||||
|                 utils.setCacheHitOutput(false); | ||||
|             } | ||||
|         } | ||||
|     } catch (error) { | ||||
|         core.setFailed(error.message); | ||||
|     } catch (error: unknown) { | ||||
|         core.setFailed((error as Error).message); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
							
								
								
									
										20
									
								
								src/save.ts
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								src/save.ts
									
									
									
									
									
								
							| @ -11,10 +11,7 @@ process.on("uncaughtException", e => utils.logWarning(e.message)); | ||||
|  | ||||
| async function run(): Promise<void> { | ||||
|     try { | ||||
|         if (utils.isGhes()) { | ||||
|             utils.logWarning( | ||||
|                 "Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details" | ||||
|             ); | ||||
|         if (!utils.isCacheFeatureAvailable()) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
| @ -52,17 +49,18 @@ async function run(): Promise<void> { | ||||
|                 uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) | ||||
|             }); | ||||
|             core.info(`Cache saved with key: ${primaryKey}`); | ||||
|         } catch (error) { | ||||
|             if (error.name === cache.ValidationError.name) { | ||||
|         } catch (error: unknown) { | ||||
|             const typedError = error as Error; | ||||
|             if (typedError.name === cache.ValidationError.name) { | ||||
|                 throw error; | ||||
|             } else if (error.name === cache.ReserveCacheError.name) { | ||||
|                 core.info(error.message); | ||||
|             } else if (typedError.name === cache.ReserveCacheError.name) { | ||||
|                 core.info(typedError.message); | ||||
|             } else { | ||||
|                 utils.logWarning(error.message); | ||||
|                 utils.logWarning(typedError.message); | ||||
|             } | ||||
|         } | ||||
|     } catch (error) { | ||||
|         utils.logWarning(error.message); | ||||
|     } catch (error: unknown) { | ||||
|         utils.logWarning((error as Error).message); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| import * as cache from "@actions/cache"; | ||||
| import * as core from "@actions/core"; | ||||
|  | ||||
| import { Outputs, RefKey, State } from "../constants"; | ||||
| @ -74,3 +75,20 @@ export function getInputAsInt( | ||||
|     } | ||||
|     return value; | ||||
| } | ||||
|  | ||||
| export function isCacheFeatureAvailable(): boolean { | ||||
|     if (!cache.isFeatureAvailable()) { | ||||
|         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." | ||||
|             ); | ||||
|         } 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 true; | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	