Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test.yml: use image cache with parameters created from template #2508

Conversation

norio-nomura
Copy link
Contributor

@norio-nomura norio-nomura commented Jul 24, 2024

This should reduce the cache size used by the CI.

This change adds ./.github/actions/setup_cache_for_template to set up the cache using templates in tests, and utilizes it in test.yml.

For example, when using templates/default.yaml:

    - name: Cache image used by default.yaml
      uses: ./.github/actions/setup_cache_for_template
      with:
        template: templates/default.yaml

templates/default.yaml:

images:
- location: "https://cloud-images.ubuntu.com/releases/24.04/release-20240423/ubuntu-24.04-server-cloudimg-amd64.img"
  arch: "x86_64"
  digest: "sha256:32a9d30d18803da72f5936cf2b7b9efcb4d0bb63c67933f17e3bdfd1751de3f3"

The corresponding arch's location and digest are read from the images section and used to set up the cache as follows:

  uses: actions/cache@v4
  with:
    path: .download/by-url-sha256/b5438b965b068d0c98c8f6ad42a7ca16ad7a245d98a60d9a7826a4679de739a7
    key: image-sha256:32a9d30d18803da72f5936cf2b7b9efcb4d0bb63c67933f17e3bdfd1751de3f3
    enableCrossOsArchive: true
  • By using a relative path from the working directory for path, it avoids using ~ which expands to different absolute paths on different platforms.
  • .download is a symbolic link to ~/Library/Caches/lima/download on macOS and ~/.cache/lima/download on Linux, making it usable on both platforms.
  • The key uses image- + digest, ensuring the cache is not reused if the digest changes while the location remains the same (though such a scenario is rare). If the digest is absent, it falls back to ${{ runner.os }}-${{ hashFiles(inputs.template) }}.
  • Setting enableCrossOsArchive allows sharing the cache between macOS and Linux.

Additionally, ./.github/actions/setup_cache_for_template can accept a URL for the template, allowing cache setup for remote templates in upgrade tests:

    - name: Cache image used by ${{ matrix.oldver }}/examples/ubuntu-lts.yaml
      uses: ./.github/actions/setup_cache_for_template
      with:
        template: https://raw.githubusercontent.com/lima-vm/lima/${{ matrix.oldver }}/examples/ubuntu-lts.yaml

Since many templates use the same images, this approach reduces cache usage more effectively than using the template file as the hash key.

Thanks,

@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch 12 times, most recently from d839954 to ec43bfb Compare July 24, 2024 12:58
@norio-nomura
Copy link
Contributor Author

norio-nomura commented Jul 24, 2024

Some templates download not only images but also nerdctl, so using only the image digest for caching might result in nerdctl not being cached. However, I believe that reducing the cache size should be prioritized over this.

Looking at the current cache status, it appears that some caches contain empty directories due to trial and error during the work process. I believe this can be resolved either by deleting the caches or by having the caches recreated when the PR is merged.
cache keys that contains empty directory:

(keys has been expired.)

@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from ec43bfb to 8a09f1c Compare July 25, 2024 00:33
@norio-nomura norio-nomura changed the title test.yml: use a digest of image in template as key for cache test.yml: use image cache with parameters created from template Jul 25, 2024
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from 8a09f1c to 2e32b6f Compare July 25, 2024 00:43
@norio-nomura
Copy link
Contributor Author

Updated to create image caches on a per-directory basis under by-url-sha256/{sha256sum of location}.

@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from a1050c7 to 47e601f Compare July 25, 2024 01:47
@norio-nomura
Copy link
Contributor Author

It seems the image.location used in hack/test-templates/test-misc.yaml returns 404.

- location: "https://cloud-images.ubuntu.com/releases/22.04/release-20220902/ubuntu-22.04-server-cloudimg-amd64.img"
  arch: "x86_64"
  digest: "sha256:c777670007cc5f132417b9e0bc01367ccfc2a989951ffa225bb1952917c3aa81"
- location: "https://cloud-images.ubuntu.com/releases/22.04/release-20220902/ubuntu-22.04-server-cloudimg-arm64.img"
  arch: "aarch64"
  digest: "sha256:9620f479bd5a6cbf1e805654d41b27f4fc56ef20f916c8331558241734de81ae"

https://github.com/lima-vm/lima/actions/runs/10086752926/job/27889808281?pr=2508#step:10:11

@norio-nomura
Copy link
Contributor Author

It seems the image.location used in hack/test-templates/test-misc.yaml returns 404.

I created #2513 to checking remote image existence on ci.

@norio-nomura
Copy link
Contributor Author

Updated PR description: #2508 (comment)

@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from 47e601f to 072f9d6 Compare July 28, 2024 02:57
@AkihiroSuda AkihiroSuda added the area/test Tests and CI label Jul 30, 2024
@AkihiroSuda AkihiroSuda requested review from a team July 30, 2024 21:49
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from 072f9d6 to 41923ae Compare July 31, 2024 00:01
@norio-nomura
Copy link
Contributor Author

fixed commit message(key: "digest-$digest" -> key: "image-$digest") and force pushed

@@ -0,0 +1,88 @@
name: 'setup cache for template'
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for your dedicated work. Is it possible to measure how much we are saving by implementing caching in this GitHub Action workflow?

We need to understand the benefits we will receive if we merge this pull request.

Copy link
Contributor Author

@norio-nomura norio-nomura Aug 3, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To answer the question, I created a script to calculate the cache size usage and committed it at 9bb92f3.

Running the script produces the following output:

$ hack/calculate-cache.sh
==> expected content size, actual cached size, and cache-keys used in caching method prior implementation in https://github.com/lima-vm/lima/pull/2508
content-size actual-size cache-key
  784.84 MiB <<missing>> Linux-1c3b2791d52735d916dc44767c745c2319eb7cae74af71bbf45ddb268f42fc1d
  605.53 MiB <<missing>> Linux-231c66957fc2cdb18ea10e63f60770049026e29051ecd6598fc390b60d6a4fa6
   74.00 MiB <<missing>> Linux-69a547b760dbf1650007ed541408474237bc611704077214adcac292de556444
  554.60 MiB <<missing>> Linux-710b470b49a6cc49e1ef9cb911e6e749311dc44bb6a9c29493ffe97a21c9abd5
  474.86 MiB <<missing>> Linux-7782f8b4ff8cd378377eb79f8d61c9559b94bbd0c11d19eb380ee7bda19af04e
  723.24 MiB <<missing>> Linux-a1122da40e693040c8f499d00dd9b8634eb070648e543de6436e24ef8f149067
  453.00 MiB <<missing>> Linux-ad6e29b3057a13dfd0cac759735d0aac4bb6c9c6aad480f957be363685efb646
  784.84 MiB  774.10 MiB Linux-de83bce0608d787e3c68c7a31c5fab2b6d054320fd7bf633a031845e2ee03414
   72.00 MiB <<missing>> Linux-f88f0b3b678ff6432386a42bdd27661133c84a36ad29f393da407c871b0143eb
  679.46 MiB  669.58 MiB Linux-fb77ce057fac31cb2e2ec5d8c8e9fc6e385a662090373e35a557a3aff7e1d7e4
  878.96 MiB <<missing>> macOS-10ad71d670ff0c9a346871f49f665972f8f8f201c47b4dd573e54ae1053ebb63
  605.53 MiB <<missing>> macOS-231c66957fc2cdb18ea10e63f60770049026e29051ecd6598fc390b60d6a4fa6
  784.84 MiB <<missing>> macOS-8f37f663956af5f743f0f99ab973729b6a02f200ebfac7a3a036eff296550732
  679.46 MiB <<missing>> macOS-b3b32541a86504a4206a16a3a8cb27098edb89176bd51f6dd81d2130ef6160ad
  679.46 MiB <<missing>> macOS-f174bdf75da4cd402b862784fcafca4fff2e690cab986351201496447ed96bb9
------------
 8834.64 MiB

==> expected content size, actual cached size, and cache-keys used in caching method after implementation in https://github.com/lima-vm/lima/pull/2508
content-size actual-size cache-key
  226.46 MiB  226.43 MiB containerd:nerdctl-full-1.7.6-linux-amd64.tar.gz-sha256:2c841e097fcfb5a1760bd354b3778cb695b44cd01f9f271c17507dc4a0b25606
  496.77 MiB <<missing>> image:Arch-Linux-x86_64-cloudimg.qcow2-url-sha256:f84cefea6f889e36ddc5a7ffc1368a9aa95fd24b4589e1f79aab7ab85325d065
  379.06 MiB  377.28 MiB image:Fedora-Cloud-Base-Generic.x86_64-40-1.14.qcow2-sha256:ac58f3c35b73272d5986fa6d3bc44fd246b45df4c334e99a07b3bbd00684adee
   72.00 MiB   65.34 MiB image:alpine-lima-std-3.19.0-x86_64.iso-sha512:568852df405e6b9858e678171a9894c058f483df0b0570c22cf33fc75f349ba6cc5bb3d50188180d8c31faaf53400fe884ca3e5f949961b03b2bf53e65de88d7
   74.00 MiB   67.05 MiB image:alpine-lima-std-3.20.0-x86_64.iso-sha512:df013ba0666460c9e303e996e46e061e613ce546124a9de60060041874c702444ac7a90e67f1aed4756b85cc89d40c5ea4375dea62c98b9536ceb44f18874b67
  328.14 MiB  320.45 MiB image:debian-12-genericcloud-amd64-20240429-1732.qcow2-sha512:6cc752d71b390c7fea64b0b598225914a7f4adacd4a33fa366187fac01094648628e0681a109ae9320b9a79aba2832f33395fa13154dad636465b7d9cdbed599
  248.40 MiB  245.08 MiB image:openSUSE-Leap-15.5-Minimal-VM.x86_64-Cloud.qcow2-url-sha256:713f6146e29554b9092f147652323bc0625a501abccc82dff249e139df8fade3
  652.50 MiB  644.52 MiB image:ubuntu-22.04-server-cloudimg-amd64.img-sha256:345fbbb6ec827ca02ec1a1ced90f7d40d3fd345811ba97c5772ac40e951458e1
  453.00 MiB  443.15 MiB image:ubuntu-24.04-server-cloudimg-amd64.img-sha256:32a9d30d18803da72f5936cf2b7b9efcb4d0bb63c67933f17e3bdfd1751de3f3
  558.38 MiB  547.64 MiB image:ubuntu-24.04-server-cloudimg-amd64.img-url-sha256:3b6b67faf5fd451e96832cbcaf6f5e04704d2ff7c47e749663508fc2a636130f
------------
 3488.72 MiB

It appears that the cache is stored in a compressed format, so the actual cache size is somewhat smaller than the size of the downloaded content. However, I believe the results are generally accurate and this should answer the question.

During the process of creating this response, several improvements were made to utilize the cache more efficiently. Thank you for the question.

Copy link
Contributor Author

@norio-nomura norio-nomura Aug 5, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Rebased on master(6c2bfaa).
Following is output of hack/calculate-cache.sh

$ hack/calculate-cache.sh
==> expected content size, actual cached size, and cache-keys used in caching method prior implementation in https://github.com/lima-vm/lima/pull/2508
content-size actual-size cache-key
  784.84 MiB  774.11 MiB Linux-1c3b2791d52735d916dc44767c745c2319eb7cae74af71bbf45ddb268f42fc1d
  605.53 MiB  603.70 MiB Linux-231c66957fc2cdb18ea10e63f60770049026e29051ecd6598fc390b60d6a4fa6
  558.38 MiB  547.67 MiB Linux-3b906d46fa532e3bc348c35fc8e7ede6c69f0b27032046ee2cbb56d4022d1146
   74.00 MiB <<missing>> Linux-69a547b760dbf1650007ed541408474237bc611704077214adcac292de556444
  474.86 MiB  471.56 MiB Linux-7782f8b4ff8cd378377eb79f8d61c9559b94bbd0c11d19eb380ee7bda19af04e
  784.84 MiB  775.04 MiB Linux-8812aedfe81b4456d421645928b493b1f2f88aff04b7f3171207492fd44cd189
  723.24 MiB <<missing>> Linux-a1122da40e693040c8f499d00dd9b8634eb070648e543de6436e24ef8f149067
  784.84 MiB  774.10 MiB Linux-de83bce0608d787e3c68c7a31c5fab2b6d054320fd7bf633a031845e2ee03414
  552.05 MiB  543.28 MiB Linux-eb88a19dfcf2fb98278e7c7e941c143737c6d7cd8950a88f58e04b4ee7cef1bc
   72.00 MiB   65.31 MiB Linux-f88f0b3b678ff6432386a42bdd27661133c84a36ad29f393da407c871b0143eb
  878.96 MiB <<missing>> macOS-10ad71d670ff0c9a346871f49f665972f8f8f201c47b4dd573e54ae1053ebb63
  605.53 MiB  603.68 MiB macOS-231c66957fc2cdb18ea10e63f60770049026e29051ecd6598fc390b60d6a4fa6
  784.84 MiB  775.51 MiB macOS-49aa50a4872ded07ebf657c0eaf9e44ecc0c174d033a97c537ecd270f35b462f
  784.84 MiB  774.11 MiB macOS-8f37f663956af5f743f0f99ab973729b6a02f200ebfac7a3a036eff296550732
  784.84 MiB  775.51 MiB macOS-ef5509b5d4495c8c3590442ee912ad1c9a33f872dc4a29421c524fc1e2103b59
------------
 9253.59 MiB

==> expected content size, actual cached size, and cache-keys used in caching method after implementation in https://github.com/lima-vm/lima/pull/2508
content-size actual-size cache-key
  226.46 MiB  226.43 MiB containerd:nerdctl-full-1.7.6-linux-amd64.tar.gz-sha256:2c841e097fcfb5a1760bd354b3778cb695b44cd01f9f271c17507dc4a0b25606
  496.77 MiB <<missing>> image:Arch-Linux-x86_64-cloudimg.qcow2-url-sha256:f84cefea6f889e36ddc5a7ffc1368a9aa95fd24b4589e1f79aab7ab85325d065
  379.06 MiB  377.28 MiB image:Fedora-Cloud-Base-Generic.x86_64-40-1.14.qcow2-sha256:ac58f3c35b73272d5986fa6d3bc44fd246b45df4c334e99a07b3bbd00684adee
   72.00 MiB   65.34 MiB image:alpine-lima-std-3.19.0-x86_64.iso-sha512:568852df405e6b9858e678171a9894c058f483df0b0570c22cf33fc75f349ba6cc5bb3d50188180d8c31faaf53400fe884ca3e5f949961b03b2bf53e65de88d7
   74.00 MiB   67.05 MiB image:alpine-lima-std-3.20.0-x86_64.iso-sha512:df013ba0666460c9e303e996e46e061e613ce546124a9de60060041874c702444ac7a90e67f1aed4756b85cc89d40c5ea4375dea62c98b9536ceb44f18874b67
  325.58 MiB  317.74 MiB image:debian-12-genericcloud-amd64-20240717-1811.qcow2-sha512:0f0075d53749dba4c9825e606899360626bb20ac6bab3dbdeff40041b051d203eb1a56e68d377c9fac0187faa0aea77fd543ef4a883fff2304eac252cce01b44
  248.40 MiB  245.08 MiB image:openSUSE-Leap-15.5-Minimal-VM.x86_64-Cloud.qcow2-url-sha256:713f6146e29554b9092f147652323bc0625a501abccc82dff249e139df8fade3
  652.50 MiB  644.52 MiB image:ubuntu-22.04-server-cloudimg-amd64.img-sha256:345fbbb6ec827ca02ec1a1ced90f7d40d3fd345811ba97c5772ac40e951458e1
  558.38 MiB  547.64 MiB image:ubuntu-24.04-server-cloudimg-amd64.img-sha256:d2377667ea95222330ca2287817403c85178dad397e9fed768a9b4aec79d2a7f
  558.38 MiB  547.64 MiB image:ubuntu-24.04-server-cloudimg-amd64.img-url-sha256:3b6b67faf5fd451e96832cbcaf6f5e04704d2ff7c47e749663508fc2a636130f
------------
 3591.53 MiB

Judging from this output, I believe the cache size calculations prior to this PR are generally accurate.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Updated.
Latest output of calculate-cach.sh:

$ hack/calculate-cache.sh
=> compare expected content size, actual cached size, and cache-keys used before and after the change in https://github.com/lima-vm/lima/pull/2508
==> before
content-size actual-size cache-key
  785.15 MiB  773.20 MiB Linux-1c3b2791d52735d916dc44767c745c2319eb7cae74af71bbf45ddb268f42fc1d
  605.53 MiB  603.71 MiB Linux-231c66957fc2cdb18ea10e63f60770049026e29051ecd6598fc390b60d6a4fa6
  558.38 MiB  547.64 MiB Linux-3b906d46fa532e3bc348c35fc8e7ede6c69f0b27032046ee2cbb56d4022d1146
   74.00 MiB   67.05 MiB Linux-69a547b760dbf1650007ed541408474237bc611704077214adcac292de556444
  474.49 MiB  471.25 MiB Linux-7782f8b4ff8cd378377eb79f8d61c9559b94bbd0c11d19eb380ee7bda19af04e
  784.84 MiB  775.08 MiB Linux-8812aedfe81b4456d421645928b493b1f2f88aff04b7f3171207492fd44cd189
  723.24 MiB  719.76 MiB Linux-caa7d8af214d55ad8902e82d5918e61573f3d6795d2b5ad9a35305e26fa0e6a9
  785.15 MiB  773.14 MiB Linux-de83bce0608d787e3c68c7a31c5fab2b6d054320fd7bf633a031845e2ee03414
  552.05 MiB  544.19 MiB Linux-eb88a19dfcf2fb98278e7c7e941c143737c6d7cd8950a88f58e04b4ee7cef1bc
   72.00 MiB   65.32 MiB Linux-f88f0b3b678ff6432386a42bdd27661133c84a36ad29f393da407c871b0143eb
  878.96 MiB <<missing>> macOS-10ad71d670ff0c9a346871f49f665972f8f8f201c47b4dd573e54ae1053ebb63
  605.53 MiB  603.70 MiB macOS-231c66957fc2cdb18ea10e63f60770049026e29051ecd6598fc390b60d6a4fa6
  784.84 MiB  775.51 MiB macOS-49aa50a4872ded07ebf657c0eaf9e44ecc0c174d033a97c537ecd270f35b462f
  785.15 MiB  773.20 MiB macOS-8f37f663956af5f743f0f99ab973729b6a02f200ebfac7a3a036eff296550732
  784.84 MiB  775.51 MiB macOS-ef5509b5d4495c8c3590442ee912ad1c9a33f872dc4a29421c524fc1e2103b59
------------
 9254.15 MiB

==> after
content-size actual-size cache-key
  226.46 MiB  226.43 MiB containerd:nerdctl-full-1.7.6-linux-amd64.tar.gz-sha256:2c841e097fcfb5a1760bd354b3778cb695b44cd01f9f271c17507dc4a0b25606
  496.77 MiB  493.33 MiB image:Arch-Linux-x86_64-cloudimg-20240801.250900.qcow2-sha256:f0e92eb32c15f4352d27662fdee90e8acc51902f50ded1843ee622e48e999eea
  379.06 MiB  377.28 MiB image:Fedora-Cloud-Base-Generic.x86_64-40-1.14.qcow2-sha256:ac58f3c35b73272d5986fa6d3bc44fd246b45df4c334e99a07b3bbd00684adee
   72.00 MiB   65.32 MiB image:alpine-lima-std-3.19.0-x86_64.iso-sha512:568852df405e6b9858e678171a9894c058f483df0b0570c22cf33fc75f349ba6cc5bb3d50188180d8c31faaf53400fe884ca3e5f949961b03b2bf53e65de88d7
   74.00 MiB   67.06 MiB image:alpine-lima-std-3.20.0-x86_64.iso-sha512:df013ba0666460c9e303e996e46e061e613ce546124a9de60060041874c702444ac7a90e67f1aed4756b85cc89d40c5ea4375dea62c98b9536ceb44f18874b67
  325.58 MiB  317.73 MiB image:debian-12-genericcloud-amd64-20240717-1811.qcow2-sha512:0f0075d53749dba4c9825e606899360626bb20ac6bab3dbdeff40041b051d203eb1a56e68d377c9fac0187faa0aea77fd543ef4a883fff2304eac252cce01b44
  248.02 MiB  244.80 MiB image:openSUSE-Leap-15.5-Minimal-VM.x86_64-Cloud.qcow2-url-sha256:713f6146e29554b9092f147652323bc0625a501abccc82dff249e139df8fade3
  652.50 MiB  644.52 MiB image:ubuntu-22.04-server-cloudimg-amd64.img-sha256:345fbbb6ec827ca02ec1a1ced90f7d40d3fd345811ba97c5772ac40e951458e1
  558.38 MiB  547.61 MiB image:ubuntu-24.04-server-cloudimg-amd64.img-sha256:d2377667ea95222330ca2287817403c85178dad397e9fed768a9b4aec79d2a7f
  558.69 MiB  546.71 MiB image:ubuntu-24.04-server-cloudimg-amd64.img-url-sha256:3b6b67faf5fd451e96832cbcaf6f5e04704d2ff7c47e749663508fc2a636130f
------------
 3591.47 MiB

@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch 2 times, most recently from a3d0d7e to a09d928 Compare August 3, 2024 14:54
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from 3e79f33 to 0c0c914 Compare August 5, 2024 07:27
norio-nomura added a commit to norio-nomura/lima that referenced this pull request Aug 7, 2024
… versus previous method

This was created in response to the question at lima-vm#2508 (comment).

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: `shfmt -s`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from 3df02fc to c82e6ce Compare August 7, 2024 02:41
@norio-nomura
Copy link
Contributor Author

FYI, the details of the cache currently used in this repository's CI can be seen here: https://github.com/lima-vm/lima/actions/caches.
スクリーンショット 2024-08-07 12 05 47

The cache settings are not efficient, so we quickly exceed the limit and caches expire. This PR will minimize the cache for files downloaded during limactl execution. Separately, I plan to create a PR to improve the cache set by actions/setup-go.

@@ -0,0 +1,207 @@
#!/usr/bin/env bash
# This script calculates the expected content size, actual cached size, and cache-keys used in caching method prior and after
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you add the usage of the script?
What is the input and the output?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Added some descriptions to calculate-cache.sh.

norio-nomura added a commit to norio-nomura/lima that referenced this pull request Aug 16, 2024
… versus previous method

This was created in response to the question at lima-vm#2508 (comment).

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: `shfmt -s`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from c82e6ce to bcfd453 Compare August 16, 2024 06:26
@norio-nomura
Copy link
Contributor Author

Following shfmt issue does not happen with shfmt@v3.8.0 that I'm using on local.
https://github.com/lima-vm/lima/actions/runs/10415694648/job/28846620704?pr=2508#step:13:23
It looks lint job using older version shfmt@v3.4.3.
Are there any reason to pinning shfmt at older version?

@AkihiroSuda
Copy link
Member

Are there any reason to pinning shfmt at older version?

No, it is just out of sync with the latest version

Use `actions/cache@v4` with following params:
path: ".download/by-url-sha256/$(echo $location | sha256sum | cut -d' ' -f1)"
key: "image-$digest"
enableCrossOsArchive: true

To make the image cache cross-platform, the cache directory is specified using a relative path from the working directory, and the platform-specific cache directories are accessed via symbolic links.

This should reduce the cache size used by the CI.

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

setup_cache_for_template: support url in template parameter

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
…erdctl` archives

- Change cache key to `url-sha256:$sha256` for caching images without a digest
- Include image basename in the cache key
- Use `limactl validate --fill` to retrieve nerdctl archive info and set cache if needed
- `test.yml`: Change cache configuration to run after `make install`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

test.yml: Remove `normalize_template_path` since `hashFile` is no longer used.

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
norio-nomura added a commit to norio-nomura/lima that referenced this pull request Aug 18, 2024
… versus previous method

This was created in response to the question at lima-vm#2508 (comment).

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: `shfmt -s`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch 3 times, most recently from 12893ad to dc7681d Compare August 20, 2024 11:19
norio-nomura added a commit to norio-nomura/lima that referenced this pull request Aug 20, 2024
… versus previous method

This was created in response to the question at lima-vm#2508 (comment).

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: `shfmt -s`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: extract `runs_on` and `template` from workflow file

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add DEBUG=1 to save collected information as yaml

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add descriptions and output examples to functions

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: use `--jq` instead of `| jq`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add some descriptions

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: resolve shfmt issue

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: mention response cache file

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch 3 times, most recently from 5b9f0bb to f44b3f9 Compare August 21, 2024 03:11
… versus previous method

This was created in response to the question at lima-vm#2508 (comment).

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: `shfmt -s`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: extract `runs_on` and `template` from workflow file

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add DEBUG=1 to save collected information as yaml

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add descriptions and output examples to functions

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: use `--jq` instead of `| jq`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add some descriptions

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: resolve shfmt issue

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: mention response cache file

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>

calculate-cache.sh: add `select(.steps)|`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
refactor some common codes from `setup_cache_for_template` and `calculate-cache.sh` into `cache-common-inc.sh`

Signed-off-by: Norio Nomura <norio.nomura@gmail.com>
@norio-nomura norio-nomura force-pushed the ci-use-digest-of-image-in-template-as-key-for-cache branch from f44b3f9 to 5058106 Compare August 21, 2024 04:11
@AkihiroSuda AkihiroSuda requested a review from a team August 23, 2024 16:58
@AkihiroSuda AkihiroSuda added this to the v1.0 milestone Aug 30, 2024
Copy link
Member

@AkihiroSuda AkihiroSuda left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks

@AkihiroSuda AkihiroSuda merged commit 726f61d into lima-vm:master Aug 30, 2024
27 checks passed
@norio-nomura norio-nomura deleted the ci-use-digest-of-image-in-template-as-key-for-cache branch August 30, 2024 07:45
@norio-nomura
Copy link
Contributor Author

Thanks! 🙏🏻

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/test Tests and CI
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants