Compare commits
	
		
			231 Commits 
		
	
	
	| Author | SHA1 | Date | 
|---|---|---|
|  | 1583c0f09d | |
|  | ed158e7963 | |
|  | 4cc794f83e | |
|  | 4dfc3d6c5d | |
|  | af1b253b8d | |
|  | 3c6ab92b04 | |
|  | 2c8bcdab54 | |
|  | 1051acaba6 | |
|  | e8cd182ec7 | |
|  | 8c5c87276d | |
|  | 90fa7ac870 | |
|  | 7ebadadf6b | |
|  | ee3eb2f3a4 | |
|  | c65d441f38 | |
|  | da183f8ca3 | |
|  | f7a6c723e1 | |
|  | 8424fa0070 | |
|  | c52693d481 | |
|  | 5efa6e34fd | |
|  | 774224adf6 | |
|  | 5d221e8956 | |
|  | 68163b97ca | |
|  | ae7d6893e8 | |
|  | ac3a803dd3 | |
|  | e468171a9d | |
|  | a3e7502fd0 | |
|  | b145473295 | |
|  | 18ce135bb5 | |
|  | 0e198e93af | |
|  | 05f3f3ac10 | |
|  | 622913496d | |
|  | c6f6a07025 | |
|  | 6c5e29d848 | |
|  | 548b297749 | |
|  | 36590ad0c1 | |
|  | 4143b5899b | |
|  | 3f1544eb9e | |
|  | f3204bbfac | |
|  | 4ba329ef89 | |
|  | e600775e52 | |
|  | b2b2ffa946 | |
|  | fe905840cd | |
|  | 8998bbe94b | |
|  | 830833e0c7 | |
|  | 941183f0a0 | |
|  | 311b62b254 | |
|  | afeb29a6e0 | |
|  | b560416601 | |
|  | 516bb780e5 | |
|  | 11445527f0 | |
|  | b5ca514318 | |
|  | 1418a4ef33 | |
|  | 93acf831ce | |
|  | f7ce87c1d6 | |
|  | aa1e2a0b49 | |
|  | 673e008776 | |
|  | ba31df4664 | |
|  | 5475af18ec | |
|  | acacad903e | |
|  | 6a25f988bd | |
|  | ca1af179f5 | |
|  | 6524bf65af | |
|  | 8d5e0747fc | |
|  | 7199e57b35 | |
|  | db63cee3de | |
|  | 043ebe137f | |
|  | 686da9073d | |
|  | a3d74876b8 | |
|  | 4dcdbcec48 | |
|  | 1a8ac74316 | |
|  | e827ebe8ba | |
|  | adacc1474e | |
|  | 0f069ddc17 | |
|  | d036b3238c | |
|  | 460e45646d | |
|  | 93aa1c807f | |
|  | d391aad55c | |
|  | e5b688ea46 | |
|  | c47758b77c | |
|  | 8fea382513 | |
|  | 2874e980e8 | |
|  | 8026d2bc36 | |
|  | e51aab53e9 | |
|  | fd7390e14d | |
|  | 910a304005 | |
|  | 3623ee443e | |
|  | e0e5ecf670 | |
|  | 5334dd0cdd | |
|  | 214bb6dac1 | |
|  | 818c69a4ea | |
|  | b467d6aa7a | |
|  | 7594cf3831 | |
|  | 988b5a0280 | |
|  | 2c215620b8 | |
|  | 3382292cd5 | |
|  | 3d68780484 | |
|  | d069e98648 | |
|  | 8b850f86dc | |
|  | aa33708b10 | |
|  | 2d99e3412d | |
|  | 4dab43650b | |
|  | 49a04d6890 | |
|  | a6ade2e34f | |
|  | 2f2694b8d1 | |
|  | 0a4bab6632 | |
|  | 2ad185228a | |
|  | 560ac469d6 | |
|  | b3a341759e | |
|  | 4fd812986e | |
|  | 3386dc4251 | |
|  | d191aef416 | |
|  | f686054aab | |
|  | 78547859d7 | |
|  | 830928c706 | |
|  | 26d2aec173 | |
|  | ab17e3ec80 | |
|  | d79cb80903 | |
|  | 13cf78894f | |
|  | 0e592087a0 | |
|  | 47032b9b53 | |
|  | abe89fb761 | |
|  | e027232c25 | |
|  | 5d9397e7ca | |
|  | e9ab4c6a14 | |
|  | 748835b452 | |
|  | 554c728605 | |
|  | 1c1261e632 | |
|  | 5138f76647 | |
|  | eddcf46655 | |
|  | 2740b29678 | |
|  | 1113efed2b | |
|  | 8a2a7ad780 | |
|  | e3c7deb79b | |
|  | be3701b211 | |
|  | e2ed622d10 | |
|  | b73b950903 | |
|  | 157d6d0106 | |
|  | a530e948ad | |
|  | 28ecb964cd | |
|  | dc25d8b2ee | |
|  | d70bba72b1 | |
|  | 7638634cb7 | |
|  | c68420fe0b | |
|  | 2b51285047 | |
|  | 0f00370563 | |
|  | 11c9683db9 | |
|  | 56a16b8f2a | |
|  | c23f46eb91 | |
|  | f876da6242 | |
|  | b7cf918227 | |
|  | 0150f0ed7a | |
|  | d89f1f9116 | |
|  | 12d65f6595 | |
|  | 8e1cfa56de | |
|  | 0d103c3126 | |
|  | f19477aacd | |
|  | a4180f835d | |
|  | 524315340d | |
|  | 3679a54023 | |
|  | 37a22a2fb2 | |
|  | 65afe610a1 | |
|  | fcb8f722fd | |
|  | f62b9a17c0 | |
|  | 74c5b717e5 | |
|  | 0d7aea7476 | |
|  | edfb0fe620 | |
|  | ee40da0772 | |
|  | 02e65a5ab9 | |
|  | 6d5347c402 | |
|  | ab3fcb73e7 | |
|  | 3762d454f3 | |
|  | cdd4983d88 | |
|  | a3e8dc13a7 | |
|  | 5d98624985 | |
|  | fa0a3f8db8 | |
|  | 0d99838e0e | |
|  | dedd61cf5d | |
|  | a9e6efb8d7 | |
|  | 572af8c114 | |
|  | 8bda7f18d0 | |
|  | 36dc84a6af | |
|  | 1eaf7017ec | |
|  | 35db0cdb94 | |
|  | 524ee0563f | |
|  | 91c74bb1dc | |
|  | 7d508e5a8a | |
|  | c9db9161e9 | |
|  | f95db51fdd | |
|  | 998a87c2c1 | |
|  | 28bae59336 | |
|  | c215341715 | |
|  | 02e9319239 | |
|  | 5c9160effc | |
|  | 1283140f57 | |
|  | c6afe06e4a | |
|  | f35e0d5a04 | |
|  | baeb468fb2 | |
|  | 8e48232775 | |
|  | a52126db3d | |
|  | 2afcb42c88 | |
|  | 2fbc37fd36 | |
|  | 23d726350c | |
|  | 885d1462b8 | |
|  | e5fad018d0 | |
|  | 45161fd92a | |
|  | a4d51f53dd | |
|  | 93b8ecaa2c | |
|  | 7703e82fbc | |
|  | 0005881963 | |
|  | b699069f49 | |
|  | 9bfc5497b8 | |
|  | b92d4d8769 | |
|  | 285be6c835 | |
|  | 4c0219f9ac | |
|  | 0db41bf51b | |
|  | 62fc1a1dd6 | |
|  | 2a1a44ac4a | |
|  | a6c26a99ef | |
|  | a5a7f565d9 | |
|  | 7d7611f95b | |
|  | 16c0bc4a6e | |
|  | ebcacb9c21 | |
|  | 496a823b8b | |
|  | a56031a493 | |
|  | 922550f064 | |
|  | ecf95283f0 | |
|  | b2a38ee0c6 | |
|  | 7f79690cac | |
|  | bdd549bec0 | |
|  | be4a3855af | |
|  | 6c4dbb29f6 | 
|  | @ -1,2 +1,12 @@ | ||||||
| /coverage | /coverage | ||||||
| /node_modules | 
 | ||||||
|  | # Dependency directories | ||||||
|  | node_modules/ | ||||||
|  | jspm_packages/ | ||||||
|  | 
 | ||||||
|  | # yarn v2 | ||||||
|  | .yarn/cache | ||||||
|  | .yarn/unplugged | ||||||
|  | .yarn/build-state.yml | ||||||
|  | .yarn/install-state.gz | ||||||
|  | .pnp.* | ||||||
|  |  | ||||||
|  | @ -0,0 +1,3 @@ | ||||||
|  | /dist/** | ||||||
|  | /coverage/** | ||||||
|  | /node_modules/** | ||||||
|  | @ -1,11 +1,12 @@ | ||||||
| { | { | ||||||
|   "env": { |   "env": { | ||||||
|     "node": true, |     "node": true, | ||||||
|     "es2021": true, |     "es6": true, | ||||||
|     "jest": true |     "jest": true | ||||||
|   }, |   }, | ||||||
|   "extends": [ |   "extends": [ | ||||||
|     "eslint:recommended", |     "eslint:recommended", | ||||||
|  |     "plugin:@typescript-eslint/eslint-recommended", | ||||||
|     "plugin:@typescript-eslint/recommended", |     "plugin:@typescript-eslint/recommended", | ||||||
|     "plugin:jest/recommended", |     "plugin:jest/recommended", | ||||||
|     "plugin:prettier/recommended" |     "plugin:prettier/recommended" | ||||||
|  |  | ||||||
|  | @ -1,2 +1,4 @@ | ||||||
|  | /.yarn/releases/** binary | ||||||
|  | /.yarn/plugins/** binary | ||||||
| /dist/** linguist-generated=true | /dist/** linguist-generated=true | ||||||
| /lib/** linguist-generated=true | /lib/** linguist-generated=true | ||||||
|  |  | ||||||
|  | @ -1 +0,0 @@ | ||||||
| *	@crazy-max |  | ||||||
|  | @ -0,0 +1,3 @@ | ||||||
|  | # Code of conduct | ||||||
|  | 
 | ||||||
|  | - [Moby community guidelines](https://github.com/moby/moby/blob/master/CONTRIBUTING.md#moby-community-guidelines) | ||||||
|  | @ -0,0 +1,101 @@ | ||||||
|  | # https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/syntax-for-githubs-form-schema | ||||||
|  | name: Bug Report | ||||||
|  | description: Report a bug | ||||||
|  | labels: | ||||||
|  |   - status/triage | ||||||
|  | 
 | ||||||
|  | body: | ||||||
|  |   - type: markdown | ||||||
|  |     attributes: | ||||||
|  |       value: | | ||||||
|  |         Thank you for taking the time to report a bug! | ||||||
|  |         If this is a security issue please report it to the [Docker Security team](mailto:security@docker.com). | ||||||
|  | 
 | ||||||
|  |   - type: checkboxes | ||||||
|  |     attributes: | ||||||
|  |       label: Contributing guidelines | ||||||
|  |       description: > | ||||||
|  |         Make sure you've read the contributing guidelines before proceeding. | ||||||
|  |       options: | ||||||
|  |         - label: I've read the [contributing guidelines](https://github.com/docker/setup-buildx-action/blob/master/.github/CONTRIBUTING.md) and wholeheartedly agree | ||||||
|  |           required: true | ||||||
|  | 
 | ||||||
|  |   - type: checkboxes | ||||||
|  |     attributes: | ||||||
|  |       label: "I've found a bug, and:" | ||||||
|  |       description: | | ||||||
|  |         Make sure that your request fulfills all of the following requirements. | ||||||
|  |         If one requirement cannot be satisfied, explain in detail why. | ||||||
|  |       options: | ||||||
|  |         - label: The documentation does not mention anything about my problem | ||||||
|  |         - label: There are no open or closed issues that are related to my problem | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: Description | ||||||
|  |       description: > | ||||||
|  |         Provide a brief description of the bug in 1-2 sentences. | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: Expected behaviour | ||||||
|  |       description: > | ||||||
|  |         Describe precisely what you'd expect to happen. | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: Actual behaviour | ||||||
|  |       description: > | ||||||
|  |         Describe precisely what is actually happening. | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  | 
 | ||||||
|  |   - type: input | ||||||
|  |     attributes: | ||||||
|  |       label: Repository URL | ||||||
|  |       description: > | ||||||
|  |         Enter the URL of the repository where you are experiencing the | ||||||
|  |         issue. If your repository is private, provide a link to a minimal | ||||||
|  |         repository that reproduces the issue. | ||||||
|  | 
 | ||||||
|  |   - type: input | ||||||
|  |     attributes: | ||||||
|  |       label: Workflow run URL | ||||||
|  |       description: > | ||||||
|  |         Enter the URL of the GitHub Action workflow run if public (e.g. | ||||||
|  |         `https://github.com/<user>/<repo>/actions/runs/<id>`) | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: YAML workflow | ||||||
|  |       description: | | ||||||
|  |         Provide the YAML of the workflow that's causing the issue. | ||||||
|  |         Make sure to remove any sensitive information. | ||||||
|  |       render: yaml | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: Workflow logs | ||||||
|  |       description: > | ||||||
|  |         [Attach](https://docs.github.com/en/get-started/writing-on-github/working-with-advanced-formatting/attaching-files) | ||||||
|  |         the [log file of your workflow run](https://docs.github.com/en/actions/managing-workflow-runs/using-workflow-run-logs#downloading-logs) | ||||||
|  |         and make sure to remove any sensitive information. | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: BuildKit logs | ||||||
|  |       description: > | ||||||
|  |         If applicable, provide the [BuildKit container logs](https://docs.docker.com/build/ci/github-actions/configure-builder/#buildkit-container-logs) | ||||||
|  |       render: text | ||||||
|  | 
 | ||||||
|  |   - type: textarea | ||||||
|  |     attributes: | ||||||
|  |       label: Additional info | ||||||
|  |       description: | | ||||||
|  |         Provide any additional information that could be useful. | ||||||
|  | @ -1,34 +0,0 @@ | ||||||
| --- |  | ||||||
| name: Bug report |  | ||||||
| about: Create a report to help us improve |  | ||||||
| --- |  | ||||||
| 
 |  | ||||||
| ### Behaviour |  | ||||||
| 
 |  | ||||||
| #### Steps to reproduce this issue |  | ||||||
| 
 |  | ||||||
| 1. |  | ||||||
| 2. |  | ||||||
| 3. |  | ||||||
| 
 |  | ||||||
| #### Expected behaviour |  | ||||||
| 
 |  | ||||||
| > Tell us what should happen |  | ||||||
| 
 |  | ||||||
| #### Actual behaviour |  | ||||||
| 
 |  | ||||||
| > Tell us what happens instead |  | ||||||
| 
 |  | ||||||
| ### Configuration |  | ||||||
| 
 |  | ||||||
| * Repository URL (if public):  |  | ||||||
| * Build URL (if public):  |  | ||||||
| 
 |  | ||||||
| ```yml |  | ||||||
| # paste your YAML workflow file here and remove sensitive data |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| ### Logs |  | ||||||
| 
 |  | ||||||
| > Download the [log file of your build](https://docs.github.com/en/actions/managing-workflow-runs/using-workflow-run-logs#downloading-logs) |  | ||||||
| > and [attach it](https://docs.github.com/en/github/managing-your-work-on-github/file-attachments-on-issues-and-pull-requests) to this issue. |  | ||||||
|  | @ -0,0 +1,9 @@ | ||||||
|  | # https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/configuring-issue-templates-for-your-repository#configuring-the-template-chooser | ||||||
|  | blank_issues_enabled: true | ||||||
|  | contact_links: | ||||||
|  |   - name: Questions and Discussions | ||||||
|  |     url: https://github.com/docker/setup-buildx-action/discussions/new | ||||||
|  |     about: Use Github Discussions to ask questions and/or open discussion topics. | ||||||
|  |   - name: Documentation | ||||||
|  |     url: https://docs.docker.com/build/ci/github-actions/ | ||||||
|  |     about: Read the documentation. | ||||||
|  | @ -0,0 +1,15 @@ | ||||||
|  | # https://docs.github.com/en/communities/using-templates-to-encourage-useful-issues-and-pull-requests/syntax-for-githubs-form-schema | ||||||
|  | name: Feature request | ||||||
|  | description: Missing functionality? Come tell us about it! | ||||||
|  | labels: | ||||||
|  |   - kind/enhancement | ||||||
|  |   - status/triage | ||||||
|  | 
 | ||||||
|  | body: | ||||||
|  |   - type: textarea | ||||||
|  |     id: description | ||||||
|  |     attributes: | ||||||
|  |       label: Description | ||||||
|  |       description: What is the feature you want to see? | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  | @ -0,0 +1,12 @@ | ||||||
|  | # Reporting security issues | ||||||
|  | 
 | ||||||
|  | The project maintainers take security seriously. If you discover a security | ||||||
|  | issue, please bring it to their attention right away! | ||||||
|  | 
 | ||||||
|  | **Please _DO NOT_ file a public issue**, instead send your report privately to | ||||||
|  | [security@docker.com](mailto:security@docker.com). | ||||||
|  | 
 | ||||||
|  | Security reports are greatly appreciated, and we will publicly thank you for it. | ||||||
|  | We also like to send gifts—if you'd like Docker swag, make sure to let | ||||||
|  | us know. We currently do not offer a paid security bounty program, but are not | ||||||
|  | ruling it out in the future. | ||||||
|  | @ -1,31 +0,0 @@ | ||||||
| # Support [](https://isitmaintained.com/project/docker/setup-buildx-action) |  | ||||||
| 
 |  | ||||||
| First, [be a good guy](https://github.com/kossnocorp/etiquette/blob/master/README.md). |  | ||||||
| 
 |  | ||||||
| ## Reporting an issue |  | ||||||
| 
 |  | ||||||
| Please do a search in [open issues](https://github.com/docker/setup-buildx-action/issues?utf8=%E2%9C%93&q=) to see if the issue or feature request has already been filed. |  | ||||||
| 
 |  | ||||||
| If you find your issue already exists, make relevant comments and add your [reaction](https://github.com/blog/2119-add-reactions-to-pull-requests-issues-and-comments). Use a reaction in place of a "+1" comment. |  | ||||||
| 
 |  | ||||||
| :+1: - upvote |  | ||||||
| 
 |  | ||||||
| :-1: - downvote |  | ||||||
| 
 |  | ||||||
| If you cannot find an existing issue that describes your bug or feature, submit an issue using the guidelines below. |  | ||||||
| 
 |  | ||||||
| ## Writing good bug reports and feature requests |  | ||||||
| 
 |  | ||||||
| File a single issue per problem and feature request. |  | ||||||
| 
 |  | ||||||
| * Do not enumerate multiple bugs or feature requests in the same issue. |  | ||||||
| * Do not add your issue as a comment to an existing issue unless it's for the identical input. Many issues look similar, but have different causes. |  | ||||||
| 
 |  | ||||||
| The more information you can provide, the more likely someone will be successful reproducing the issue and finding a fix. |  | ||||||
| 
 |  | ||||||
| You are now ready to [create a new issue](https://github.com/docker/setup-buildx-action/issues/new/choose)! |  | ||||||
| 
 |  | ||||||
| ## Closure policy |  | ||||||
| 
 |  | ||||||
| * Issues that don't have the information requested above (when applicable) will be closed immediately and the poster directed to the support guidelines. |  | ||||||
| * Issues that go a week without a response from original poster are subject to closure at our discretion. |  | ||||||
|  | @ -11,6 +11,7 @@ updates: | ||||||
|     directory: "/" |     directory: "/" | ||||||
|     schedule: |     schedule: | ||||||
|       interval: "daily" |       interval: "daily" | ||||||
|  |     versioning-strategy: "increase" | ||||||
|     allow: |     allow: | ||||||
|       - dependency-type: "production" |       - dependency-type: "production" | ||||||
|     labels: |     labels: | ||||||
|  |  | ||||||
|  | @ -1,6 +1,11 @@ | ||||||
| name: ci | name: ci | ||||||
| 
 | 
 | ||||||
|  | concurrency: | ||||||
|  |   group: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |   cancel-in-progress: true | ||||||
|  | 
 | ||||||
| on: | on: | ||||||
|  |   workflow_dispatch: | ||||||
|   schedule: |   schedule: | ||||||
|     - cron: '0 10 * * *' |     - cron: '0 10 * * *' | ||||||
|   push: |   push: | ||||||
|  | @ -18,13 +23,16 @@ jobs: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         buildx-version: |         buildx-version: | ||||||
|           - latest |  | ||||||
|           - v0.4.1 |  | ||||||
|           - "" |           - "" | ||||||
|  |           - "latest" | ||||||
|  |           - "v0.4.1" | ||||||
|  |           - "cloud:latest" | ||||||
|  |           - "cloud:v0.11.2-desktop.2" | ||||||
|  |           - "lab:latest" | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         id: buildx |         id: buildx | ||||||
|  | @ -43,7 +51,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx 1 |         name: Set up Docker Buildx 1 | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -56,11 +64,11 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Stop docker |         name: Stop docker | ||||||
|         run: | |         run: | | ||||||
|           sudo systemctl stop docker |           sudo systemctl stop docker docker.socket | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         id: buildx |         id: buildx | ||||||
|  | @ -84,7 +92,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Create Dockerfile |         name: Create Dockerfile | ||||||
|         run: | |         run: | | ||||||
|  | @ -94,7 +102,7 @@ jobs: | ||||||
|           EOL |           EOL | ||||||
|       - |       - | ||||||
|         name: Set up QEMU |         name: Set up QEMU | ||||||
|         uses: docker/setup-qemu-action@v2 |         uses: docker/setup-qemu-action@v3 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -102,7 +110,7 @@ jobs: | ||||||
|           buildkitd-flags: --debug |           buildkitd-flags: --debug | ||||||
|       - |       - | ||||||
|         name: Build |         name: Build | ||||||
|         uses: docker/build-push-action@v4 |         uses: docker/build-push-action@v6 | ||||||
|         with: |         with: | ||||||
|           context: . |           context: . | ||||||
|           platforms: linux/amd64,linux/arm64,linux/ppc64le |           platforms: linux/amd64,linux/arm64,linux/ppc64le | ||||||
|  | @ -112,7 +120,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -134,7 +142,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -157,7 +165,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -170,7 +178,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -203,7 +211,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Create context |         name: Create context | ||||||
|         run: | |         run: | | ||||||
|  | @ -225,7 +233,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Create buildkitd conf |         name: Create buildkitd conf | ||||||
|         run: | |         run: | | ||||||
|  | @ -245,10 +253,10 @@ jobs: | ||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
|           buildkitd-flags: --debug |           buildkitd-flags: --debug | ||||||
|           config: /tmp/buildkitd.toml |           buildkitd-config: /tmp/buildkitd.toml | ||||||
|       - |       - | ||||||
|         name: Build |         name: Build | ||||||
|         uses: docker/build-push-action@v4 |         uses: docker/build-push-action@v6 | ||||||
|         with: |         with: | ||||||
|           context: . |           context: . | ||||||
| 
 | 
 | ||||||
|  | @ -257,7 +265,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Create Dockerfile |         name: Create Dockerfile | ||||||
|         run: | |         run: | | ||||||
|  | @ -269,13 +277,13 @@ jobs: | ||||||
|         uses: ./ |         uses: ./ | ||||||
|         with: |         with: | ||||||
|           buildkitd-flags: --debug |           buildkitd-flags: --debug | ||||||
|           config-inline: | |           buildkitd-config-inline: | | ||||||
|             debug = true |             debug = true | ||||||
|             [registry."docker.io"] |             [registry."docker.io"] | ||||||
|               mirrors = ["mirror.gcr.io"] |               mirrors = ["mirror.gcr.io"] | ||||||
|       - |       - | ||||||
|         name: Build |         name: Build | ||||||
|         uses: docker/build-push-action@v4 |         uses: docker/build-push-action@v6 | ||||||
|         with: |         with: | ||||||
|           context: . |           context: . | ||||||
| 
 | 
 | ||||||
|  | @ -285,8 +293,7 @@ jobs: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         buildx-version: |         buildx-version: | ||||||
|           - latest |           - v0.9.1 | ||||||
|           - v0.4.1 |  | ||||||
|           - "" |           - "" | ||||||
|         qemu-platforms: |         qemu-platforms: | ||||||
|           - all |           - all | ||||||
|  | @ -294,10 +301,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up QEMU |         name: Set up QEMU | ||||||
|         uses: docker/setup-qemu-action@v2 |         uses: docker/setup-qemu-action@v3 | ||||||
|         with: |         with: | ||||||
|           platforms: ${{ matrix.qemu-platforms }} |           platforms: ${{ matrix.qemu-platforms }} | ||||||
|       - |       - | ||||||
|  | @ -323,7 +330,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -346,11 +353,15 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Uninstall docker cli |         name: Uninstall docker cli | ||||||
|         run: | |         run: | | ||||||
|           sudo apt-get purge -y moby-cli moby-buildx |           if dpkg -s "docker-ce" >/dev/null 2>&1; then | ||||||
|  |             sudo dpkg -r --force-depends docker-ce-cli docker-buildx-plugin | ||||||
|  |           else | ||||||
|  |             sudo apt-get purge -y moby-cli moby-buildx | ||||||
|  |           fi | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -370,11 +381,15 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Uninstall docker cli |         name: Uninstall docker cli | ||||||
|         run: | |         run: | | ||||||
|           sudo apt-get purge -y moby-cli moby-buildx |           if dpkg -s "docker-ce" >/dev/null 2>&1; then | ||||||
|  |             sudo dpkg -r --force-depends docker-ce-cli docker-buildx-plugin | ||||||
|  |           else | ||||||
|  |             sudo apt-get purge -y moby-cli moby-buildx | ||||||
|  |           fi | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -397,11 +412,15 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Uninstall docker cli |         name: Uninstall docker cli | ||||||
|         run: | |         run: | | ||||||
|           sudo apt-get purge -y moby-cli moby-buildx |           if dpkg -s "docker-ce" >/dev/null 2>&1; then | ||||||
|  |             sudo dpkg -r --force-depends docker-ce-cli docker-buildx-plugin | ||||||
|  |           else | ||||||
|  |             sudo apt-get purge -y moby-cli moby-buildx | ||||||
|  |           fi | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         id: buildx |         id: buildx | ||||||
|  | @ -423,7 +442,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Create dummy contexts |         name: Create dummy contexts | ||||||
|         run: | |         run: | | ||||||
|  | @ -452,10 +471,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up QEMU |         name: Set up QEMU | ||||||
|         uses: docker/setup-qemu-action@v2 |         uses: docker/setup-qemu-action@v3 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -467,7 +486,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Create Docker context |         name: Create Docker context | ||||||
|         run: | |         run: | | ||||||
|  | @ -490,7 +509,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -498,22 +517,21 @@ jobs: | ||||||
|           cleanup: ${{ matrix.cleanup }} |           cleanup: ${{ matrix.cleanup }} | ||||||
| 
 | 
 | ||||||
|   k3s: |   k3s: | ||||||
|     runs-on: ubuntu-20.04 |     runs-on: ubuntu-latest | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         version: |         version: | ||||||
|           - v0.11.0-rc1 |           - latest | ||||||
|  |           - v0.11.0 | ||||||
|           - v0.10.5 |           - v0.10.5 | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Install k3s |         name: Install k3s | ||||||
|         uses: crazy-max/.github/.github/actions/install-k3s@605d30d5ae97f6680578ace4b56645af79343e60 |         uses: crazy-max/.github/.github/actions/install-k3s@a94383ec9e125b23907fb6fcebf7ff87964595e5 | ||||||
|         with: |  | ||||||
|           version: "v1.21.2-k3s1" |  | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         id: buildx |         id: buildx | ||||||
|  | @ -546,3 +564,85 @@ jobs: | ||||||
|         uses: docker/build-push-action@master |         uses: docker/build-push-action@master | ||||||
|         with: |         with: | ||||||
|           context: . |           context: . | ||||||
|  | 
 | ||||||
|  |   cache-binary: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         cache: | ||||||
|  |           - true | ||||||
|  |           - false | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Set up Docker Buildx | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           version: v0.11.2 | ||||||
|  |           cache-binary: ${{ matrix.cache }} | ||||||
|  | 
 | ||||||
|  |   windows-error: | ||||||
|  |     runs-on: windows-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Set up Docker Buildx | ||||||
|  |         id: buildx | ||||||
|  |         continue-on-error: true | ||||||
|  |         uses: ./ | ||||||
|  |       - | ||||||
|  |         name: Check | ||||||
|  |         run: | | ||||||
|  |           echo "${{ toJson(steps.buildx) }}" | ||||||
|  |           if [ "${{ steps.buildx.outcome }}" != "failure" ] || [ "${{ steps.buildx.conclusion }}" != "success" ]; then | ||||||
|  |             echo "::error::Should have failed" | ||||||
|  |             exit 1 | ||||||
|  |           fi | ||||||
|  |         shell: bash | ||||||
|  | 
 | ||||||
|  |   keep-state: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Set up Docker Buildx | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           name: foo | ||||||
|  |           keep-state: true | ||||||
|  |       - | ||||||
|  |         name: Set up Docker Buildx | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           name: foo | ||||||
|  |           keep-state: true | ||||||
|  | 
 | ||||||
|  |   keep-state-error: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Set up Docker Buildx | ||||||
|  |         id: buildx | ||||||
|  |         continue-on-error: true | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           driver: docker | ||||||
|  |           keep-state: true | ||||||
|  |       - | ||||||
|  |         name: Check | ||||||
|  |         run: | | ||||||
|  |           echo "${{ toJson(steps.buildx) }}" | ||||||
|  |           if [ "${{ steps.buildx.outcome }}" != "failure" ] || [ "${{ steps.buildx.conclusion }}" != "success" ]; then | ||||||
|  |             echo "::error::Should have failed" | ||||||
|  |             exit 1 | ||||||
|  |           fi | ||||||
|  |  | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | name: pr-assign-author | ||||||
|  | 
 | ||||||
|  | permissions: | ||||||
|  |   contents: read | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   pull_request_target: | ||||||
|  |     types: | ||||||
|  |       - opened | ||||||
|  |       - reopened | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   run: | ||||||
|  |     uses: crazy-max/.github/.github/workflows/pr-assign-author.yml@1b673f36fad86812f538c1df9794904038a23cbf | ||||||
|  |     permissions: | ||||||
|  |       contents: read | ||||||
|  |       pull-requests: write | ||||||
|  | @ -0,0 +1,21 @@ | ||||||
|  | name: publish | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: | ||||||
|  |       - published | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   publish: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       contents: read | ||||||
|  |       id-token: write | ||||||
|  |       packages: write | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Publish | ||||||
|  |         uses: actions/publish-immutable-action@v0.0.4 | ||||||
|  | @ -1,5 +1,9 @@ | ||||||
| name: test | name: test | ||||||
| 
 | 
 | ||||||
|  | concurrency: | ||||||
|  |   group: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |   cancel-in-progress: true | ||||||
|  | 
 | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|  | @ -13,17 +17,18 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: ./ |         uses: ./ | ||||||
|       - |       - | ||||||
|         name: Test |         name: Test | ||||||
|         uses: docker/bake-action@v3 |         uses: docker/bake-action@v6 | ||||||
|         with: |         with: | ||||||
|           targets: test |           targets: test | ||||||
|       - |       - | ||||||
|         name: Upload coverage |         name: Upload coverage | ||||||
|         uses: codecov/codecov-action@v3 |         uses: codecov/codecov-action@v5 | ||||||
|         with: |         with: | ||||||
|           file: ./coverage/clover.xml |           files: ./coverage/clover.xml | ||||||
|  |           token: ${{ secrets.CODECOV_TOKEN }} | ||||||
|  |  | ||||||
|  | @ -1,5 +1,9 @@ | ||||||
| name: validate | name: validate | ||||||
| 
 | 
 | ||||||
|  | concurrency: | ||||||
|  |   group: ${{ github.workflow }}-${{ github.ref }} | ||||||
|  |   cancel-in-progress: true | ||||||
|  | 
 | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|  | @ -11,16 +15,17 @@ jobs: | ||||||
|   prepare: |   prepare: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     outputs: |     outputs: | ||||||
|       targets: ${{ steps.targets.outputs.matrix }} |       targets: ${{ steps.generate.outputs.targets }} | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Targets matrix |         name: List targets | ||||||
|         id: targets |         id: generate | ||||||
|         run: | |         uses: docker/bake-action/subaction/list-targets@v6 | ||||||
|           echo "matrix=$(docker buildx bake validate --print | jq -cr '.group.validate.targets')" >> $GITHUB_OUTPUT |         with: | ||||||
|  |           target: validate | ||||||
| 
 | 
 | ||||||
|   validate: |   validate: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  | @ -31,11 +36,8 @@ jobs: | ||||||
|       matrix: |       matrix: | ||||||
|         target: ${{ fromJson(needs.prepare.outputs.targets) }} |         target: ${{ fromJson(needs.prepare.outputs.targets) }} | ||||||
|     steps: |     steps: | ||||||
|       - |  | ||||||
|         name: Checkout |  | ||||||
|         uses: actions/checkout@v3 |  | ||||||
|       - |       - | ||||||
|         name: Validate |         name: Validate | ||||||
|         uses: docker/bake-action@v3 |         uses: docker/bake-action@v6 | ||||||
|         with: |         with: | ||||||
|           targets: ${{ matrix.target }} |           targets: ${{ matrix.target }} | ||||||
|  |  | ||||||
|  | @ -1,12 +1,5 @@ | ||||||
| /.dev | # https://raw.githubusercontent.com/github/gitignore/main/Node.gitignore | ||||||
| node_modules |  | ||||||
| lib |  | ||||||
| 
 | 
 | ||||||
| # Jetbrains |  | ||||||
| /.idea |  | ||||||
| /*.iml |  | ||||||
| 
 |  | ||||||
| # Rest of the file pulled from https://github.com/github/gitignore/blob/master/Node.gitignore |  | ||||||
| # Logs | # Logs | ||||||
| logs | logs | ||||||
| *.log | *.log | ||||||
|  | @ -14,6 +7,7 @@ npm-debug.log* | ||||||
| yarn-debug.log* | yarn-debug.log* | ||||||
| yarn-error.log* | yarn-error.log* | ||||||
| lerna-debug.log* | lerna-debug.log* | ||||||
|  | .pnpm-debug.log* | ||||||
| 
 | 
 | ||||||
| # Diagnostic reports (https://nodejs.org/api/report.html) | # Diagnostic reports (https://nodejs.org/api/report.html) | ||||||
| report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json | ||||||
|  | @ -24,34 +18,14 @@ pids | ||||||
| *.seed | *.seed | ||||||
| *.pid.lock | *.pid.lock | ||||||
| 
 | 
 | ||||||
| # Directory for instrumented libs generated by jscoverage/JSCover |  | ||||||
| lib-cov |  | ||||||
| 
 |  | ||||||
| # Coverage directory used by tools like istanbul | # Coverage directory used by tools like istanbul | ||||||
| coverage | coverage | ||||||
| *.lcov | *.lcov | ||||||
| 
 | 
 | ||||||
| # nyc test coverage |  | ||||||
| .nyc_output |  | ||||||
| 
 |  | ||||||
| # Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) |  | ||||||
| .grunt |  | ||||||
| 
 |  | ||||||
| # Bower dependency directory (https://bower.io/) |  | ||||||
| bower_components |  | ||||||
| 
 |  | ||||||
| # node-waf configuration |  | ||||||
| .lock-wscript |  | ||||||
| 
 |  | ||||||
| # Compiled binary addons (https://nodejs.org/api/addons.html) |  | ||||||
| build/Release |  | ||||||
| 
 |  | ||||||
| # Dependency directories | # Dependency directories | ||||||
|  | node_modules/ | ||||||
| jspm_packages/ | jspm_packages/ | ||||||
| 
 | 
 | ||||||
| # TypeScript v1 declaration files |  | ||||||
| typings/ |  | ||||||
| 
 |  | ||||||
| # TypeScript cache | # TypeScript cache | ||||||
| *.tsbuildinfo | *.tsbuildinfo | ||||||
| 
 | 
 | ||||||
|  | @ -61,36 +35,19 @@ typings/ | ||||||
| # Optional eslint cache | # Optional eslint cache | ||||||
| .eslintcache | .eslintcache | ||||||
| 
 | 
 | ||||||
| # Optional REPL history |  | ||||||
| .node_repl_history |  | ||||||
| 
 |  | ||||||
| # Output of 'npm pack' |  | ||||||
| *.tgz |  | ||||||
| 
 |  | ||||||
| # Yarn Integrity file | # Yarn Integrity file | ||||||
| .yarn-integrity | .yarn-integrity | ||||||
| 
 | 
 | ||||||
| # dotenv environment variables file | # dotenv environment variable files | ||||||
| .env | .env | ||||||
| .env.test | .env.development.local | ||||||
|  | .env.test.local | ||||||
|  | .env.production.local | ||||||
|  | .env.local | ||||||
| 
 | 
 | ||||||
| # parcel-bundler cache (https://parceljs.org/) | # yarn v2 | ||||||
| .cache | .yarn/cache | ||||||
| 
 | .yarn/unplugged | ||||||
| # next.js build output | .yarn/build-state.yml | ||||||
| .next | .yarn/install-state.gz | ||||||
| 
 | .pnp.* | ||||||
| # nuxt.js build output |  | ||||||
| .nuxt |  | ||||||
| 
 |  | ||||||
| # vuepress build output |  | ||||||
| .vuepress/dist |  | ||||||
| 
 |  | ||||||
| # Serverless directories |  | ||||||
| .serverless/ |  | ||||||
| 
 |  | ||||||
| # FuseBox cache |  | ||||||
| .fusebox/ |  | ||||||
| 
 |  | ||||||
| # DynamoDB Local files |  | ||||||
| .dynamodb/ |  | ||||||
|  |  | ||||||
|  | @ -0,0 +1,6 @@ | ||||||
|  | # Dependency directories | ||||||
|  | node_modules/ | ||||||
|  | jspm_packages/ | ||||||
|  | 
 | ||||||
|  | # yarn v2 | ||||||
|  | .yarn/ | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | # https://yarnpkg.com/configuration/yarnrc | ||||||
|  | 
 | ||||||
|  | compressionLevel: mixed | ||||||
|  | enableGlobalCache: false | ||||||
|  | enableHardenedMode: true | ||||||
|  | 
 | ||||||
|  | logFilters: | ||||||
|  |   - code: YN0013 | ||||||
|  |     level: discard | ||||||
|  |   - code: YN0019 | ||||||
|  |     level: discard | ||||||
|  |   - code: YN0076 | ||||||
|  |     level: discard | ||||||
|  |   - code: YN0086 | ||||||
|  |     level: discard | ||||||
|  | 
 | ||||||
|  | nodeLinker: node-modules | ||||||
							
								
								
									
										61
									
								
								README.md
								
								
								
								
							
							
						
						
									
										61
									
								
								README.md
								
								
								
								
							|  | @ -42,15 +42,15 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         # Add support for more platforms with QEMU (optional) |         # Add support for more platforms with QEMU (optional) | ||||||
|         # https://github.com/docker/setup-qemu-action |         # https://github.com/docker/setup-qemu-action | ||||||
|         name: Set up QEMU |         name: Set up QEMU | ||||||
|         uses: docker/setup-qemu-action@v2 |         uses: docker/setup-qemu-action@v3 | ||||||
|       - |       - | ||||||
|         name: Set up Docker Buildx |         name: Set up Docker Buildx | ||||||
|         uses: docker/setup-buildx-action@v2 |         uses: docker/setup-buildx-action@v3 | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## Configuring your builder | ## Configuring your builder | ||||||
|  | @ -71,7 +71,7 @@ jobs: | ||||||
| 
 | 
 | ||||||
| ### inputs | ### inputs | ||||||
| 
 | 
 | ||||||
| Following inputs can be used as `step.with` keys: | The following inputs can be used as `step.with` keys: | ||||||
| 
 | 
 | ||||||
| > `List` type is a newline-delimited string | > `List` type is a newline-delimited string | ||||||
| > ```yaml | > ```yaml | ||||||
|  | @ -85,33 +85,42 @@ Following inputs can be used as `step.with` keys: | ||||||
| > platforms: linux/amd64,linux/arm64 | > platforms: linux/amd64,linux/arm64 | ||||||
| > ``` | > ``` | ||||||
| 
 | 
 | ||||||
| | Name              | Type     | Default            | Description                                                                                                                                                                  | | | Name                         | Type     | Default            | Description                                                                                                                                                                 | | ||||||
| |-------------------|----------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | |------------------------------|----------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ||||||
| | `version`         | String   |                    | [Buildx](https://github.com/docker/buildx) version. (eg. `v0.3.0`, `latest`, `https://github.com/docker/buildx.git#master`)                                                  | | | `version`                    | String   |                    | [Buildx](https://github.com/docker/buildx) version. (eg. `v0.3.0`, `latest`, `https://github.com/docker/buildx.git#master`)                                                 | | ||||||
| | `driver`          | String   | `docker-container` | Sets the [builder driver](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver) to be used                                                             | | | `name`                       | String   |                    | Name of the builder. If not specified, one will be generated or if it already exists, it will be used instead of creating a new one                                         | | ||||||
| | `driver-opts`     | List     |                    | List of additional [driver-specific options](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver-opt) (eg. `image=moby/buildkit:master`)              | | | `driver`                     | String   | `docker-container` | Sets the [builder driver](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver) to be used                                                            | | ||||||
| | `buildkitd-flags` | String   |                    | [Flags for buildkitd](https://docs.docker.com/engine/reference/commandline/buildx_create/#buildkitd-flags) daemon                                                            | | | `driver-opts`                | List     |                    | List of additional [driver-specific options](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver-opt) (eg. `image=moby/buildkit:master`)             | | ||||||
| | `install`         | Bool     | `false`            | Sets up `docker build` command as an alias to `docker buildx`                                                                                                                | | | `buildkitd-flags`            | String   |                    | [BuildKit daemon flags](https://docs.docker.com/engine/reference/commandline/buildx_create/#buildkitd-flags)                                                                | | ||||||
| | `use`             | Bool     | `true`             | Switch to this builder instance                                                                                                                                              | | | `buildkitd-config` \*        | String   |                    | [BuildKit daemon config file](https://docs.docker.com/engine/reference/commandline/buildx_create/#config)                                                                   | | ||||||
| | `endpoint`        | String   |                    | [Optional address for docker socket](https://docs.docker.com/engine/reference/commandline/buildx_create/#description) or context from `docker context ls`                    | | | `buildkitd-config-inline` \* | String   |                    | Same as `buildkitd-config` but inline                                                                                                                                       | | ||||||
| | `platforms`       | List/CSV |                    | Fixed [platforms](https://docs.docker.com/engine/reference/commandline/buildx_create/#platform) for current node. If not empty, values take priority over the detected ones. | | | `install`                    | Bool     | `false`            | Sets up `docker build` command as an alias to `docker buildx`                                                                                                               | | ||||||
| | `config`¹         | String   |                    | [BuildKit config file](https://docs.docker.com/engine/reference/commandline/buildx_create/#config)                                                                           | | | `use`                        | Bool     | `true`             | Switch to this builder instance                                                                                                                                             | | ||||||
| | `config-inline`¹  | String   |                    | Same as `config` but inline                                                                                                                                                  | | | `endpoint`                   | String   |                    | [Optional address for docker socket](https://docs.docker.com/engine/reference/commandline/buildx_create/#description) or context from `docker context ls`                   | | ||||||
| | `append`          | YAML     |                    | [Append additional nodes](docs/advanced/append-nodes.md) to the builder                                                                                                      | | | `platforms`                  | List/CSV |                    | Fixed [platforms](https://docs.docker.com/engine/reference/commandline/buildx_create/#platform) for current node. If not empty, values take priority over the detected ones | | ||||||
| | `cleanup`         | Bool     | `true`             | Cleanup temp files and remove builder at the end of a job                                                                                                                    | | | `append`                     | YAML     |                    | [Append additional nodes](https://docs.docker.com/build/ci/github-actions/configure-builder/#append-additional-nodes-to-the-builder) to the builder                         | | ||||||
|  | | `keep-state`                 | Bool     | `false`            | Keep BuildKit state on `cleanup`. This is only useful on persistent self-hosted runners                                                                                     | | ||||||
|  | | `cache-binary`               | Bool     | `true`             | Cache buildx binary to GitHub Actions cache backend                                                                                                                         | | ||||||
|  | | `cleanup`                    | Bool     | `true`             | Cleanup temp files and remove builder at the end of a job                                                                                                                   | | ||||||
| 
 | 
 | ||||||
| > * ¹ `config` and `config-inline` are mutually exclusive | > [!IMPORTANT] | ||||||
|  | > If you set the `buildkitd-flags` input, the default flags (`--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host`) | ||||||
|  | > will be reset. If you want to retain the default behavior, make sure to | ||||||
|  | > include these flags in your custom `buildkitd-flags` value. | ||||||
|  | 
 | ||||||
|  | > [!NOTE] | ||||||
|  | > `buildkitd-config` and `buildkitd-config-inline` are mutually exclusive. | ||||||
| 
 | 
 | ||||||
| ### outputs | ### outputs | ||||||
| 
 | 
 | ||||||
| Following outputs are available | The following outputs are available: | ||||||
| 
 | 
 | ||||||
| | Name        | Type   | Description                                     | | | Name        | Type   | Description                                         | | ||||||
| |-------------|--------|-------------------------------------------------| | |-------------|--------|-----------------------------------------------------| | ||||||
| | `name`      | String | Builder name                                    | | | `name`      | String | Builder name                                        | | ||||||
| | `driver`    | String | Builder driver                                  | | | `driver`    | String | Builder driver                                      | | ||||||
| | `platforms` | String | Builder node platforms (preferred or available) | | | `platforms` | String | Builder node platforms (preferred and/or available) | | ||||||
| | `nodes`     | JSON   | Builder [nodes metadata](#nodes-output)         | | | `nodes`     | JSON   | Builder [nodes metadata](#nodes-output)             | | ||||||
| 
 | 
 | ||||||
| ### environment variables | ### environment variables | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,14 +1,36 @@ | ||||||
| import {beforeEach, describe, expect, jest, test} from '@jest/globals'; | import {beforeEach, describe, expect, jest, test} from '@jest/globals'; | ||||||
| import * as uuid from 'uuid'; | import * as fs from 'fs'; | ||||||
|  | import * as path from 'path'; | ||||||
| import {Buildx} from '@docker/actions-toolkit/lib/buildx/buildx'; | import {Buildx} from '@docker/actions-toolkit/lib/buildx/buildx'; | ||||||
|  | import {Context} from '@docker/actions-toolkit/lib/context'; | ||||||
| import {Docker} from '@docker/actions-toolkit/lib/docker/docker'; | import {Docker} from '@docker/actions-toolkit/lib/docker/docker'; | ||||||
| import {Toolkit} from '@docker/actions-toolkit/lib/toolkit'; | import {Toolkit} from '@docker/actions-toolkit/lib/toolkit'; | ||||||
| import {Node} from '@docker/actions-toolkit/lib/types/builder'; | import {Node} from '@docker/actions-toolkit/lib/types/buildx/builder'; | ||||||
| 
 | 
 | ||||||
| import * as context from '../src/context'; | import * as context from '../src/context'; | ||||||
| 
 | 
 | ||||||
| jest.mock('uuid'); | const fixturesDir = path.join(__dirname, 'fixtures'); | ||||||
| jest.spyOn(uuid, 'v4').mockReturnValue('9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d'); | // prettier-ignore
 | ||||||
|  | const tmpDir = path.join(process.env.TEMP || '/tmp', 'setup-buildx-jest'); | ||||||
|  | const tmpName = path.join(tmpDir, '.tmpname-jest'); | ||||||
|  | 
 | ||||||
|  | jest.spyOn(Context, 'tmpDir').mockImplementation((): string => { | ||||||
|  |   if (!fs.existsSync(tmpDir)) { | ||||||
|  |     fs.mkdirSync(tmpDir, {recursive: true}); | ||||||
|  |   } | ||||||
|  |   return tmpDir; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | jest.spyOn(Context, 'tmpName').mockImplementation((): string => { | ||||||
|  |   return tmpName; | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | jest.mock('crypto', () => { | ||||||
|  |   return { | ||||||
|  |     ...(jest.requireActual('crypto') as object), | ||||||
|  |     randomUUID: jest.fn(() => '9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d') | ||||||
|  |   }; | ||||||
|  | }); | ||||||
| 
 | 
 | ||||||
| jest.spyOn(Docker, 'context').mockImplementation((): Promise<string> => { | jest.spyOn(Docker, 'context').mockImplementation((): Promise<string> => { | ||||||
|   return Promise.resolve('default'); |   return Promise.resolve('default'); | ||||||
|  | @ -32,7 +54,9 @@ describe('getCreateArgs', () => { | ||||||
|       new Map<string, string>([ |       new Map<string, string>([ | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'true'], |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -49,7 +73,9 @@ describe('getCreateArgs', () => { | ||||||
|         ['driver', 'docker'], |         ['driver', 'docker'], | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'true'], |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -66,7 +92,9 @@ describe('getCreateArgs', () => { | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'false'], |         ['use', 'false'], | ||||||
|         ['driver-opts', 'image=moby/buildkit:master\nnetwork=host'], |         ['driver-opts', 'image=moby/buildkit:master\nnetwork=host'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -85,7 +113,9 @@ describe('getCreateArgs', () => { | ||||||
|         ['endpoint', 'tls://foo:1234'], |         ['endpoint', 'tls://foo:1234'], | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'true'], |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -104,7 +134,9 @@ describe('getCreateArgs', () => { | ||||||
|         ['endpoint', 'tls://foo:1234'], |         ['endpoint', 'tls://foo:1234'], | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'true'], |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -122,7 +154,9 @@ describe('getCreateArgs', () => { | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'false'], |         ['use', 'false'], | ||||||
|         ['driver-opts', `"env.no_proxy=localhost,127.0.0.1,.mydomain"`], |         ['driver-opts', `"env.no_proxy=localhost,127.0.0.1,.mydomain"`], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -139,7 +173,9 @@ describe('getCreateArgs', () => { | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'false'], |         ['use', 'false'], | ||||||
|         ['platforms', 'linux/amd64\n"linux/arm64,linux/arm/v7"'], |         ['platforms', 'linux/amd64\n"linux/arm64,linux/arm/v7"'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|       ]), |       ]), | ||||||
|       [ |       [ | ||||||
|         'create', |         'create', | ||||||
|  | @ -148,7 +184,119 @@ describe('getCreateArgs', () => { | ||||||
|         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', |         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', | ||||||
|         '--platform', 'linux/amd64,linux/arm64,linux/arm/v7' |         '--platform', 'linux/amd64,linux/arm64,linux/arm/v7' | ||||||
|       ] |       ] | ||||||
|     ] |     ], | ||||||
|  |     [ | ||||||
|  |       7, | ||||||
|  |       'v0.10.3', | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'false'], | ||||||
|  |         ['driver', 'unknown'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|  |       ]), | ||||||
|  |       [ | ||||||
|  |         'create', | ||||||
|  |         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d', | ||||||
|  |         '--driver', 'unknown', | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       8, | ||||||
|  |       'v0.10.3', | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'false'], | ||||||
|  |         ['buildkitd-config', path.join(fixturesDir, 'buildkitd.toml')], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|  |       ]), | ||||||
|  |       [ | ||||||
|  |         'create', | ||||||
|  |         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d', | ||||||
|  |         '--driver', 'docker-container', | ||||||
|  |         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', | ||||||
|  |         '--config', tmpName, | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       9, | ||||||
|  |       'v0.10.3', | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'false'], | ||||||
|  |         ['buildkitd-config-inline', 'debug = true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|  |       ]), | ||||||
|  |       [ | ||||||
|  |         'create', | ||||||
|  |         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d', | ||||||
|  |         '--driver', 'docker-container', | ||||||
|  |         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', | ||||||
|  |         '--config', tmpName, | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       10, | ||||||
|  |       'v0.10.3', | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'false'], | ||||||
|  |         ['driver', 'cloud'], | ||||||
|  |         ['buildkitd-flags', '--allow-insecure-entitlement network.host'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|  |       ]), | ||||||
|  |       [ | ||||||
|  |         'create', | ||||||
|  |         '--name', 'builder-9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d', | ||||||
|  |         '--driver', 'cloud', | ||||||
|  |         '--buildkitd-flags', '--allow-insecure-entitlement network.host', | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       11, | ||||||
|  |       'v0.10.3', | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['keep-state', 'false'], | ||||||
|  |         ['name', 'test-builder-name'], | ||||||
|  |       ]), | ||||||
|  |       [ | ||||||
|  |         'create', | ||||||
|  |         '--name', 'test-builder-name', | ||||||
|  |         '--driver', 'docker-container', | ||||||
|  |         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', | ||||||
|  |         '--use' | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       12, | ||||||
|  |       'v0.10.3', | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['keep-state', 'true'], | ||||||
|  |         ['name', 'test-builder-name'], | ||||||
|  |       ]), | ||||||
|  |       [ | ||||||
|  |         'create', | ||||||
|  |         '--name', 'test-builder-name', | ||||||
|  |         '--driver', 'docker-container', | ||||||
|  |         '--buildkitd-flags', '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', | ||||||
|  |         '--use', | ||||||
|  |       ] | ||||||
|  |     ], | ||||||
|   ])( |   ])( | ||||||
|     '[%d] given buildx %s and %p as inputs, returns %p', |     '[%d] given buildx %s and %p as inputs, returns %p', | ||||||
|     async (num: number, buildxVersion: string, inputs: Map<string, string>, expected: Array<string>) => { |     async (num: number, buildxVersion: string, inputs: Map<string, string>, expected: Array<string>) => { | ||||||
|  | @ -184,7 +332,9 @@ describe('getAppendArgs', () => { | ||||||
|       new Map<string, string>([ |       new Map<string, string>([ | ||||||
|         ['install', 'false'], |         ['install', 'false'], | ||||||
|         ['use', 'true'], |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|         ['cleanup', 'true'], |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|       ]), |       ]), | ||||||
|       { |       { | ||||||
|         "name": "aws_graviton2", |         "name": "aws_graviton2", | ||||||
|  | @ -223,6 +373,149 @@ describe('getAppendArgs', () => { | ||||||
|   ); |   ); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | describe('getVersion', () => { | ||||||
|  |   beforeEach(() => { | ||||||
|  |     process.env = Object.keys(process.env).reduce((object, key) => { | ||||||
|  |       if (!key.startsWith('INPUT_')) { | ||||||
|  |         object[key] = process.env[key]; | ||||||
|  |       } | ||||||
|  |       return object; | ||||||
|  |     }, {}); | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   // prettier-ignore
 | ||||||
|  |   test.each([ | ||||||
|  |     [ | ||||||
|  |       0, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       '' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       1, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'latest'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'latest' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       2, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'edge'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'edge' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       3, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'v0.19.2'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'v0.19.2' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       4, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'latest'], | ||||||
|  |         ['driver', 'cloud'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'cloud:latest' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       5, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'edge'], | ||||||
|  |         ['driver', 'cloud'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'cloud:edge' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       6, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['driver', 'cloud'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'cloud:latest' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       7, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'cloud:v0.11.2-desktop.2'], | ||||||
|  |         ['driver', 'cloud'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'cloud:v0.11.2-desktop.2' | ||||||
|  |     ], | ||||||
|  |     [ | ||||||
|  |       8, | ||||||
|  |       new Map<string, string>([ | ||||||
|  |         ['version', 'cloud:v0.11.2-desktop.2'], | ||||||
|  |         // defaults
 | ||||||
|  |         ['install', 'false'], | ||||||
|  |         ['use', 'true'], | ||||||
|  |         ['cache-binary', 'true'], | ||||||
|  |         ['cleanup', 'true'], | ||||||
|  |         ['keep-state', 'false'] | ||||||
|  |       ]), | ||||||
|  |       'cloud:v0.11.2-desktop.2' | ||||||
|  |     ], | ||||||
|  |   ])( | ||||||
|  |     '[%d] given %p as inputs, returns version %p', | ||||||
|  |     async (num: number, inputs: Map<string, string>, expected: string) => { | ||||||
|  |       inputs.forEach((value: string, name: string) => { | ||||||
|  |         setInput(name, value); | ||||||
|  |       }); | ||||||
|  |       const inp = await context.getInputs(); | ||||||
|  |       expect(context.getVersion(inp)).toEqual(expected); | ||||||
|  |     } | ||||||
|  |   ); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| // See: https://github.com/actions/toolkit/blob/master/packages/core/src/core.ts#L67
 | // See: https://github.com/actions/toolkit/blob/master/packages/core/src/core.ts#L67
 | ||||||
| function getInputName(name: string): string { | function getInputName(name: string): string { | ||||||
|   return `INPUT_${name.replace(/ /g, '_').toUpperCase()}`; |   return `INPUT_${name.replace(/ /g, '_').toUpperCase()}`; | ||||||
|  |  | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | debug = true | ||||||
							
								
								
									
										37
									
								
								action.yml
								
								
								
								
							
							
						
						
									
										37
									
								
								action.yml
								
								
								
								
							|  | @ -18,8 +18,13 @@ inputs: | ||||||
|     description: 'List of additional driver-specific options. (eg. image=moby/buildkit:master)' |     description: 'List of additional driver-specific options. (eg. image=moby/buildkit:master)' | ||||||
|     required: false |     required: false | ||||||
|   buildkitd-flags: |   buildkitd-flags: | ||||||
|     description: 'Flags for buildkitd daemon' |     description: 'BuildKit daemon flags' | ||||||
|     default: '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host' |     required: false | ||||||
|  |   buildkitd-config: | ||||||
|  |     description: 'BuildKit daemon config file' | ||||||
|  |     required: false | ||||||
|  |   buildkitd-config-inline: | ||||||
|  |     description: 'Inline BuildKit daemon config' | ||||||
|     required: false |     required: false | ||||||
|   install: |   install: | ||||||
|     description: 'Sets up docker build command as an alias to docker buildx build' |     description: 'Sets up docker build command as an alias to docker buildx build' | ||||||
|  | @ -29,25 +34,39 @@ inputs: | ||||||
|     description: 'Switch to this builder instance' |     description: 'Switch to this builder instance' | ||||||
|     default: 'true' |     default: 'true' | ||||||
|     required: false |     required: false | ||||||
|  |   name: | ||||||
|  |     description: 'Name of the builder. If not specified, one will be generated or if it already exists, it will be used instead of creating a new one.' | ||||||
|  |     required: false | ||||||
|   endpoint: |   endpoint: | ||||||
|     description: 'Optional address for docker socket or context from `docker context ls`' |     description: 'Optional address for docker socket or context from `docker context ls`' | ||||||
|     required: false |     required: false | ||||||
|   platforms: |   platforms: | ||||||
|     description: 'Fixed platforms for current node. If not empty, values take priority over the detected ones' |     description: 'Fixed platforms for current node. If not empty, values take priority over the detected ones' | ||||||
|     required: false |     required: false | ||||||
|   config: |  | ||||||
|     description: 'BuildKit config file' |  | ||||||
|     required: false |  | ||||||
|   config-inline: |  | ||||||
|     description: 'Inline BuildKit config' |  | ||||||
|     required: false |  | ||||||
|   append: |   append: | ||||||
|     description: 'Append additional nodes to the builder' |     description: 'Append additional nodes to the builder' | ||||||
|     required: false |     required: false | ||||||
|  |   keep-state: | ||||||
|  |     description: 'Keep BuildKit state on cleanup. This is only useful on persistent self-hosted runners.' | ||||||
|  |     default: 'false' | ||||||
|  |     required: false | ||||||
|  |   cache-binary: | ||||||
|  |     description: 'Cache buildx binary to GitHub Actions cache backend' | ||||||
|  |     default: 'true' | ||||||
|  |     required: false | ||||||
|   cleanup: |   cleanup: | ||||||
|     description: 'Cleanup temp files and remove builder at the end of a job' |     description: 'Cleanup temp files and remove builder at the end of a job' | ||||||
|     default: 'true' |     default: 'true' | ||||||
|     required: false |     required: false | ||||||
|  |   # TODO: remove deprecated config and config-inline inputs | ||||||
|  |   config: | ||||||
|  |     description: 'BuildKit daemon config file' | ||||||
|  |     deprecationMessage: 'Use buildkitd-config instead' | ||||||
|  |     required: false | ||||||
|  |   config-inline: | ||||||
|  |     description: 'Inline BuildKit daemon config' | ||||||
|  |     deprecationMessage: 'Use buildkitd-config-inline instead' | ||||||
|  |     required: false | ||||||
| 
 | 
 | ||||||
| outputs: | outputs: | ||||||
|   name: |   name: | ||||||
|  | @ -66,6 +85,6 @@ outputs: | ||||||
|     description: 'Builder node flags (deprecated, use nodes output instead)' |     description: 'Builder node flags (deprecated, use nodes output instead)' | ||||||
| 
 | 
 | ||||||
| runs: | runs: | ||||||
|   using: 'node16' |   using: 'node20' | ||||||
|   main: 'dist/index.js' |   main: 'dist/index.js' | ||||||
|   post: 'dist/index.js' |   post: 'dist/index.js' | ||||||
|  |  | ||||||
|  | @ -1,15 +1,20 @@ | ||||||
| # syntax=docker/dockerfile:1 | # syntax=docker/dockerfile:1 | ||||||
| 
 | 
 | ||||||
| ARG NODE_VERSION=16 | ARG NODE_VERSION=20 | ||||||
| ARG DOCKER_VERSION=20.10.13 |  | ||||||
| ARG BUILDX_VERSION=0.8.1 |  | ||||||
| 
 | 
 | ||||||
| FROM node:${NODE_VERSION}-alpine AS base | FROM node:${NODE_VERSION}-alpine AS base | ||||||
| RUN apk add --no-cache cpio findutils git | RUN apk add --no-cache cpio findutils git | ||||||
| WORKDIR /src | WORKDIR /src | ||||||
|  | RUN --mount=type=bind,target=.,rw \ | ||||||
|  |   --mount=type=cache,target=/src/.yarn/cache <<EOT | ||||||
|  |   corepack enable | ||||||
|  |   yarn --version | ||||||
|  |   yarn config set --home enableTelemetry 0 | ||||||
|  | EOT | ||||||
| 
 | 
 | ||||||
| FROM base AS deps | FROM base AS deps | ||||||
| RUN --mount=type=bind,target=.,rw \ | RUN --mount=type=bind,target=.,rw \ | ||||||
|  |   --mount=type=cache,target=/src/.yarn/cache \ | ||||||
|   --mount=type=cache,target=/src/node_modules \ |   --mount=type=cache,target=/src/node_modules \ | ||||||
|   yarn install && mkdir /vendor && cp yarn.lock /vendor |   yarn install && mkdir /vendor && cp yarn.lock /vendor | ||||||
| 
 | 
 | ||||||
|  | @ -18,18 +23,19 @@ COPY --from=deps /vendor / | ||||||
| 
 | 
 | ||||||
| FROM deps AS vendor-validate | FROM deps AS vendor-validate | ||||||
| RUN --mount=type=bind,target=.,rw <<EOT | RUN --mount=type=bind,target=.,rw <<EOT | ||||||
| set -e |   set -e | ||||||
| git add -A |   git add -A | ||||||
| cp -rf /vendor/* . |   cp -rf /vendor/* . | ||||||
| if [ -n "$(git status --porcelain -- yarn.lock)" ]; then |   if [ -n "$(git status --porcelain -- yarn.lock)" ]; then | ||||||
|   echo >&2 'ERROR: Vendor result differs. Please vendor your package with "docker buildx bake vendor-update"' |     echo >&2 'ERROR: Vendor result differs. Please vendor your package with "docker buildx bake vendor"' | ||||||
|   git status --porcelain -- yarn.lock |     git status --porcelain -- yarn.lock | ||||||
|   exit 1 |     exit 1 | ||||||
| fi |   fi | ||||||
| EOT | EOT | ||||||
| 
 | 
 | ||||||
| FROM deps AS build | FROM deps AS build | ||||||
| RUN --mount=type=bind,target=.,rw \ | RUN --mount=type=bind,target=.,rw \ | ||||||
|  |   --mount=type=cache,target=/src/.yarn/cache \ | ||||||
|   --mount=type=cache,target=/src/node_modules \ |   --mount=type=cache,target=/src/node_modules \ | ||||||
|   yarn run build && mkdir /out && cp -Rf dist /out/ |   yarn run build && mkdir /out && cp -Rf dist /out/ | ||||||
| 
 | 
 | ||||||
|  | @ -38,42 +44,37 @@ COPY --from=build /out / | ||||||
| 
 | 
 | ||||||
| FROM build AS build-validate | FROM build AS build-validate | ||||||
| RUN --mount=type=bind,target=.,rw <<EOT | RUN --mount=type=bind,target=.,rw <<EOT | ||||||
| set -e |   set -e | ||||||
| git add -A |   git add -A | ||||||
| cp -rf /out/* . |   cp -rf /out/* . | ||||||
| if [ -n "$(git status --porcelain -- dist)" ]; then |   if [ -n "$(git status --porcelain -- dist)" ]; then | ||||||
|   echo >&2 'ERROR: Build result differs. Please build first with "docker buildx bake build"' |     echo >&2 'ERROR: Build result differs. Please build first with "docker buildx bake build"' | ||||||
|   git status --porcelain -- dist |     git status --porcelain -- dist | ||||||
|   exit 1 |     exit 1 | ||||||
| fi |   fi | ||||||
| EOT | EOT | ||||||
| 
 | 
 | ||||||
| FROM deps AS format | FROM deps AS format | ||||||
| RUN --mount=type=bind,target=.,rw \ | RUN --mount=type=bind,target=.,rw \ | ||||||
|  |   --mount=type=cache,target=/src/.yarn/cache \ | ||||||
|   --mount=type=cache,target=/src/node_modules \ |   --mount=type=cache,target=/src/node_modules \ | ||||||
|   yarn run format \ |   yarn run format \ | ||||||
|   && mkdir /out && find . -name '*.ts' -not -path './node_modules/*' | cpio -pdm /out |   && mkdir /out && find . -name '*.ts' -not -path './node_modules/*' -not -path './.yarn/*' | cpio -pdm /out | ||||||
| 
 | 
 | ||||||
| FROM scratch AS format-update | FROM scratch AS format-update | ||||||
| COPY --from=format /out / | COPY --from=format /out / | ||||||
| 
 | 
 | ||||||
| FROM deps AS lint | FROM deps AS lint | ||||||
| RUN --mount=type=bind,target=.,rw \ | RUN --mount=type=bind,target=.,rw \ | ||||||
|  |   --mount=type=cache,target=/src/.yarn/cache \ | ||||||
|   --mount=type=cache,target=/src/node_modules \ |   --mount=type=cache,target=/src/node_modules \ | ||||||
|   yarn run lint |   yarn run lint | ||||||
| 
 | 
 | ||||||
| FROM docker:${DOCKER_VERSION} as docker |  | ||||||
| FROM docker/buildx-bin:${BUILDX_VERSION} as buildx |  | ||||||
| 
 |  | ||||||
| FROM deps AS test | FROM deps AS test | ||||||
| ENV RUNNER_TEMP=/tmp/github_runner |  | ||||||
| ENV RUNNER_TOOL_CACHE=/tmp/github_tool_cache |  | ||||||
| RUN --mount=type=bind,target=.,rw \ | RUN --mount=type=bind,target=.,rw \ | ||||||
|  |   --mount=type=cache,target=/src/.yarn/cache \ | ||||||
|   --mount=type=cache,target=/src/node_modules \ |   --mount=type=cache,target=/src/node_modules \ | ||||||
|   --mount=type=bind,from=docker,source=/usr/local/bin/docker,target=/usr/bin/docker \ |   yarn run test --coverage --coverageDirectory=/tmp/coverage | ||||||
|   --mount=type=bind,from=buildx,source=/buildx,target=/usr/bin/buildx \ |  | ||||||
|   --mount=type=bind,from=buildx,source=/buildx,target=/usr/libexec/docker/cli-plugins/docker-buildx \ |  | ||||||
|   yarn run test --coverageDirectory=/tmp/coverage |  | ||||||
| 
 | 
 | ||||||
| FROM scratch AS test-coverage | FROM scratch AS test-coverage | ||||||
| COPY --from=test /tmp/coverage / | COPY --from=test /tmp/coverage / | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -1,9 +1,15 @@ | ||||||
|  | target "_common" { | ||||||
|  |   args = { | ||||||
|  |     BUILDKIT_CONTEXT_KEEP_GIT_DIR = 1 | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| group "default" { | group "default" { | ||||||
|   targets = ["build"] |   targets = ["build"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| group "pre-checkin" { | group "pre-checkin" { | ||||||
|   targets = ["vendor-update", "format", "build"] |   targets = ["vendor", "format", "build"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| group "validate" { | group "validate" { | ||||||
|  | @ -11,42 +17,49 @@ group "validate" { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "build" { | target "build" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "build-update" |   target = "build-update" | ||||||
|   output = ["."] |   output = ["."] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "build-validate" { | target "build-validate" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "build-validate" |   target = "build-validate" | ||||||
|   output = ["type=cacheonly"] |   output = ["type=cacheonly"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "format" { | target "format" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "format-update" |   target = "format-update" | ||||||
|   output = ["."] |   output = ["."] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "lint" { | target "lint" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "lint" |   target = "lint" | ||||||
|   output = ["type=cacheonly"] |   output = ["type=cacheonly"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "vendor-update" { | target "vendor" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "vendor-update" |   target = "vendor-update" | ||||||
|   output = ["."] |   output = ["."] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "vendor-validate" { | target "vendor-validate" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "vendor-validate" |   target = "vendor-validate" | ||||||
|   output = ["type=cacheonly"] |   output = ["type=cacheonly"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "test" { | target "test" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "test-coverage" |   target = "test-coverage" | ||||||
|   output = ["./coverage"] |   output = ["./coverage"] | ||||||
|  |  | ||||||
|  | @ -1,3 +0,0 @@ | ||||||
| # Append additional nodes to the builder |  | ||||||
| 
 |  | ||||||
| This page has moved to [Docker Docs website](https://docs.docker.com/build/ci/github-actions/configure-builder/#append-additional-nodes-to-the-builder) |  | ||||||
|  | @ -1,3 +0,0 @@ | ||||||
| # Authentication support |  | ||||||
| 
 |  | ||||||
| This page has moved to [Docker Docs website](https://docs.docker.com/build/ci/github-actions/configure-builder/#authentication-for-remote-builders) |  | ||||||
|  | @ -1,3 +0,0 @@ | ||||||
| # BuildKit daemon configuration |  | ||||||
| 
 |  | ||||||
| This page has moved to [Docker Docs website](https://docs.docker.com/build/ci/github-actions/configure-builder/#buildkit-daemon-configuration) |  | ||||||
|  | @ -1,3 +0,0 @@ | ||||||
| # Standalone mode |  | ||||||
| 
 |  | ||||||
| This page has moved to [Docker Docs website](https://docs.docker.com/build/ci/github-actions/configure-builder/#standalone-mode) |  | ||||||
							
								
								
									
										60
									
								
								package.json
								
								
								
								
							
							
						
						
									
										60
									
								
								package.json
								
								
								
								
							|  | @ -1,13 +1,16 @@ | ||||||
| { | { | ||||||
|   "name": "docker-setup-buildx", |   "name": "docker-setup-buildx", | ||||||
|   "description": "Set up Docker Buildx", |   "description": "Set up Docker Buildx", | ||||||
|   "main": "lib/main.js", |   "main": "src/main.ts", | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "build": "ncc build src/main.ts --source-map --minify --license licenses.txt", |     "build": "ncc build --source-map --minify --license licenses.txt", | ||||||
|     "lint": "eslint src/**/*.ts __tests__/**/*.ts", |     "lint": "yarn run prettier && yarn run eslint", | ||||||
|     "format": "eslint --fix src/**/*.ts __tests__/**/*.ts", |     "format": "yarn run prettier:fix && yarn run eslint:fix", | ||||||
|     "test": "jest --coverage", |     "eslint": "eslint --max-warnings=0 .", | ||||||
|     "all": "yarn run build && yarn run format && yarn test" |     "eslint:fix": "eslint --fix .", | ||||||
|  |     "prettier": "prettier --check \"./**/*.ts\"", | ||||||
|  |     "prettier:fix": "prettier --write \"./**/*.ts\"", | ||||||
|  |     "test": "jest" | ||||||
|   }, |   }, | ||||||
|   "repository": { |   "repository": { | ||||||
|     "type": "git", |     "type": "git", | ||||||
|  | @ -18,34 +21,29 @@ | ||||||
|     "docker", |     "docker", | ||||||
|     "buildx" |     "buildx" | ||||||
|   ], |   ], | ||||||
|   "author": "Docker", |   "author": "Docker Inc.", | ||||||
|   "contributors": [ |  | ||||||
|     { |  | ||||||
|       "name": "CrazyMax", |  | ||||||
|       "url": "https://crazymax.dev" |  | ||||||
|     } |  | ||||||
|   ], |  | ||||||
|   "license": "Apache-2.0", |   "license": "Apache-2.0", | ||||||
|  |   "packageManager": "yarn@4.9.2", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/core": "^1.10.0", |     "@actions/core": "^1.11.1", | ||||||
|     "@actions/exec": "^1.1.1", |     "@docker/actions-toolkit": "^0.63.0", | ||||||
|     "@docker/actions-toolkit": "^0.3.0", |     "js-yaml": "^4.1.0" | ||||||
|     "js-yaml": "^4.1.0", |  | ||||||
|     "uuid": "^9.0.0" |  | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/node": "^16.18.21", |     "@types/js-yaml": "^4.0.9", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.56.0", |     "@types/node": "^20.19.9", | ||||||
|     "@typescript-eslint/parser": "^5.56.0", |     "@types/uuid": "^10.0.0", | ||||||
|     "@vercel/ncc": "^0.36.1", |     "@typescript-eslint/eslint-plugin": "^7.18.0", | ||||||
|     "eslint": "^8.36.0", |     "@typescript-eslint/parser": "^7.18.0", | ||||||
|     "eslint-config-prettier": "^8.8.0", |     "@vercel/ncc": "^0.38.3", | ||||||
|     "eslint-plugin-jest": "^27.2.1", |     "eslint": "^8.57.1", | ||||||
|     "eslint-plugin-prettier": "^4.2.1", |     "eslint-config-prettier": "^9.1.2", | ||||||
|     "jest": "^29.5.0", |     "eslint-plugin-jest": "^28.14.0", | ||||||
|     "prettier": "^2.8.7", |     "eslint-plugin-prettier": "^5.5.4", | ||||||
|     "ts-jest": "^29.0.5", |     "jest": "^29.7.0", | ||||||
|     "ts-node": "^10.9.1", |     "prettier": "^3.6.2", | ||||||
|     "typescript": "^4.9.5" |     "ts-jest": "^29.4.1", | ||||||
|  |     "ts-node": "^10.9.2", | ||||||
|  |     "typescript": "^5.9.2" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,11 +1,14 @@ | ||||||
| import * as uuid from 'uuid'; | import * as crypto from 'crypto'; | ||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
|  | 
 | ||||||
| import {Docker} from '@docker/actions-toolkit/lib/docker/docker'; | import {Docker} from '@docker/actions-toolkit/lib/docker/docker'; | ||||||
| import {Util} from '@docker/actions-toolkit/lib/util'; | import {Util} from '@docker/actions-toolkit/lib/util'; | ||||||
| import {Toolkit} from '@docker/actions-toolkit/lib/toolkit'; | import {Toolkit} from '@docker/actions-toolkit/lib/toolkit'; | ||||||
| import {Node} from '@docker/actions-toolkit/lib/types/builder'; | 
 | ||||||
|  | import {Node} from '@docker/actions-toolkit/lib/types/buildx/builder'; | ||||||
| 
 | 
 | ||||||
| export const builderNodeEnvPrefix = 'BUILDER_NODE'; | export const builderNodeEnvPrefix = 'BUILDER_NODE'; | ||||||
|  | const defaultBuildkitdFlags = '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host'; | ||||||
| 
 | 
 | ||||||
| export interface Inputs { | export interface Inputs { | ||||||
|   version: string; |   version: string; | ||||||
|  | @ -13,46 +16,52 @@ export interface Inputs { | ||||||
|   driver: string; |   driver: string; | ||||||
|   driverOpts: string[]; |   driverOpts: string[]; | ||||||
|   buildkitdFlags: string; |   buildkitdFlags: string; | ||||||
|  |   buildkitdConfig: string; | ||||||
|  |   buildkitdConfigInline: string; | ||||||
|   platforms: string[]; |   platforms: string[]; | ||||||
|   install: boolean; |   install: boolean; | ||||||
|   use: boolean; |   use: boolean; | ||||||
|   endpoint: string; |   endpoint: string; | ||||||
|   config: string; |  | ||||||
|   configInline: string; |  | ||||||
|   append: string; |   append: string; | ||||||
|  |   cacheBinary: boolean; | ||||||
|   cleanup: boolean; |   cleanup: boolean; | ||||||
|  |   keepState: boolean; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function getInputs(): Promise<Inputs> { | export async function getInputs(): Promise<Inputs> { | ||||||
|   return { |   return { | ||||||
|     version: core.getInput('version'), |     version: core.getInput('version'), | ||||||
|     name: await getBuilderName(core.getInput('driver') || 'docker-container'), |     name: await getBuilderName(core.getInput('name'), core.getInput('driver') || 'docker-container'), | ||||||
|     driver: core.getInput('driver') || 'docker-container', |     driver: core.getInput('driver') || 'docker-container', | ||||||
|     driverOpts: Util.getInputList('driver-opts', {ignoreComma: true, quote: false}), |     driverOpts: Util.getInputList('driver-opts', {ignoreComma: true, quote: false}), | ||||||
|     buildkitdFlags: core.getInput('buildkitd-flags') || '--allow-insecure-entitlement security.insecure --allow-insecure-entitlement network.host', |     buildkitdFlags: core.getInput('buildkitd-flags'), | ||||||
|     platforms: Util.getInputList('platforms'), |     platforms: Util.getInputList('platforms'), | ||||||
|     install: core.getBooleanInput('install'), |     install: core.getBooleanInput('install'), | ||||||
|     use: core.getBooleanInput('use'), |     use: core.getBooleanInput('use'), | ||||||
|     endpoint: core.getInput('endpoint'), |     endpoint: core.getInput('endpoint'), | ||||||
|     config: core.getInput('config'), |     buildkitdConfig: core.getInput('buildkitd-config') || core.getInput('config'), | ||||||
|     configInline: core.getInput('config-inline'), |     buildkitdConfigInline: core.getInput('buildkitd-config-inline') || core.getInput('config-inline'), | ||||||
|     append: core.getInput('append'), |     append: core.getInput('append'), | ||||||
|  |     keepState: core.getBooleanInput('keep-state'), | ||||||
|  |     cacheBinary: core.getBooleanInput('cache-binary'), | ||||||
|     cleanup: core.getBooleanInput('cleanup') |     cleanup: core.getBooleanInput('cleanup') | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function getBuilderName(driver: string): Promise<string> { | export async function getBuilderName(name: string, driver: string): Promise<string> { | ||||||
|   return driver == 'docker' ? await Docker.context() : `builder-${uuid.v4()}`; |   return driver == 'docker' ? await Docker.context() : name || `builder-${crypto.randomUUID()}`; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export async function getCreateArgs(inputs: Inputs, toolkit: Toolkit): Promise<Array<string>> { | export async function getCreateArgs(inputs: Inputs, toolkit: Toolkit): Promise<Array<string>> { | ||||||
|   const args: Array<string> = ['create', '--name', inputs.name, '--driver', inputs.driver]; |   const args: Array<string> = ['create', '--name', inputs.name, '--driver', inputs.driver]; | ||||||
|   if (await toolkit.buildx.versionSatisfies('>=0.3.0')) { |   if (await toolkit.buildx.versionSatisfies('>=0.3.0')) { | ||||||
|     await Util.asyncForEach(inputs.driverOpts, async driverOpt => { |     await Util.asyncForEach(inputs.driverOpts, async (driverOpt: string) => { | ||||||
|       args.push('--driver-opt', driverOpt); |       args.push('--driver-opt', driverOpt); | ||||||
|     }); |     }); | ||||||
|     if (inputs.driver != 'remote' && inputs.buildkitdFlags) { |     if (inputs.buildkitdFlags) { | ||||||
|       args.push('--buildkitd-flags', inputs.buildkitdFlags); |       args.push('--buildkitd-flags', inputs.buildkitdFlags); | ||||||
|  |     } else if (driverSupportsBuildkitdFlags(inputs.driver)) { | ||||||
|  |       args.push('--buildkitd-flags', defaultBuildkitdFlags); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   if (inputs.platforms.length > 0) { |   if (inputs.platforms.length > 0) { | ||||||
|  | @ -61,12 +70,10 @@ export async function getCreateArgs(inputs: Inputs, toolkit: Toolkit): Promise<A | ||||||
|   if (inputs.use) { |   if (inputs.use) { | ||||||
|     args.push('--use'); |     args.push('--use'); | ||||||
|   } |   } | ||||||
|   if (inputs.driver != 'remote') { |   if (inputs.buildkitdConfig) { | ||||||
|     if (inputs.config) { |     args.push('--config', toolkit.buildkit.config.resolveFromFile(inputs.buildkitdConfig)); | ||||||
|       args.push('--config', toolkit.buildkit.config.resolveFromFile(inputs.config)); |   } else if (inputs.buildkitdConfigInline) { | ||||||
|     } else if (inputs.configInline) { |     args.push('--config', toolkit.buildkit.config.resolveFromString(inputs.buildkitdConfigInline)); | ||||||
|       args.push('--config', toolkit.buildkit.config.resolveFromString(inputs.configInline)); |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|   if (inputs.endpoint) { |   if (inputs.endpoint) { | ||||||
|     args.push(inputs.endpoint); |     args.push(inputs.endpoint); | ||||||
|  | @ -79,14 +86,16 @@ export async function getAppendArgs(inputs: Inputs, node: Node, toolkit: Toolkit | ||||||
|   if (node.name) { |   if (node.name) { | ||||||
|     args.push('--node', node.name); |     args.push('--node', node.name); | ||||||
|   } else if (inputs.driver == 'kubernetes' && (await toolkit.buildx.versionSatisfies('<0.11.0'))) { |   } else if (inputs.driver == 'kubernetes' && (await toolkit.buildx.versionSatisfies('<0.11.0'))) { | ||||||
|     args.push('--node', `node-${uuid.v4()}`); |     args.push('--node', `node-${crypto.randomUUID()}`); | ||||||
|   } |   } | ||||||
|   if (node['driver-opts'] && (await toolkit.buildx.versionSatisfies('>=0.3.0'))) { |   if (node['driver-opts'] && (await toolkit.buildx.versionSatisfies('>=0.3.0'))) { | ||||||
|     await Util.asyncForEach(node['driver-opts'], async driverOpt => { |     await Util.asyncForEach(node['driver-opts'], async (driverOpt: string) => { | ||||||
|       args.push('--driver-opt', driverOpt); |       args.push('--driver-opt', driverOpt); | ||||||
|     }); |     }); | ||||||
|     if (inputs.driver != 'remote' && node['buildkitd-flags']) { |     if (node['buildkitd-flags']) { | ||||||
|       args.push('--buildkitd-flags', node['buildkitd-flags']); |       args.push('--buildkitd-flags', node['buildkitd-flags']); | ||||||
|  |     } else if (driverSupportsBuildkitdFlags(inputs.driver)) { | ||||||
|  |       args.push('--buildkitd-flags', defaultBuildkitdFlags); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   if (node.platforms) { |   if (node.platforms) { | ||||||
|  | @ -105,3 +114,21 @@ export async function getInspectArgs(inputs: Inputs, toolkit: Toolkit): Promise< | ||||||
|   } |   } | ||||||
|   return args; |   return args; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | function driverSupportsBuildkitdFlags(driver: string): boolean { | ||||||
|  |   return driver == '' || driver == 'docker-container' || driver == 'docker' || driver == 'kubernetes'; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export function getVersion(inputs: Inputs): string { | ||||||
|  |   const version = inputs.version; | ||||||
|  |   if (inputs.driver === 'cloud') { | ||||||
|  |     if (!version || version === 'latest') { | ||||||
|  |       return 'cloud:latest'; | ||||||
|  |     } | ||||||
|  |     if (version.startsWith('cloud:') || version.startsWith('lab:')) { | ||||||
|  |       return version; | ||||||
|  |     } | ||||||
|  |     return `cloud:${version}`; | ||||||
|  |   } | ||||||
|  |   return version; | ||||||
|  | } | ||||||
|  |  | ||||||
							
								
								
									
										179
									
								
								src/main.ts
								
								
								
								
							
							
						
						
									
										179
									
								
								src/main.ts
								
								
								
								
							|  | @ -1,14 +1,18 @@ | ||||||
|  | import * as crypto from 'crypto'; | ||||||
| import * as fs from 'fs'; | import * as fs from 'fs'; | ||||||
| import * as yaml from 'js-yaml'; | import * as yaml from 'js-yaml'; | ||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| import * as exec from '@actions/exec'; |  | ||||||
| import * as actionsToolkit from '@docker/actions-toolkit'; | import * as actionsToolkit from '@docker/actions-toolkit'; | ||||||
|  | 
 | ||||||
| import {Buildx} from '@docker/actions-toolkit/lib/buildx/buildx'; | import {Buildx} from '@docker/actions-toolkit/lib/buildx/buildx'; | ||||||
| import {Builder} from '@docker/actions-toolkit/lib/buildx/builder'; | import {Builder} from '@docker/actions-toolkit/lib/buildx/builder'; | ||||||
| import {Docker} from '@docker/actions-toolkit/lib/docker/docker'; | import {Docker} from '@docker/actions-toolkit/lib/docker/docker'; | ||||||
|  | import {Exec} from '@docker/actions-toolkit/lib/exec'; | ||||||
| import {Toolkit} from '@docker/actions-toolkit/lib/toolkit'; | import {Toolkit} from '@docker/actions-toolkit/lib/toolkit'; | ||||||
| import {Util} from '@docker/actions-toolkit/lib/util'; | import {Util} from '@docker/actions-toolkit/lib/util'; | ||||||
| import {Node} from '@docker/actions-toolkit/lib/types/builder'; | 
 | ||||||
|  | import {Node} from '@docker/actions-toolkit/lib/types/buildx/builder'; | ||||||
|  | import {ContextInfo} from '@docker/actions-toolkit/lib/types/docker/docker'; | ||||||
| 
 | 
 | ||||||
| import * as context from './context'; | import * as context from './context'; | ||||||
| import * as stateHelper from './state-helper'; | import * as stateHelper from './state-helper'; | ||||||
|  | @ -18,11 +22,18 @@ actionsToolkit.run( | ||||||
|   async () => { |   async () => { | ||||||
|     const inputs: context.Inputs = await context.getInputs(); |     const inputs: context.Inputs = await context.getInputs(); | ||||||
|     stateHelper.setCleanup(inputs.cleanup); |     stateHelper.setCleanup(inputs.cleanup); | ||||||
|  |     const version = context.getVersion(inputs); | ||||||
| 
 | 
 | ||||||
|     const toolkit = new Toolkit(); |     const toolkit = new Toolkit(); | ||||||
|     const standalone = await toolkit.buildx.isStandalone(); |     const standalone = await toolkit.buildx.isStandalone(); | ||||||
|     stateHelper.setStandalone(standalone); |     stateHelper.setStandalone(standalone); | ||||||
| 
 | 
 | ||||||
|  |     if (inputs.keepState && inputs.driver !== 'docker-container') { | ||||||
|  |       // https://docs.docker.com/reference/cli/docker/buildx/rm/#keep-state
 | ||||||
|  |       throw new Error(`Cannot use keep-state with ${inputs.driver} driver`); | ||||||
|  |     } | ||||||
|  |     stateHelper.setKeepState(inputs.keepState); | ||||||
|  | 
 | ||||||
|     await core.group(`Docker info`, async () => { |     await core.group(`Docker info`, async () => { | ||||||
|       try { |       try { | ||||||
|         await Docker.printVersion(); |         await Docker.printVersion(); | ||||||
|  | @ -33,16 +44,16 @@ actionsToolkit.run( | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     let toolPath; |     let toolPath; | ||||||
|     if (Util.isValidRef(inputs.version)) { |     if (Util.isValidRef(version)) { | ||||||
|       if (standalone) { |       if (standalone) { | ||||||
|         throw new Error(`Cannot build from source without the Docker CLI`); |         throw new Error(`Cannot build from source without the Docker CLI`); | ||||||
|       } |       } | ||||||
|       await core.group(`Build buildx from source`, async () => { |       await core.group(`Build buildx from source`, async () => { | ||||||
|         toolPath = await toolkit.buildxInstall.build(inputs.version); |         toolPath = await toolkit.buildxInstall.build(version, !inputs.cacheBinary); | ||||||
|       }); |       }); | ||||||
|     } else if (!(await toolkit.buildx.isAvailable()) || inputs.version) { |     } else if (!(await toolkit.buildx.isAvailable()) || version) { | ||||||
|       await core.group(`Download buildx from GitHub Releases`, async () => { |       await core.group(`Download buildx from GitHub Releases`, async () => { | ||||||
|         toolPath = await toolkit.buildxInstall.download(inputs.version || 'latest'); |         toolPath = await toolkit.buildxInstall.download(version || 'latest', !inputs.cacheBinary); | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
|     if (toolPath) { |     if (toolPath) { | ||||||
|  | @ -66,18 +77,73 @@ actionsToolkit.run( | ||||||
|     fs.mkdirSync(Buildx.certsDir, {recursive: true}); |     fs.mkdirSync(Buildx.certsDir, {recursive: true}); | ||||||
|     stateHelper.setCertsDir(Buildx.certsDir); |     stateHelper.setCertsDir(Buildx.certsDir); | ||||||
| 
 | 
 | ||||||
|  |     // if the default context has TLS data loaded and endpoint is not set, then
 | ||||||
|  |     // we create a temporary docker context only if driver is docker-container
 | ||||||
|  |     // https://github.com/docker/buildx/blob/b96ad59f64d40873e4959336d294b648bb3937fe/builder/builder.go#L489
 | ||||||
|  |     // https://github.com/docker/setup-buildx-action/issues/105
 | ||||||
|  |     if (!standalone && inputs.driver == 'docker-container' && (await Docker.context()) == 'default' && inputs.endpoint.length == 0) { | ||||||
|  |       let defaultContextWithTLS: boolean = false; | ||||||
|  |       await core.group(`Inspecting default docker context`, async () => { | ||||||
|  |         await Docker.getExecOutput(['context', 'inspect', '--format=json', 'default'], { | ||||||
|  |           ignoreReturnCode: true, | ||||||
|  |           silent: true | ||||||
|  |         }).then(res => { | ||||||
|  |           if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |             core.info(`Cannot inspect default docker context: ${res.stderr.trim()}`); | ||||||
|  |           } else { | ||||||
|  |             try { | ||||||
|  |               const contextInfo = (<Array<ContextInfo>>JSON.parse(res.stdout.trim()))[0]; | ||||||
|  |               core.info(JSON.stringify(JSON.parse(res.stdout.trim()), undefined, 2)); | ||||||
|  |               const hasTLSData = Object.keys(contextInfo.Endpoints).length > 0 && Object.values(contextInfo.Endpoints)[0].TLSData !== undefined; | ||||||
|  |               const hasTLSMaterial = Object.keys(contextInfo.TLSMaterial).length > 0 && Object.values(contextInfo.TLSMaterial)[0].length > 0; | ||||||
|  |               defaultContextWithTLS = hasTLSData || hasTLSMaterial; | ||||||
|  |             } catch (e) { | ||||||
|  |               core.info(`Unable to parse default docker context info: ${e}`); | ||||||
|  |               core.info(res.stdout.trim()); | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         }); | ||||||
|  |       }); | ||||||
|  |       if (defaultContextWithTLS) { | ||||||
|  |         const tmpDockerContext = `buildx-${crypto.randomUUID()}`; | ||||||
|  |         await core.group(`Creating temp docker context (TLS data loaded in default one)`, async () => { | ||||||
|  |           await Docker.getExecOutput(['context', 'create', tmpDockerContext], { | ||||||
|  |             ignoreReturnCode: true | ||||||
|  |           }).then(res => { | ||||||
|  |             if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |               core.warning(`Cannot create docker context ${tmpDockerContext}: ${res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'}`); | ||||||
|  |             } else { | ||||||
|  |               core.info(`Setting builder endpoint to ${tmpDockerContext} context`); | ||||||
|  |               inputs.endpoint = tmpDockerContext; | ||||||
|  |               stateHelper.setTmpDockerContext(tmpDockerContext); | ||||||
|  |             } | ||||||
|  |           }); | ||||||
|  |         }); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     if (inputs.driver !== 'docker') { |     if (inputs.driver !== 'docker') { | ||||||
|       await core.group(`Creating a new builder instance`, async () => { |       await core.group(`Creating a new builder instance`, async () => { | ||||||
|         const certsDriverOpts = Buildx.resolveCertsDriverOpts(inputs.driver, inputs.endpoint, { |         if (await toolkit.builder.exists(inputs.name)) { | ||||||
|           cacert: process.env[`${context.builderNodeEnvPrefix}_0_AUTH_TLS_CACERT`], |           core.info(`Builder ${inputs.name} already exists, skipping creation`); | ||||||
|           cert: process.env[`${context.builderNodeEnvPrefix}_0_AUTH_TLS_CERT`], |         } else { | ||||||
|           key: process.env[`${context.builderNodeEnvPrefix}_0_AUTH_TLS_KEY`] |           const certsDriverOpts = Buildx.resolveCertsDriverOpts(inputs.driver, inputs.endpoint, { | ||||||
|         }); |             cacert: process.env[`${context.builderNodeEnvPrefix}_0_AUTH_TLS_CACERT`], | ||||||
|         if (certsDriverOpts.length > 0) { |             cert: process.env[`${context.builderNodeEnvPrefix}_0_AUTH_TLS_CERT`], | ||||||
|           inputs.driverOpts = [...inputs.driverOpts, ...certsDriverOpts]; |             key: process.env[`${context.builderNodeEnvPrefix}_0_AUTH_TLS_KEY`] | ||||||
|  |           }); | ||||||
|  |           if (certsDriverOpts.length > 0) { | ||||||
|  |             inputs.driverOpts = [...inputs.driverOpts, ...certsDriverOpts]; | ||||||
|  |           } | ||||||
|  |           const createCmd = await toolkit.buildx.getCommand(await context.getCreateArgs(inputs, toolkit)); | ||||||
|  |           await Exec.getExecOutput(createCmd.command, createCmd.args, { | ||||||
|  |             ignoreReturnCode: true | ||||||
|  |           }).then(res => { | ||||||
|  |             if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |               throw new Error(res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'); | ||||||
|  |             } | ||||||
|  |           }); | ||||||
|         } |         } | ||||||
|         const createCmd = await toolkit.buildx.getCommand(await context.getCreateArgs(inputs, toolkit)); |  | ||||||
|         await exec.exec(createCmd.command, createCmd.args); |  | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -95,7 +161,13 @@ actionsToolkit.run( | ||||||
|             node['driver-opts'] = [...(node['driver-opts'] || []), ...certsDriverOpts]; |             node['driver-opts'] = [...(node['driver-opts'] || []), ...certsDriverOpts]; | ||||||
|           } |           } | ||||||
|           const appendCmd = await toolkit.buildx.getCommand(await context.getAppendArgs(inputs, node, toolkit)); |           const appendCmd = await toolkit.buildx.getCommand(await context.getAppendArgs(inputs, node, toolkit)); | ||||||
|           await exec.exec(appendCmd.command, appendCmd.args); |           await Exec.getExecOutput(appendCmd.command, appendCmd.args, { | ||||||
|  |             ignoreReturnCode: true | ||||||
|  |           }).then(res => { | ||||||
|  |             if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |               throw new Error(`Failed to append node ${node.name}: ${res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'}`); | ||||||
|  |             } | ||||||
|  |           }); | ||||||
|           nodeIndex++; |           nodeIndex++; | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|  | @ -103,7 +175,13 @@ actionsToolkit.run( | ||||||
| 
 | 
 | ||||||
|     await core.group(`Booting builder`, async () => { |     await core.group(`Booting builder`, async () => { | ||||||
|       const inspectCmd = await toolkit.buildx.getCommand(await context.getInspectArgs(inputs, toolkit)); |       const inspectCmd = await toolkit.buildx.getCommand(await context.getInspectArgs(inputs, toolkit)); | ||||||
|       await exec.exec(inspectCmd.command, inspectCmd.args); |       await Exec.getExecOutput(inspectCmd.command, inspectCmd.args, { | ||||||
|  |         ignoreReturnCode: true | ||||||
|  |       }).then(res => { | ||||||
|  |         if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |           throw new Error(res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'); | ||||||
|  |         } | ||||||
|  |       }); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     if (inputs.install) { |     if (inputs.install) { | ||||||
|  | @ -111,8 +189,15 @@ actionsToolkit.run( | ||||||
|         throw new Error(`Cannot set buildx as default builder without the Docker CLI`); |         throw new Error(`Cannot set buildx as default builder without the Docker CLI`); | ||||||
|       } |       } | ||||||
|       await core.group(`Setting buildx as default builder`, async () => { |       await core.group(`Setting buildx as default builder`, async () => { | ||||||
|  |         stateHelper.setBuildxIsDefaultBuilder(true); | ||||||
|         const installCmd = await toolkit.buildx.getCommand(['install']); |         const installCmd = await toolkit.buildx.getCommand(['install']); | ||||||
|         await exec.exec(installCmd.command, installCmd.args); |         await Exec.getExecOutput(installCmd.command, installCmd.args, { | ||||||
|  |           ignoreReturnCode: true | ||||||
|  |         }).then(res => { | ||||||
|  |           if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |             throw new Error(res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'); | ||||||
|  |           } | ||||||
|  |         }); | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -155,15 +240,13 @@ actionsToolkit.run( | ||||||
|   async () => { |   async () => { | ||||||
|     if (stateHelper.IsDebug && stateHelper.containerName.length > 0) { |     if (stateHelper.IsDebug && stateHelper.containerName.length > 0) { | ||||||
|       await core.group(`BuildKit container logs`, async () => { |       await core.group(`BuildKit container logs`, async () => { | ||||||
|         await exec |         await Docker.getExecOutput(['logs', `${stateHelper.containerName}`], { | ||||||
|           .getExecOutput('docker', ['logs', `${stateHelper.containerName}`], { |           ignoreReturnCode: true | ||||||
|             ignoreReturnCode: true |         }).then(res => { | ||||||
|           }) |           if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|           .then(res => { |             core.warning(res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'); | ||||||
|             if (res.stderr.length > 0 && res.exitCode != 0) { |           } | ||||||
|               core.warning(res.stderr.trim()); |         }); | ||||||
|             } |  | ||||||
|           }); |  | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -176,26 +259,48 @@ actionsToolkit.run( | ||||||
|         const buildx = new Buildx({standalone: stateHelper.standalone}); |         const buildx = new Buildx({standalone: stateHelper.standalone}); | ||||||
|         const builder = new Builder({buildx: buildx}); |         const builder = new Builder({buildx: buildx}); | ||||||
|         if (await builder.exists(stateHelper.builderName)) { |         if (await builder.exists(stateHelper.builderName)) { | ||||||
|           const rmCmd = await buildx.getCommand(['rm', stateHelper.builderName]); |           const rmCmd = await buildx.getCommand(['rm', stateHelper.builderName, ...(stateHelper.keepState ? ['--keep-state'] : [])]); | ||||||
|           await exec |           await Exec.getExecOutput(rmCmd.command, rmCmd.args, { | ||||||
|             .getExecOutput(rmCmd.command, rmCmd.args, { |             ignoreReturnCode: true | ||||||
|               ignoreReturnCode: true |           }).then(res => { | ||||||
|             }) |             if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|             .then(res => { |               core.warning(res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'); | ||||||
|               if (res.stderr.length > 0 && res.exitCode != 0) { |             } | ||||||
|                 core.warning(res.stderr.trim()); |           }); | ||||||
|               } |  | ||||||
|             }); |  | ||||||
|         } else { |         } else { | ||||||
|           core.info(`${stateHelper.builderName} does not exist`); |           core.info(`${stateHelper.builderName} does not exist`); | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     if (stateHelper.tmpDockerContext) { | ||||||
|  |       await core.group(`Removing temp docker context`, async () => { | ||||||
|  |         await Exec.getExecOutput('docker', ['context', 'rm', '-f', stateHelper.tmpDockerContext], { | ||||||
|  |           ignoreReturnCode: true | ||||||
|  |         }).then(res => { | ||||||
|  |           if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |             core.warning(`${res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'}`); | ||||||
|  |           } | ||||||
|  |         }); | ||||||
|  |       }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     if (stateHelper.certsDir.length > 0 && fs.existsSync(stateHelper.certsDir)) { |     if (stateHelper.certsDir.length > 0 && fs.existsSync(stateHelper.certsDir)) { | ||||||
|       await core.group(`Cleaning up certificates`, async () => { |       await core.group(`Cleaning up certificates`, async () => { | ||||||
|         fs.rmSync(stateHelper.certsDir, {recursive: true}); |         fs.rmSync(stateHelper.certsDir, {recursive: true}); | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     if (stateHelper.buildxIsDefaultBuilder) { | ||||||
|  |       await core.group(`Restoring default builder`, async () => { | ||||||
|  |         await Exec.getExecOutput('docker', ['buildx', 'uninstall'], { | ||||||
|  |           ignoreReturnCode: true | ||||||
|  |         }).then(res => { | ||||||
|  |           if (res.stderr.length > 0 && res.exitCode != 0) { | ||||||
|  |             core.warning(`${res.stderr.match(/(.*)\s*$/)?.[0]?.trim() ?? 'unknown error'}`); | ||||||
|  |           } | ||||||
|  |         }); | ||||||
|  |       }); | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| ); | ); | ||||||
|  |  | ||||||
|  | @ -6,7 +6,10 @@ export const builderName = process.env['STATE_builderName'] || ''; | ||||||
| export const builderDriver = process.env['STATE_builderDriver'] || ''; | export const builderDriver = process.env['STATE_builderDriver'] || ''; | ||||||
| export const containerName = process.env['STATE_containerName'] || ''; | export const containerName = process.env['STATE_containerName'] || ''; | ||||||
| export const certsDir = process.env['STATE_certsDir'] || ''; | export const certsDir = process.env['STATE_certsDir'] || ''; | ||||||
|  | export const tmpDockerContext = process.env['STATE_tmpDockerContext'] || ''; | ||||||
| export const cleanup = /true/i.test(process.env['STATE_cleanup'] || ''); | export const cleanup = /true/i.test(process.env['STATE_cleanup'] || ''); | ||||||
|  | export const buildxIsDefaultBuilder = /true/i.test(process.env['STATE_buildxIsDefaultBuilder'] || ''); | ||||||
|  | export const keepState = /true/i.test(process.env['STATE_keepState'] || ''); | ||||||
| 
 | 
 | ||||||
| export function setDebug(debug: string) { | export function setDebug(debug: string) { | ||||||
|   core.saveState('isDebug', debug); |   core.saveState('isDebug', debug); | ||||||
|  | @ -32,6 +35,18 @@ export function setCertsDir(certsDir: string) { | ||||||
|   core.saveState('certsDir', certsDir); |   core.saveState('certsDir', certsDir); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | export function setTmpDockerContext(tmpDockerContext: string) { | ||||||
|  |   core.saveState('tmpDockerContext', tmpDockerContext); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export function setCleanup(cleanup: boolean) { | export function setCleanup(cleanup: boolean) { | ||||||
|   core.saveState('cleanup', cleanup); |   core.saveState('cleanup', cleanup); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | export function setBuildxIsDefaultBuilder(buildxIsDefaultBuilder: boolean) { | ||||||
|  |   core.saveState('buildxIsDefaultBuilder', buildxIsDefaultBuilder); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export function setKeepState(keepState: boolean) { | ||||||
|  |   core.saveState('keepState', keepState); | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue