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 |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v2 |       - uses: actions/checkout@v3 | ||||||
|  |       - name: Setup Node.js 16.x | ||||||
|       - name: Set Node.js 12.x |         uses: actions/setup-node@v3 | ||||||
|         uses: actions/setup-node@v1 |  | ||||||
|         with: |         with: | ||||||
|           node-version: 12.x |           node-version: 16.x | ||||||
|  |  | ||||||
|       - name: Install dependencies |       - name: Install dependencies | ||||||
|         run: npm ci |         run: npm ci | ||||||
|  |  | ||||||
|       - name: Rebuild the dist/ directory |       - name: Rebuild the dist/ directory | ||||||
|         run: npm run build |         run: npm run build | ||||||
|  |  | ||||||
| @ -45,7 +42,7 @@ jobs: | |||||||
|         id: diff |         id: diff | ||||||
|  |  | ||||||
|       # If index.js was different than expected, upload the expected version as an artifact |       # 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' }} |         if: ${{ failure() && steps.diff.conclusion == 'failure' }} | ||||||
|         with: |         with: | ||||||
|           name: dist |           name: dist | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								.github/workflows/close-inactive-issues.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/close-inactive-issues.yml
									
									
									
									
										vendored
									
									
								
							| @ -12,10 +12,10 @@ jobs: | |||||||
|     steps: |     steps: | ||||||
|       - uses: actions/stale@v3 |       - uses: actions/stale@v3 | ||||||
|         with: |         with: | ||||||
|           days-before-issue-stale: 365 |           days-before-issue-stale: 200 | ||||||
|           days-before-issue-close: 5 |           days-before-issue-close: 5 | ||||||
|           stale-issue-label: "stale" |           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." |           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-stale: -1 | ||||||
|           days-before-pr-close: -1 |           days-before-pr-close: -1 | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @ -14,7 +14,7 @@ jobs: | |||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout repository |     - name: Checkout repository | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|       with: |       with: | ||||||
|         # We must fetch at least the immediate parents so that if this is |         # We must fetch at least the immediate parents so that if this is | ||||||
|         # a pull request then we can checkout the head. |         # 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 |     runs-on: ubuntu-latest | ||||||
|     name: Check licenses |     name: Check licenses | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/checkout@v2 |       - uses: actions/checkout@v3 | ||||||
|       - run: npm ci |       - run: npm ci | ||||||
|       - name: Install licensed |       - name: Install licensed | ||||||
|         run: | |         run: | | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @ -24,17 +24,17 @@ jobs: | |||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |     - name: Checkout | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|     - name: Setup Node.js |     - name: Setup Node.js 16.x | ||||||
|       uses: actions/setup-node@v1 |       uses: actions/setup-node@v3 | ||||||
|       with: |       with: | ||||||
|         node-version: '12.x' |         node-version: 16.x | ||||||
|     - name: Determine npm cache directory |     - name: Determine npm cache directory | ||||||
|       id: npm-cache |       id: npm-cache | ||||||
|       run: | |       run: | | ||||||
|         echo "::set-output name=dir::$(npm config get cache)" |         echo "::set-output name=dir::$(npm config get cache)" | ||||||
|     - name: Restore npm cache |     - name: Restore npm cache | ||||||
|       uses: actions/cache@v2 |       uses: actions/cache@v3 | ||||||
|       with: |       with: | ||||||
|         path: ${{ steps.npm-cache.outputs.dir }} |         path: ${{ steps.npm-cache.outputs.dir }} | ||||||
|         key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} |         key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} | ||||||
| @ -57,7 +57,7 @@ jobs: | |||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |     - name: Checkout | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|     - name: Generate files in working directory |     - name: Generate files in working directory | ||||||
|       shell: bash |       shell: bash | ||||||
|       run: __tests__/create-cache-files.sh ${{ runner.os }} test-cache |       run: __tests__/create-cache-files.sh ${{ runner.os }} test-cache | ||||||
| @ -80,7 +80,7 @@ jobs: | |||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |     - name: Checkout | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|     - name: Restore cache |     - name: Restore cache | ||||||
|       uses: ./ |       uses: ./ | ||||||
|       with: |       with: | ||||||
| @ -110,7 +110,7 @@ jobs: | |||||||
|       https_proxy: http://squid-proxy:3128 |       https_proxy: http://squid-proxy:3128 | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |     - name: Checkout | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|     - name: Generate files |     - name: Generate files | ||||||
|       run: __tests__/create-cache-files.sh proxy test-cache |       run: __tests__/create-cache-files.sh proxy test-cache | ||||||
|     - name: Save cache |     - name: Save cache | ||||||
| @ -133,7 +133,7 @@ jobs: | |||||||
|       https_proxy: http://squid-proxy:3128 |       https_proxy: http://squid-proxy:3128 | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout |     - name: Checkout | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|     - name: Restore cache |     - name: Restore cache | ||||||
|       uses: ./ |       uses: ./ | ||||||
|       with: |       with: | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/cache.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: "@actions/cache" | name: "@actions/cache" | ||||||
| version: 1.0.10 | version: 2.0.2 | ||||||
| type: npm | type: npm | ||||||
| summary:  | summary:  | ||||||
| homepage:  | homepage:  | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.licenses/npm/@actions/core.dep.yml
									
									
									
										generated
									
									
									
								
							| @ -1,6 +1,6 @@ | |||||||
| --- | --- | ||||||
| name: "@actions/core" | name: "@actions/core" | ||||||
| version: 1.6.0 | version: 1.7.0 | ||||||
| type: npm | type: npm | ||||||
| summary: Actions core lib | summary: Actions core lib | ||||||
| homepage: https://github.com/actions/toolkit/tree/main/packages/core | 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" | name: "@opentelemetry/api" | ||||||
| version: 1.1.0 | version: 1.0.4 | ||||||
| type: npm | type: npm | ||||||
| summary:  | summary: Public API for OpenTelemetry | ||||||
| homepage:  | homepage: https://github.com/open-telemetry/opentelemetry-js-api#readme | ||||||
| license: apache-2.0 | license: apache-2.0 | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE | - 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" | name: "@types/node" | ||||||
| version: 16.11.26 | version: 16.11.33 | ||||||
| type: npm | type: npm | ||||||
| summary:  | summary: TypeScript definitions for Node.js | ||||||
| homepage:  | homepage: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node | ||||||
| license: mit | license: mit | ||||||
| licenses: | licenses: | ||||||
| - sources: LICENSE | - 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). | 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 | ## 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. | * Added support for multiple paths, [glob patterns](https://github.com/actions/toolkit/tree/main/packages/glob), and single file caches. | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - name: Cache multiple paths | - name: Cache multiple paths | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/cache |       ~/cache | ||||||
| @ -65,11 +71,11 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|     - uses: actions/checkout@v2 |     - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|     - name: Cache Primes |     - name: Cache Primes | ||||||
|       id: cache-primes |       id: cache-primes | ||||||
|       uses: actions/cache@v2 |       uses: actions/cache@v3 | ||||||
|       with: |       with: | ||||||
|         path: prime-numbers |         path: prime-numbers | ||||||
|         key: ${{ runner.os }}-primes |         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. | 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 | ```yaml | ||||||
|   - uses: actions/cache@v2 |   - uses: actions/cache@v3 | ||||||
|     with: |     with: | ||||||
|       path: | |       path: | | ||||||
|         path/to/dependencies |         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")" |       echo "::set-output name=date::$(/bin/date -u "+%Y%m%d")" | ||||||
|     shell: bash |     shell: bash | ||||||
|  |  | ||||||
|   - uses: actions/cache@v2 |   - uses: actions/cache@v3 | ||||||
|     with: |     with: | ||||||
|       path: path/to/dependencies |       path: path/to/dependencies | ||||||
|       key: ${{ runner.os }}-${{ steps.get-date.outputs.date }}-${{ hashFiles('**/lockfiles') }} |       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: | Example: | ||||||
| ```yaml | ```yaml | ||||||
| steps: | steps: | ||||||
|   - uses: actions/checkout@v2 |   - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|   - uses: actions/cache@v2 |   - uses: actions/cache@v3 | ||||||
|     id: cache |     id: cache | ||||||
|     with: |     with: | ||||||
|       path: path/to/dependencies |       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`) | > 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 | ## 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. | 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 * as core from "@actions/core"; | ||||||
|  |  | ||||||
| import { Events, Outputs, RefKey, State } from "../src/constants"; | 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"; | import * as testUtils from "../src/utils/testUtils"; | ||||||
|  |  | ||||||
| jest.mock("@actions/core"); | jest.mock("@actions/core"); | ||||||
|  | jest.mock("@actions/cache"); | ||||||
|  |  | ||||||
| beforeAll(() => { | beforeAll(() => { | ||||||
|     jest.spyOn(core, "getInput").mockImplementation((name, options) => { |     jest.spyOn(core, "getInput").mockImplementation((name, options) => { | ||||||
| @ -232,3 +234,41 @@ test("getInputAsInt throws if required and value missing", () => { | |||||||
|         actionUtils.getInputAsInt("undefined", { required: true }) |         actionUtils.getInputAsInt("undefined", { required: true }) | ||||||
|     ).toThrowError(); |     ).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"; |     process.env[RefKey] = "refs/heads/feature-branch"; | ||||||
|  |  | ||||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); |     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); | ||||||
|  |     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||||
|  |         () => true | ||||||
|  |     ); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| afterEach(() => { | afterEach(() => { | ||||||
| @ -55,10 +58,12 @@ test("restore with invalid event outputs warning", async () => { | |||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| test("restore on GHES should no-op", async () => { | test("restore without AC available should no-op", async () => { | ||||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); |     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 restoreCacheMock = jest.spyOn(cache, "restoreCache"); | ||||||
|     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); |     const setCacheHitOutputMock = jest.spyOn(actionUtils, "setCacheHitOutput"); | ||||||
|  |  | ||||||
| @ -67,9 +72,54 @@ test("restore on GHES should no-op", async () => { | |||||||
|     expect(restoreCacheMock).toHaveBeenCalledTimes(0); |     expect(restoreCacheMock).toHaveBeenCalledTimes(0); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); |     expect(setCacheHitOutputMock).toHaveBeenCalledTimes(1); | ||||||
|     expect(setCacheHitOutputMock).toHaveBeenCalledWith(false); |     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 () => { | test("restore with no path should fail", async () => { | ||||||
|  | |||||||
| @ -54,6 +54,9 @@ beforeEach(() => { | |||||||
|     process.env[RefKey] = "refs/heads/feature-branch"; |     process.env[RefKey] = "refs/heads/feature-branch"; | ||||||
|  |  | ||||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); |     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => false); | ||||||
|  |     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||||
|  |         () => true | ||||||
|  |     ); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| afterEach(() => { | afterEach(() => { | ||||||
| @ -101,18 +104,67 @@ test("save with no primary key in state outputs warning", async () => { | |||||||
|     expect(failedMock).toHaveBeenCalledTimes(0); |     expect(failedMock).toHaveBeenCalledTimes(0); | ||||||
| }); | }); | ||||||
|  |  | ||||||
| test("save on GHES should no-op", async () => { | test("save without AC available should no-op", async () => { | ||||||
|     jest.spyOn(actionUtils, "isGhes").mockImplementation(() => true); |     jest.spyOn(actionUtils, "isCacheFeatureAvailable").mockImplementation( | ||||||
|  |         () => false | ||||||
|  |     ); | ||||||
|  |  | ||||||
|     const logWarningMock = jest.spyOn(actionUtils, "logWarning"); |  | ||||||
|     const saveCacheMock = jest.spyOn(cache, "saveCache"); |     const saveCacheMock = jest.spyOn(cache, "saveCache"); | ||||||
|  |  | ||||||
|     await run(); |     await run(); | ||||||
|  |  | ||||||
|     expect(saveCacheMock).toHaveBeenCalledTimes(0); |     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 () => { | 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; |     return value; | ||||||
| } | } | ||||||
| exports.assertDefined = assertDefined; | 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
 | //# sourceMappingURL=cacheUtils.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| @ -1405,36 +1410,7 @@ exports.default = _default; | |||||||
| /* 39 */, | /* 39 */, | ||||||
| /* 40 */, | /* 40 */, | ||||||
| /* 41 */, | /* 41 */, | ||||||
| /* 42 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 43 */, | /* 43 */, | ||||||
| /* 44 */, | /* 44 */, | ||||||
| /* 45 */, | /* 45 */, | ||||||
| @ -3221,10 +3197,7 @@ const options_1 = __webpack_require__(538); | |||||||
| const requestUtils_1 = __webpack_require__(899); | const requestUtils_1 = __webpack_require__(899); | ||||||
| const versionSalt = '1.0'; | const versionSalt = '1.0'; | ||||||
| function getCacheApiUrl(resource) { | function getCacheApiUrl(resource) { | ||||||
|     // Ideally we just use ACTIONS_CACHE_URL
 |     const baseUrl = process.env['ACTIONS_CACHE_URL'] || ''; | ||||||
|     const baseUrl = (process.env['ACTIONS_CACHE_URL'] || |  | ||||||
|         process.env['ACTIONS_RUNTIME_URL'] || |  | ||||||
|         '').replace('pipelines', 'artifactcache'); |  | ||||||
|     if (!baseUrl) { |     if (!baseUrl) { | ||||||
|         throw new Error('Cache Service Url not found, unable to restore cache.'); |         throw new Error('Cache Service Url not found, unable to restore cache.'); | ||||||
|     } |     } | ||||||
| @ -3302,18 +3275,18 @@ function downloadCache(archiveLocation, archivePath, options) { | |||||||
| exports.downloadCache = downloadCache; | exports.downloadCache = downloadCache; | ||||||
| // Reserve Cache
 | // Reserve Cache
 | ||||||
| function reserveCache(key, paths, options) { | function reserveCache(key, paths, options) { | ||||||
|     var _a, _b; |  | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const httpClient = createHttpClient(); |         const httpClient = createHttpClient(); | ||||||
|         const version = getCacheVersion(paths, options === null || options === void 0 ? void 0 : options.compressionMethod); |         const version = getCacheVersion(paths, options === null || options === void 0 ? void 0 : options.compressionMethod); | ||||||
|         const reserveCacheRequest = { |         const reserveCacheRequest = { | ||||||
|             key, |             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* () { |         const response = yield requestUtils_1.retryTypedResponse('reserveCache', () => __awaiter(this, void 0, void 0, function* () { | ||||||
|             return httpClient.postJson(getCacheApiUrl('caches'), reserveCacheRequest); |             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; | exports.reserveCache = reserveCache; | ||||||
| @ -4470,7 +4443,7 @@ var NoopTracer_1 = __webpack_require__(151); | |||||||
| var NoopTracerProvider = /** @class */ (function () { | var NoopTracerProvider = /** @class */ (function () { | ||||||
|     function NoopTracerProvider() { |     function NoopTracerProvider() { | ||||||
|     } |     } | ||||||
|     NoopTracerProvider.prototype.getTracer = function (_name, _version, _options) { |     NoopTracerProvider.prototype.getTracer = function (_name, _version) { | ||||||
|         return new NoopTracer_1.NoopTracer(); |         return new NoopTracer_1.NoopTracer(); | ||||||
|     }; |     }; | ||||||
|     return NoopTracerProvider; |     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
 |             // 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
 |             // 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 downloadProgress = new DownloadProgress(contentLength); | ||||||
|             const fd = fs.openSync(archivePath, 'w'); |             const fd = fs.openSync(archivePath, 'w'); | ||||||
|             try { |             try { | ||||||
| @ -36293,9 +36267,9 @@ var ProxyTracerProvider = /** @class */ (function () { | |||||||
|     /** |     /** | ||||||
|      * Get a {@link ProxyTracer} |      * Get a {@link ProxyTracer} | ||||||
|      */ |      */ | ||||||
|     ProxyTracerProvider.prototype.getTracer = function (name, version, options) { |     ProxyTracerProvider.prototype.getTracer = function (name, version) { | ||||||
|         var _a; |         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 () { |     ProxyTracerProvider.prototype.getDelegate = function () { | ||||||
|         var _a; |         var _a; | ||||||
| @ -36307,9 +36281,9 @@ var ProxyTracerProvider = /** @class */ (function () { | |||||||
|     ProxyTracerProvider.prototype.setDelegate = function (delegate) { |     ProxyTracerProvider.prototype.setDelegate = function (delegate) { | ||||||
|         this._delegate = delegate; |         this._delegate = delegate; | ||||||
|     }; |     }; | ||||||
|     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version, options) { |     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version) { | ||||||
|         var _a; |         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; |     return ProxyTracerProvider; | ||||||
| }()); | }()); | ||||||
| @ -36348,11 +36322,10 @@ var NOOP_TRACER = new NoopTracer_1.NoopTracer(); | |||||||
|  * Proxy tracer provided by the proxy tracer provider |  * Proxy tracer provided by the proxy tracer provider | ||||||
|  */ |  */ | ||||||
| var ProxyTracer = /** @class */ (function () { | var ProxyTracer = /** @class */ (function () { | ||||||
|     function ProxyTracer(_provider, name, version, options) { |     function ProxyTracer(_provider, name, version) { | ||||||
|         this._provider = _provider; |         this._provider = _provider; | ||||||
|         this.name = name; |         this.name = name; | ||||||
|         this.version = version; |         this.version = version; | ||||||
|         this.options = options; |  | ||||||
|     } |     } | ||||||
|     ProxyTracer.prototype.startSpan = function (name, options, context) { |     ProxyTracer.prototype.startSpan = function (name, options, context) { | ||||||
|         return this._getTracer().startSpan(name, options, context); |         return this._getTracer().startSpan(name, options, context); | ||||||
| @ -36369,7 +36342,7 @@ var ProxyTracer = /** @class */ (function () { | |||||||
|         if (this._delegate) { |         if (this._delegate) { | ||||||
|             return 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) { |         if (!tracer) { | ||||||
|             return NOOP_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); |     for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | 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); | __exportStar(__webpack_require__(880), exports); | ||||||
| var utils_1 = __webpack_require__(112); | var utils_1 = __webpack_require__(112); | ||||||
| Object.defineProperty(exports, "baggageEntryMetadataFromString", { enumerable: true, get: function () { return utils_1.baggageEntryMetadataFromString; } }); | Object.defineProperty(exports, "baggageEntryMetadataFromString", { enumerable: true, get: function () { return utils_1.baggageEntryMetadataFromString; } }); | ||||||
| __exportStar(__webpack_require__(452), exports); | __exportStar(__webpack_require__(452), exports); | ||||||
| __exportStar(__webpack_require__(158), exports); | __exportStar(__webpack_require__(158), exports); | ||||||
| __exportStar(__webpack_require__(907), exports); |  | ||||||
| __exportStar(__webpack_require__(893), exports); | __exportStar(__webpack_require__(893), exports); | ||||||
| __exportStar(__webpack_require__(881), exports); | __exportStar(__webpack_require__(881), exports); | ||||||
| __exportStar(__webpack_require__(906), exports); | __exportStar(__webpack_require__(906), exports); | ||||||
| @ -37391,11 +37363,8 @@ __exportStar(__webpack_require__(220), exports); | |||||||
| __exportStar(__webpack_require__(932), exports); | __exportStar(__webpack_require__(932), exports); | ||||||
| __exportStar(__webpack_require__(975), exports); | __exportStar(__webpack_require__(975), exports); | ||||||
| __exportStar(__webpack_require__(207), 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__(694), exports); | ||||||
| __exportStar(__webpack_require__(695), exports); | __exportStar(__webpack_require__(695), exports); | ||||||
| __exportStar(__webpack_require__(743), exports); |  | ||||||
| var spancontext_utils_1 = __webpack_require__(629); | var spancontext_utils_1 = __webpack_require__(629); | ||||||
| Object.defineProperty(exports, "isSpanContextValid", { enumerable: true, get: function () { return spancontext_utils_1.isSpanContextValid; } }); | 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; } }); | 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) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     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) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -37454,12 +37427,13 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     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); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | 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 core = __importStar(__webpack_require__(470)); | ||||||
| const constants_1 = __webpack_require__(196); | const constants_1 = __webpack_require__(196); | ||||||
| function isGhes() { | function isGhes() { | ||||||
| @ -37524,6 +37498,19 @@ function getInputAsInt(name, options) { | |||||||
|     return value; |     return value; | ||||||
| } | } | ||||||
| exports.getInputAsInt = getInputAsInt; | 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; | 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
 | //# 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 */, | /* 549 */, | ||||||
| /* 550 */, | /* 550 */, | ||||||
| /* 551 */, | /* 551 */, | ||||||
| @ -42117,58 +42393,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | |||||||
| /* 587 */, | /* 587 */, | ||||||
| /* 588 */, | /* 588 */, | ||||||
| /* 589 */, | /* 589 */, | ||||||
| /* 590 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 591 */, | /* 591 */, | ||||||
| /* 592 */, | /* 592 */, | ||||||
| /* 593 */, | /* 593 */, | ||||||
| @ -46439,6 +46664,15 @@ function checkKey(key) { | |||||||
|         throw new ValidationError(`Key Validation Error: ${key} cannot contain commas.`); |         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 |  * 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 |  * @returns number returns cacheId if the cache was saved successfully and throws an error if save fails | ||||||
|  */ |  */ | ||||||
| function saveCache(paths, key, options) { | function saveCache(paths, key, options) { | ||||||
|  |     var _a, _b, _c, _d, _e; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         checkPaths(paths); |         checkPaths(paths); | ||||||
|         checkKey(key); |         checkKey(key); | ||||||
|         const compressionMethod = yield utils.getCompressionMethod(); |         const compressionMethod = yield utils.getCompressionMethod(); | ||||||
|         core.debug('Reserving Cache'); |         let cacheId = null; | ||||||
|         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}`); |  | ||||||
|         const cachePaths = yield utils.resolvePaths(paths); |         const cachePaths = yield utils.resolvePaths(paths); | ||||||
|         core.debug('Cache Paths:'); |         core.debug('Cache Paths:'); | ||||||
|         core.debug(`${JSON.stringify(cachePaths)}`); |         core.debug(`${JSON.stringify(cachePaths)}`); | ||||||
| @ -46531,9 +46759,24 @@ function saveCache(paths, key, options) { | |||||||
|             const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit
 |             const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit
 | ||||||
|             const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); |             const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); | ||||||
|             core.debug(`File Size: ${archiveFileSize}`); |             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.`); |                 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})`); |             core.debug(`Saving Cache (ID: ${cacheId})`); | ||||||
|             yield cacheHttpClient.saveCache(cacheId, archivePath, options); |             yield cacheHttpClient.saveCache(cacheId, archivePath, options); | ||||||
|         } |         } | ||||||
| @ -47220,30 +47463,7 @@ exports.OidcClient = OidcClient; | |||||||
| //# sourceMappingURL=oidc-utils.js.map
 | //# sourceMappingURL=oidc-utils.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| /* 743 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 744 */, | /* 744 */, | ||||||
| /* 745 */, | /* 745 */, | ||||||
| /* 746 */, | /* 746 */, | ||||||
| @ -47340,117 +47560,7 @@ function async(callback) | |||||||
| /* 753 */, | /* 753 */, | ||||||
| /* 754 */, | /* 754 */, | ||||||
| /* 755 */, | /* 755 */, | ||||||
| /* 756 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 757 */, | /* 757 */, | ||||||
| /* 758 */, | /* 758 */, | ||||||
| /* 759 */, | /* 759 */, | ||||||
| @ -48066,7 +48176,11 @@ module.exports = function(dst, src) { | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     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) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -48079,7 +48193,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     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); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -48100,8 +48214,7 @@ const utils = __importStar(__webpack_require__(443)); | |||||||
| function run() { | function run() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         try { |         try { | ||||||
|             if (utils.isGhes()) { |             if (!utils.isCacheFeatureAvailable()) { | ||||||
|                 utils.logWarning("Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details"); |  | ||||||
|                 utils.setCacheHitOutput(false); |                 utils.setCacheHitOutput(false); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @ -48132,11 +48245,12 @@ function run() { | |||||||
|                 core.info(`Cache restored from key: ${cacheKey}`); |                 core.info(`Cache restored from key: ${cacheKey}`); | ||||||
|             } |             } | ||||||
|             catch (error) { |             catch (error) { | ||||||
|                 if (error.name === cache.ValidationError.name) { |                 const typedError = error; | ||||||
|  |                 if (typedError.name === cache.ValidationError.name) { | ||||||
|                     throw error; |                     throw error; | ||||||
|                 } |                 } | ||||||
|                 else { |                 else { | ||||||
|                     utils.logWarning(error.message); |                     utils.logWarning(typedError.message); | ||||||
|                     utils.setCacheHitOutput(false); |                     utils.setCacheHitOutput(false); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -49634,7 +49748,7 @@ module.exports = v4; | |||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.VERSION = void 0; | exports.VERSION = void 0; | ||||||
| // this is autogenerated file, see scripts/version-update.js
 | // this is autogenerated file, see scripts/version-update.js
 | ||||||
| exports.VERSION = '1.1.0'; | exports.VERSION = '1.0.4'; | ||||||
| //# sourceMappingURL=version.js.map
 | //# sourceMappingURL=version.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| @ -51766,7 +51880,8 @@ function retryTypedResponse(name, method, maxAttempts = constants_1.DefaultRetry | |||||||
|                 return { |                 return { | ||||||
|                     statusCode: error.statusCode, |                     statusCode: error.statusCode, | ||||||
|                     result: null, |                     result: null, | ||||||
|                     headers: {} |                     headers: {}, | ||||||
|  |                     error | ||||||
|                 }; |                 }; | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
| @ -51857,30 +51972,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | |||||||
| //# sourceMappingURL=attributes.js.map
 | //# sourceMappingURL=attributes.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| /* 907 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 908 */, | /* 908 */, | ||||||
| /* 909 */, | /* 909 */, | ||||||
| /* 910 */ | /* 910 */ | ||||||
|  | |||||||
							
								
								
									
										662
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										662
									
								
								dist/save/index.js
									
									
									
									
										vendored
									
									
								
							| @ -1199,6 +1199,11 @@ function assertDefined(name, value) { | |||||||
|     return value; |     return value; | ||||||
| } | } | ||||||
| exports.assertDefined = assertDefined; | 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
 | //# sourceMappingURL=cacheUtils.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| @ -1405,36 +1410,7 @@ exports.default = _default; | |||||||
| /* 39 */, | /* 39 */, | ||||||
| /* 40 */, | /* 40 */, | ||||||
| /* 41 */, | /* 41 */, | ||||||
| /* 42 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 43 */, | /* 43 */, | ||||||
| /* 44 */, | /* 44 */, | ||||||
| /* 45 */, | /* 45 */, | ||||||
| @ -3221,10 +3197,7 @@ const options_1 = __webpack_require__(538); | |||||||
| const requestUtils_1 = __webpack_require__(899); | const requestUtils_1 = __webpack_require__(899); | ||||||
| const versionSalt = '1.0'; | const versionSalt = '1.0'; | ||||||
| function getCacheApiUrl(resource) { | function getCacheApiUrl(resource) { | ||||||
|     // Ideally we just use ACTIONS_CACHE_URL
 |     const baseUrl = process.env['ACTIONS_CACHE_URL'] || ''; | ||||||
|     const baseUrl = (process.env['ACTIONS_CACHE_URL'] || |  | ||||||
|         process.env['ACTIONS_RUNTIME_URL'] || |  | ||||||
|         '').replace('pipelines', 'artifactcache'); |  | ||||||
|     if (!baseUrl) { |     if (!baseUrl) { | ||||||
|         throw new Error('Cache Service Url not found, unable to restore cache.'); |         throw new Error('Cache Service Url not found, unable to restore cache.'); | ||||||
|     } |     } | ||||||
| @ -3302,18 +3275,18 @@ function downloadCache(archiveLocation, archivePath, options) { | |||||||
| exports.downloadCache = downloadCache; | exports.downloadCache = downloadCache; | ||||||
| // Reserve Cache
 | // Reserve Cache
 | ||||||
| function reserveCache(key, paths, options) { | function reserveCache(key, paths, options) { | ||||||
|     var _a, _b; |  | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         const httpClient = createHttpClient(); |         const httpClient = createHttpClient(); | ||||||
|         const version = getCacheVersion(paths, options === null || options === void 0 ? void 0 : options.compressionMethod); |         const version = getCacheVersion(paths, options === null || options === void 0 ? void 0 : options.compressionMethod); | ||||||
|         const reserveCacheRequest = { |         const reserveCacheRequest = { | ||||||
|             key, |             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* () { |         const response = yield requestUtils_1.retryTypedResponse('reserveCache', () => __awaiter(this, void 0, void 0, function* () { | ||||||
|             return httpClient.postJson(getCacheApiUrl('caches'), reserveCacheRequest); |             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; | exports.reserveCache = reserveCache; | ||||||
| @ -4470,7 +4443,7 @@ var NoopTracer_1 = __webpack_require__(151); | |||||||
| var NoopTracerProvider = /** @class */ (function () { | var NoopTracerProvider = /** @class */ (function () { | ||||||
|     function NoopTracerProvider() { |     function NoopTracerProvider() { | ||||||
|     } |     } | ||||||
|     NoopTracerProvider.prototype.getTracer = function (_name, _version, _options) { |     NoopTracerProvider.prototype.getTracer = function (_name, _version) { | ||||||
|         return new NoopTracer_1.NoopTracer(); |         return new NoopTracer_1.NoopTracer(); | ||||||
|     }; |     }; | ||||||
|     return NoopTracerProvider; |     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
 |             // 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
 |             // 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 downloadProgress = new DownloadProgress(contentLength); | ||||||
|             const fd = fs.openSync(archivePath, 'w'); |             const fd = fs.openSync(archivePath, 'w'); | ||||||
|             try { |             try { | ||||||
| @ -36293,9 +36267,9 @@ var ProxyTracerProvider = /** @class */ (function () { | |||||||
|     /** |     /** | ||||||
|      * Get a {@link ProxyTracer} |      * Get a {@link ProxyTracer} | ||||||
|      */ |      */ | ||||||
|     ProxyTracerProvider.prototype.getTracer = function (name, version, options) { |     ProxyTracerProvider.prototype.getTracer = function (name, version) { | ||||||
|         var _a; |         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 () { |     ProxyTracerProvider.prototype.getDelegate = function () { | ||||||
|         var _a; |         var _a; | ||||||
| @ -36307,9 +36281,9 @@ var ProxyTracerProvider = /** @class */ (function () { | |||||||
|     ProxyTracerProvider.prototype.setDelegate = function (delegate) { |     ProxyTracerProvider.prototype.setDelegate = function (delegate) { | ||||||
|         this._delegate = delegate; |         this._delegate = delegate; | ||||||
|     }; |     }; | ||||||
|     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version, options) { |     ProxyTracerProvider.prototype.getDelegateTracer = function (name, version) { | ||||||
|         var _a; |         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; |     return ProxyTracerProvider; | ||||||
| }()); | }()); | ||||||
| @ -36348,11 +36322,10 @@ var NOOP_TRACER = new NoopTracer_1.NoopTracer(); | |||||||
|  * Proxy tracer provided by the proxy tracer provider |  * Proxy tracer provided by the proxy tracer provider | ||||||
|  */ |  */ | ||||||
| var ProxyTracer = /** @class */ (function () { | var ProxyTracer = /** @class */ (function () { | ||||||
|     function ProxyTracer(_provider, name, version, options) { |     function ProxyTracer(_provider, name, version) { | ||||||
|         this._provider = _provider; |         this._provider = _provider; | ||||||
|         this.name = name; |         this.name = name; | ||||||
|         this.version = version; |         this.version = version; | ||||||
|         this.options = options; |  | ||||||
|     } |     } | ||||||
|     ProxyTracer.prototype.startSpan = function (name, options, context) { |     ProxyTracer.prototype.startSpan = function (name, options, context) { | ||||||
|         return this._getTracer().startSpan(name, options, context); |         return this._getTracer().startSpan(name, options, context); | ||||||
| @ -36369,7 +36342,7 @@ var ProxyTracer = /** @class */ (function () { | |||||||
|         if (this._delegate) { |         if (this._delegate) { | ||||||
|             return 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) { |         if (!tracer) { | ||||||
|             return NOOP_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); |     for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p); | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | 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); | __exportStar(__webpack_require__(880), exports); | ||||||
| var utils_1 = __webpack_require__(112); | var utils_1 = __webpack_require__(112); | ||||||
| Object.defineProperty(exports, "baggageEntryMetadataFromString", { enumerable: true, get: function () { return utils_1.baggageEntryMetadataFromString; } }); | Object.defineProperty(exports, "baggageEntryMetadataFromString", { enumerable: true, get: function () { return utils_1.baggageEntryMetadataFromString; } }); | ||||||
| __exportStar(__webpack_require__(452), exports); | __exportStar(__webpack_require__(452), exports); | ||||||
| __exportStar(__webpack_require__(158), exports); | __exportStar(__webpack_require__(158), exports); | ||||||
| __exportStar(__webpack_require__(907), exports); |  | ||||||
| __exportStar(__webpack_require__(893), exports); | __exportStar(__webpack_require__(893), exports); | ||||||
| __exportStar(__webpack_require__(881), exports); | __exportStar(__webpack_require__(881), exports); | ||||||
| __exportStar(__webpack_require__(906), exports); | __exportStar(__webpack_require__(906), exports); | ||||||
| @ -37391,11 +37363,8 @@ __exportStar(__webpack_require__(220), exports); | |||||||
| __exportStar(__webpack_require__(932), exports); | __exportStar(__webpack_require__(932), exports); | ||||||
| __exportStar(__webpack_require__(975), exports); | __exportStar(__webpack_require__(975), exports); | ||||||
| __exportStar(__webpack_require__(207), 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__(694), exports); | ||||||
| __exportStar(__webpack_require__(695), exports); | __exportStar(__webpack_require__(695), exports); | ||||||
| __exportStar(__webpack_require__(743), exports); |  | ||||||
| var spancontext_utils_1 = __webpack_require__(629); | var spancontext_utils_1 = __webpack_require__(629); | ||||||
| Object.defineProperty(exports, "isSpanContextValid", { enumerable: true, get: function () { return spancontext_utils_1.isSpanContextValid; } }); | 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; } }); | 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) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     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) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -37454,12 +37427,13 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     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); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | 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 core = __importStar(__webpack_require__(470)); | ||||||
| const constants_1 = __webpack_require__(196); | const constants_1 = __webpack_require__(196); | ||||||
| function isGhes() { | function isGhes() { | ||||||
| @ -37524,6 +37498,19 @@ function getInputAsInt(name, options) { | |||||||
|     return value; |     return value; | ||||||
| } | } | ||||||
| exports.getInputAsInt = getInputAsInt; | 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; | 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
 | //# 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 */, | /* 549 */, | ||||||
| /* 550 */, | /* 550 */, | ||||||
| /* 551 */, | /* 551 */, | ||||||
| @ -42117,58 +42393,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | |||||||
| /* 587 */, | /* 587 */, | ||||||
| /* 588 */, | /* 588 */, | ||||||
| /* 589 */, | /* 589 */, | ||||||
| /* 590 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 591 */, | /* 591 */, | ||||||
| /* 592 */, | /* 592 */, | ||||||
| /* 593 */, | /* 593 */, | ||||||
| @ -46350,7 +46575,11 @@ exports.default = _default; | |||||||
| 
 | 
 | ||||||
| var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     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) { | }) : (function(o, m, k, k2) { | ||||||
|     if (k2 === undefined) k2 = k; |     if (k2 === undefined) k2 = k; | ||||||
|     o[k2] = m[k]; |     o[k2] = m[k]; | ||||||
| @ -46363,7 +46592,7 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? ( | |||||||
| var __importStar = (this && this.__importStar) || function (mod) { | var __importStar = (this && this.__importStar) || function (mod) { | ||||||
|     if (mod && mod.__esModule) return mod; |     if (mod && mod.__esModule) return mod; | ||||||
|     var result = {}; |     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); |     __setModuleDefault(result, mod); | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -46388,8 +46617,7 @@ process.on("uncaughtException", e => utils.logWarning(e.message)); | |||||||
| function run() { | function run() { | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         try { |         try { | ||||||
|             if (utils.isGhes()) { |             if (!utils.isCacheFeatureAvailable()) { | ||||||
|                 utils.logWarning("Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details"); |  | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!utils.isValidEvent()) { |             if (!utils.isValidEvent()) { | ||||||
| @ -46417,14 +46645,15 @@ function run() { | |||||||
|                 core.info(`Cache saved with key: ${primaryKey}`); |                 core.info(`Cache saved with key: ${primaryKey}`); | ||||||
|             } |             } | ||||||
|             catch (error) { |             catch (error) { | ||||||
|                 if (error.name === cache.ValidationError.name) { |                 const typedError = error; | ||||||
|  |                 if (typedError.name === cache.ValidationError.name) { | ||||||
|                     throw error; |                     throw error; | ||||||
|                 } |                 } | ||||||
|                 else if (error.name === cache.ReserveCacheError.name) { |                 else if (typedError.name === cache.ReserveCacheError.name) { | ||||||
|                     core.info(error.message); |                     core.info(typedError.message); | ||||||
|                 } |                 } | ||||||
|                 else { |                 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.`); |         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 |  * 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 |  * @returns number returns cacheId if the cache was saved successfully and throws an error if save fails | ||||||
|  */ |  */ | ||||||
| function saveCache(paths, key, options) { | function saveCache(paths, key, options) { | ||||||
|  |     var _a, _b, _c, _d, _e; | ||||||
|     return __awaiter(this, void 0, void 0, function* () { |     return __awaiter(this, void 0, void 0, function* () { | ||||||
|         checkPaths(paths); |         checkPaths(paths); | ||||||
|         checkKey(key); |         checkKey(key); | ||||||
|         const compressionMethod = yield utils.getCompressionMethod(); |         const compressionMethod = yield utils.getCompressionMethod(); | ||||||
|         core.debug('Reserving Cache'); |         let cacheId = null; | ||||||
|         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}`); |  | ||||||
|         const cachePaths = yield utils.resolvePaths(paths); |         const cachePaths = yield utils.resolvePaths(paths); | ||||||
|         core.debug('Cache Paths:'); |         core.debug('Cache Paths:'); | ||||||
|         core.debug(`${JSON.stringify(cachePaths)}`); |         core.debug(`${JSON.stringify(cachePaths)}`); | ||||||
| @ -46625,9 +46857,24 @@ function saveCache(paths, key, options) { | |||||||
|             const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit
 |             const fileSizeLimit = 10 * 1024 * 1024 * 1024; // 10GB per repo limit
 | ||||||
|             const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); |             const archiveFileSize = utils.getArchiveFileSizeInBytes(archivePath); | ||||||
|             core.debug(`File Size: ${archiveFileSize}`); |             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.`); |                 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})`); |             core.debug(`Saving Cache (ID: ${cacheId})`); | ||||||
|             yield cacheHttpClient.saveCache(cacheId, archivePath, options); |             yield cacheHttpClient.saveCache(cacheId, archivePath, options); | ||||||
|         } |         } | ||||||
| @ -47314,30 +47561,7 @@ exports.OidcClient = OidcClient; | |||||||
| //# sourceMappingURL=oidc-utils.js.map
 | //# sourceMappingURL=oidc-utils.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| /* 743 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 744 */, | /* 744 */, | ||||||
| /* 745 */, | /* 745 */, | ||||||
| /* 746 */, | /* 746 */, | ||||||
| @ -47434,117 +47658,7 @@ function async(callback) | |||||||
| /* 753 */, | /* 753 */, | ||||||
| /* 754 */, | /* 754 */, | ||||||
| /* 755 */, | /* 755 */, | ||||||
| /* 756 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 757 */, | /* 757 */, | ||||||
| /* 758 */, | /* 758 */, | ||||||
| /* 759 */, | /* 759 */, | ||||||
| @ -49637,7 +49751,7 @@ module.exports = v4; | |||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.VERSION = void 0; | exports.VERSION = void 0; | ||||||
| // this is autogenerated file, see scripts/version-update.js
 | // this is autogenerated file, see scripts/version-update.js
 | ||||||
| exports.VERSION = '1.1.0'; | exports.VERSION = '1.0.4'; | ||||||
| //# sourceMappingURL=version.js.map
 | //# sourceMappingURL=version.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| @ -51769,7 +51883,8 @@ function retryTypedResponse(name, method, maxAttempts = constants_1.DefaultRetry | |||||||
|                 return { |                 return { | ||||||
|                     statusCode: error.statusCode, |                     statusCode: error.statusCode, | ||||||
|                     result: null, |                     result: null, | ||||||
|                     headers: {} |                     headers: {}, | ||||||
|  |                     error | ||||||
|                 }; |                 }; | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
| @ -51860,30 +51975,7 @@ Object.defineProperty(exports, "__esModule", { value: true }); | |||||||
| //# sourceMappingURL=attributes.js.map
 | //# sourceMappingURL=attributes.js.map
 | ||||||
| 
 | 
 | ||||||
| /***/ }), | /***/ }), | ||||||
| /* 907 */ | /* 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
 |  | ||||||
| 
 |  | ||||||
| /***/ }), |  | ||||||
| /* 908 */, | /* 908 */, | ||||||
| /* 909 */, | /* 909 */, | ||||||
| /* 910 */ | /* 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): | Using [NuGet lock files](https://docs.microsoft.com/nuget/consume-packages/package-references-in-project-files#locking-dependencies): | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~/.nuget/packages |     path: ~/.nuget/packages | ||||||
|     key: ${{ runner.os }}-nuget-${{ hashFiles('**/packages.lock.json') }} |     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. | 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 | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.nuget/packages |       ~/.nuget/packages | ||||||
| @ -74,7 +74,7 @@ Or you could move the cache folder like below. | |||||||
| env: | env: | ||||||
|   NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages |   NUGET_PACKAGES: ${{ github.workspace }}/.nuget/packages | ||||||
| steps: | steps: | ||||||
|   - uses: actions/cache@v2 |   - uses: actions/cache@v3 | ||||||
|     with: |     with: | ||||||
|       path: ${{ github.workspace }}/.nuget/packages |       path: ${{ github.workspace }}/.nuget/packages | ||||||
|       key: ${{ runner.os }}-nuget-${{ hashFiles('**/packages.lock.json') }} |       key: ${{ runner.os }}-nuget-${{ hashFiles('**/packages.lock.json') }} | ||||||
| @ -87,7 +87,7 @@ steps: | |||||||
| ### POSIX | ### POSIX | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~/.dub |     path: ~/.dub | ||||||
|     key: ${{ runner.os }}-dub-${{ hashFiles('**/dub.json') }} |     key: ${{ runner.os }}-dub-${{ hashFiles('**/dub.json') }} | ||||||
| @ -98,7 +98,7 @@ steps: | |||||||
| ### Windows | ### Windows | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~\AppData\Local\dub |     path: ~\AppData\Local\dub | ||||||
|     key: ${{ runner.os }}-dub-${{ hashFiles('**/dub.json') }} |     key: ${{ runner.os }}-dub-${{ hashFiles('**/dub.json') }} | ||||||
| @ -111,7 +111,7 @@ steps: | |||||||
| ### Linux | ### Linux | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.deno |       ~/.deno | ||||||
| @ -122,7 +122,7 @@ steps: | |||||||
| ### macOS | ### macOS | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.deno |       ~/.deno | ||||||
| @ -133,7 +133,7 @@ steps: | |||||||
| ### Windows | ### Windows | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~\.deno |       ~\.deno | ||||||
| @ -145,7 +145,7 @@ steps: | |||||||
| ## Elixir - Mix | ## Elixir - Mix | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       deps |       deps | ||||||
| @ -160,7 +160,7 @@ steps: | |||||||
| ### Linux | ### Linux | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.cache/go-build |       ~/.cache/go-build | ||||||
| @ -173,7 +173,7 @@ steps: | |||||||
| ### macOS | ### macOS | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/Library/Caches/go-build |       ~/Library/Caches/go-build | ||||||
| @ -186,7 +186,7 @@ steps: | |||||||
| ### Windows | ### Windows | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~\AppData\Local\go-build |       ~\AppData\Local\go-build | ||||||
| @ -202,7 +202,7 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | |||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - name: Cache ~/.cabal/packages, ~/.cabal/store and dist-newstyle | - name: Cache ~/.cabal/packages, ~/.cabal/store and dist-newstyle | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.cabal/packages |       ~/.cabal/packages | ||||||
| @ -215,14 +215,14 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | |||||||
| ## Haskell - Stack | ## Haskell - Stack | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   name: Cache ~/.stack |   name: Cache ~/.stack | ||||||
|   with: |   with: | ||||||
|     path: ~/.stack |     path: ~/.stack | ||||||
|     key: ${{ runner.os }}-stack-global-${{ hashFiles('stack.yaml') }}-${{ hashFiles('package.yaml') }} |     key: ${{ runner.os }}-stack-global-${{ hashFiles('stack.yaml') }}-${{ hashFiles('package.yaml') }} | ||||||
|     restore-keys: | |     restore-keys: | | ||||||
|       ${{ runner.os }}-stack-global- |       ${{ runner.os }}-stack-global- | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   name: Cache .stack-work |   name: Cache .stack-work | ||||||
|   with: |   with: | ||||||
|     path: .stack-work |     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. | >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 | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.gradle/caches |       ~/.gradle/caches | ||||||
| @ -250,7 +250,7 @@ We cache the elements of the Cabal store separately, as the entirety of `~/.caba | |||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - name: Cache local Maven repository | - name: Cache local Maven repository | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~/.m2/repository |     path: ~/.m2/repository | ||||||
|     key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} |     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 | ### macOS and Ubuntu | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~/.npm |     path: ~/.npm | ||||||
|     key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} |     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 |   id: npm-cache | ||||||
|   run: | |   run: | | ||||||
|     echo "::set-output name=dir::$(npm config get cache)" |     echo "::set-output name=dir::$(npm config get cache)" | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ${{ steps.npm-cache.outputs.dir }} |     path: ${{ steps.npm-cache.outputs.dir }} | ||||||
|     key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }} |     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 |   id: npm-cache-dir | ||||||
|   run: | |   run: | | ||||||
|     echo "::set-output name=dir::$(npm config get cache)" |     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' |   id: npm-cache # use this to check for `cache-hit` ==> if: steps.npm-cache.outputs.cache-hit != 'true' | ||||||
|   with: |   with: | ||||||
|     path: ${{ steps.npm-cache-dir.outputs.dir }} |     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 | ```yaml | ||||||
| - name: restore lerna | - name: restore lerna | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: **/node_modules |     path: **/node_modules | ||||||
|     key: ${{ runner.os }}-${{ hashFiles('**/yarn.lock') }} |     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 |   id: yarn-cache-dir-path | ||||||
|   run: echo "::set-output name=dir::$(yarn cache dir)" |   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'`) |   id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | ||||||
|   with: |   with: | ||||||
|     path: ${{ steps.yarn-cache-dir-path.outputs.dir }} |     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 |   id: yarn-cache-dir-path | ||||||
|   run: echo "::set-output name=dir::$(yarn config get cacheFolder)" |   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'`) |   id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`) | ||||||
|   with: |   with: | ||||||
|     path: ${{ steps.yarn-cache-dir-path.outputs.dir }} |     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 | ```yaml | ||||||
|     - name: Restore Cache |     - name: Restore Cache | ||||||
|       id: restore-cache |       id: restore-cache | ||||||
|       uses: actions/cache@v2 |       uses: actions/cache@v3 | ||||||
|       with: |       with: | ||||||
|         path: _export |         path: _export | ||||||
|         key:  ${{ runner.os }}-esy-${{ hashFiles('esy.lock/index.json') }} |         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 |   id: composer-cache | ||||||
|   run: | |   run: | | ||||||
|     echo "::set-output name=dir::$(composer config cache-files-dir)" |     echo "::set-output name=dir::$(composer config cache-files-dir)" | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ${{ steps.composer-cache.outputs.dir }} |     path: ${{ steps.composer-cache.outputs.dir }} | ||||||
|     key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} |     key: ${{ runner.os }}-composer-${{ hashFiles('**/composer.lock') }} | ||||||
| @ -409,7 +409,7 @@ Locations: | |||||||
| ### Simple example | ### Simple example | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~/.cache/pip |     path: ~/.cache/pip | ||||||
|     key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} |     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 | ### Multiple OS's in a workflow | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   if: startsWith(runner.os, 'Linux') |   if: startsWith(runner.os, 'Linux') | ||||||
|   with: |   with: | ||||||
|     path: ~/.cache/pip |     path: ~/.cache/pip | ||||||
| @ -430,7 +430,7 @@ Replace `~/.cache/pip` with the correct `path` if not using Ubuntu. | |||||||
|     restore-keys: | |     restore-keys: | | ||||||
|       ${{ runner.os }}-pip- |       ${{ runner.os }}-pip- | ||||||
|  |  | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   if: startsWith(runner.os, 'macOS') |   if: startsWith(runner.os, 'macOS') | ||||||
|   with: |   with: | ||||||
|     path: ~/Library/Caches/pip |     path: ~/Library/Caches/pip | ||||||
| @ -438,7 +438,7 @@ Replace `~/.cache/pip` with the correct `path` if not using Ubuntu. | |||||||
|     restore-keys: | |     restore-keys: | | ||||||
|       ${{ runner.os }}-pip- |       ${{ runner.os }}-pip- | ||||||
|  |  | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   if: startsWith(runner.os, 'Windows') |   if: startsWith(runner.os, 'Windows') | ||||||
|   with: |   with: | ||||||
|     path: ~\AppData\Local\pip\Cache |     path: ~\AppData\Local\pip\Cache | ||||||
| @ -464,7 +464,7 @@ jobs: | |||||||
|         - os: windows-latest |         - os: windows-latest | ||||||
|           path: ~\AppData\Local\pip\Cache |           path: ~\AppData\Local\pip\Cache | ||||||
|     steps: |     steps: | ||||||
|     - uses: actions/cache@v2 |     - uses: actions/cache@v3 | ||||||
|       with: |       with: | ||||||
|         path: ${{ matrix.path }} |         path: ${{ matrix.path }} | ||||||
|         key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} |         key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} | ||||||
| @ -482,7 +482,7 @@ jobs: | |||||||
|     echo "::set-output name=dir::$(pip cache dir)" |     echo "::set-output name=dir::$(pip cache dir)" | ||||||
|  |  | ||||||
| - name: pip cache | - name: pip cache | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ${{ steps.pip-cache.outputs.dir }} |     path: ${{ steps.pip-cache.outputs.dir }} | ||||||
|     key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} |     key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }} | ||||||
| @ -500,7 +500,7 @@ jobs: | |||||||
|  |  | ||||||
|   ⋮ |   ⋮ | ||||||
|  |  | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ~/.local/share/virtualenvs |     path: ~/.local/share/virtualenvs | ||||||
|     key: ${{ runner.os }}-python-${{ steps.setup-python.outputs.python-version }}-pipenv-${{ hashFiles('Pipfile.lock') }} |     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 = "") |     cat("##[set-output name=r-version;]", R.Version()$version.string, sep = "") | ||||||
|   shell: Rscript {0} |   shell: Rscript {0} | ||||||
| - name: Restore Renv package cache | - name: Restore Renv package cache | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: ${{ env.RENV_PATHS_ROOT }} |     path: ${{ env.RENV_PATHS_ROOT }} | ||||||
|     key: ${{ steps.get-version.outputs.os-version }}-${{ steps.get-version.outputs.r-version }}-${{ inputs.cache-version }}-${{ hashFiles('renv.lock') }} |     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 | ## Rust - Cargo | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.cargo/bin/ |       ~/.cargo/bin/ | ||||||
| @ -568,7 +568,7 @@ whenever possible: | |||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - name: Cache SBT | - name: Cache SBT | ||||||
|   uses: actions/cache@v2 |   uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: | |     path: | | ||||||
|       ~/.ivy2/cache |       ~/.ivy2/cache | ||||||
| @ -579,7 +579,7 @@ whenever possible: | |||||||
| ## Swift, Objective-C - Carthage | ## Swift, Objective-C - Carthage | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: Carthage |     path: Carthage | ||||||
|     key: ${{ runner.os }}-carthage-${{ hashFiles('**/Cartfile.resolved') }} |     key: ${{ runner.os }}-carthage-${{ hashFiles('**/Cartfile.resolved') }} | ||||||
| @ -590,7 +590,7 @@ whenever possible: | |||||||
| ## Swift, Objective-C - CocoaPods | ## Swift, Objective-C - CocoaPods | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: Pods |     path: Pods | ||||||
|     key: ${{ runner.os }}-pods-${{ hashFiles('**/Podfile.lock') }} |     key: ${{ runner.os }}-pods-${{ hashFiles('**/Podfile.lock') }} | ||||||
| @ -601,7 +601,7 @@ whenever possible: | |||||||
| ## Swift - Swift Package Manager | ## Swift - Swift Package Manager | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| - uses: actions/cache@v2 | - uses: actions/cache@v3 | ||||||
|   with: |   with: | ||||||
|     path: .build |     path: .build | ||||||
|     key: ${{ runner.os }}-spm-${{ hashFiles('**/Package.resolved') }} |     key: ${{ runner.os }}-spm-${{ hashFiles('**/Package.resolved') }} | ||||||
|  | |||||||
							
								
								
									
										13414
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										13414
									
								
								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", |   "name": "cache", | ||||||
|   "version": "3.0.0", |   "version": "3.0.2", | ||||||
|   "private": true, |   "private": true, | ||||||
|   "description": "Cache dependencies and build outputs", |   "description": "Cache dependencies and build outputs", | ||||||
|   "main": "dist/restore/index.js", |   "main": "dist/restore/index.js", | ||||||
| @ -23,29 +23,29 @@ | |||||||
|   "author": "GitHub", |   "author": "GitHub", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/cache": "^1.0.10", |     "@actions/cache": "^2.0.2", | ||||||
|     "@actions/core": "^1.2.6", |     "@actions/core": "^1.7.0", | ||||||
|     "@actions/exec": "^1.1.1", |     "@actions/exec": "^1.1.1", | ||||||
|     "@actions/io": "^1.1.2" |     "@actions/io": "^1.1.2" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/jest": "^27.4.1", |     "@types/jest": "^27.5.0", | ||||||
|     "@types/nock": "^11.1.0", |     "@types/nock": "^11.1.0", | ||||||
|     "@types/node": "^16.11.26", |     "@types/node": "^16.11.33", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.15.0", |     "@typescript-eslint/eslint-plugin": "^5.22.0", | ||||||
|     "@typescript-eslint/parser": "^5.15.0", |     "@typescript-eslint/parser": "^5.22.0", | ||||||
|     "@zeit/ncc": "^0.20.5", |     "@zeit/ncc": "^0.20.5", | ||||||
|     "eslint": "^8.11.0", |     "eslint": "^8.14.0", | ||||||
|     "eslint-config-prettier": "^8.5.0", |     "eslint-config-prettier": "^8.5.0", | ||||||
|     "eslint-plugin-import": "^2.25.4", |     "eslint-plugin-import": "^2.26.0", | ||||||
|     "eslint-plugin-jest": "^26.1.2", |     "eslint-plugin-jest": "^26.1.5", | ||||||
|     "eslint-plugin-prettier": "^4.0.0", |     "eslint-plugin-prettier": "^4.0.0", | ||||||
|     "eslint-plugin-simple-import-sort": "^7.0.0", |     "eslint-plugin-simple-import-sort": "^7.0.0", | ||||||
|     "jest": "^27.5.1", |     "jest": "^28.0.3", | ||||||
|     "jest-circus": "^27.5.1", |     "jest-circus": "^27.5.1", | ||||||
|     "nock": "^11.7.0", |     "nock": "^13.2.4", | ||||||
|     "prettier": "^2.6.0", |     "prettier": "^2.6.2", | ||||||
|     "ts-jest": "^27.1.3", |     "ts-jest": "^28.0.2", | ||||||
|     "typescript": "^3.9.9" |     "typescript": "^4.6.4" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
| @ -6,10 +6,7 @@ import * as utils from "./utils/actionUtils"; | |||||||
|  |  | ||||||
| async function run(): Promise<void> { | async function run(): Promise<void> { | ||||||
|     try { |     try { | ||||||
|         if (utils.isGhes()) { |         if (!utils.isCacheFeatureAvailable()) { | ||||||
|             utils.logWarning( |  | ||||||
|                 "Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details" |  | ||||||
|             ); |  | ||||||
|             utils.setCacheHitOutput(false); |             utils.setCacheHitOutput(false); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @ -55,16 +52,17 @@ async function run(): Promise<void> { | |||||||
|             utils.setCacheHitOutput(isExactKeyMatch); |             utils.setCacheHitOutput(isExactKeyMatch); | ||||||
|  |  | ||||||
|             core.info(`Cache restored from key: ${cacheKey}`); |             core.info(`Cache restored from key: ${cacheKey}`); | ||||||
|         } catch (error) { |         } catch (error: unknown) { | ||||||
|             if (error.name === cache.ValidationError.name) { |             const typedError = error as Error; | ||||||
|  |             if (typedError.name === cache.ValidationError.name) { | ||||||
|                 throw error; |                 throw error; | ||||||
|             } else { |             } else { | ||||||
|                 utils.logWarning(error.message); |                 utils.logWarning(typedError.message); | ||||||
|                 utils.setCacheHitOutput(false); |                 utils.setCacheHitOutput(false); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } catch (error) { |     } catch (error: unknown) { | ||||||
|         core.setFailed(error.message); |         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> { | async function run(): Promise<void> { | ||||||
|     try { |     try { | ||||||
|         if (utils.isGhes()) { |         if (!utils.isCacheFeatureAvailable()) { | ||||||
|             utils.logWarning( |  | ||||||
|                 "Cache action is not supported on GHES. See https://github.com/actions/cache/issues/505 for more details" |  | ||||||
|             ); |  | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @ -52,17 +49,18 @@ async function run(): Promise<void> { | |||||||
|                 uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) |                 uploadChunkSize: utils.getInputAsInt(Inputs.UploadChunkSize) | ||||||
|             }); |             }); | ||||||
|             core.info(`Cache saved with key: ${primaryKey}`); |             core.info(`Cache saved with key: ${primaryKey}`); | ||||||
|         } catch (error) { |         } catch (error: unknown) { | ||||||
|             if (error.name === cache.ValidationError.name) { |             const typedError = error as Error; | ||||||
|  |             if (typedError.name === cache.ValidationError.name) { | ||||||
|                 throw error; |                 throw error; | ||||||
|             } else if (error.name === cache.ReserveCacheError.name) { |             } else if (typedError.name === cache.ReserveCacheError.name) { | ||||||
|                 core.info(error.message); |                 core.info(typedError.message); | ||||||
|             } else { |             } else { | ||||||
|                 utils.logWarning(error.message); |                 utils.logWarning(typedError.message); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } catch (error) { |     } catch (error: unknown) { | ||||||
|         utils.logWarning(error.message); |         utils.logWarning((error as Error).message); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
| @ -1,3 +1,4 @@ | |||||||
|  | import * as cache from "@actions/cache"; | ||||||
| import * as core from "@actions/core"; | import * as core from "@actions/core"; | ||||||
|  |  | ||||||
| import { Outputs, RefKey, State } from "../constants"; | import { Outputs, RefKey, State } from "../constants"; | ||||||
| @ -74,3 +75,20 @@ export function getInputAsInt( | |||||||
|     } |     } | ||||||
|     return value; |     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
	