Skip to content

Commit

Permalink
chore(IDX): don't cache ic-os images (#3256)
Browse files Browse the repository at this point in the history
This saves a couple gigabytes of cache space per build:

```
ubuntu@devenv-container:/ic$ bazel --noworkspace_rc --bazelrc=./bazel/conf/.bazelrc.build build --disk_cache=,out/disk-cache --config=systest //ic-os/setupos/envs/dev && du -sh ,out
...
Target //ic-os/setupos/envs/dev:dev up-to-date:
  bazel-bin/ic-os/setupos/envs/dev/dev_pre_check_result.txt
  bazel-bin/ic-os/setupos/envs/dev/disk-img.tar.zst
INFO: Elapsed time: 0.929s, Critical Path: 0.10s
INFO: 1 process: 1 internal.
INFO: Build completed successfully, 1 total action
24G	,out

ubuntu@devenv-container:/ic$ bazel --noworkspace_rc --bazelrc=./bazel/conf/.bazelrc.build build --disk_cache=,out/disk-cache --config=systest //ic-os/setupos/envs/dev && du -sh ,out
...
Target //ic-os/setupos/envs/dev:dev up-to-date:
  bazel-bin/ic-os/setupos/envs/dev/dev_pre_check_result.txt
  bazel-bin/ic-os/setupos/envs/dev/disk-img.tar.zst
INFO: Elapsed time: 0.857s, Critical Path: 0.04s
INFO: 1 process: 1 internal.
INFO: Build completed successfully, 1 total action
6.9G	,out # NOTE: this is when everything in ic-os is marked as no-cache
```

The images are rebuilt on almost every change anyway.
  • Loading branch information
nmattia authored Jan 9, 2025
1 parent dd459b9 commit ba5e99b
Show file tree
Hide file tree
Showing 9 changed files with 47 additions and 29 deletions.
36 changes: 18 additions & 18 deletions ic-os/defs.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,7 @@ def icos_build(
build_args = image_deps["build_args"],
file_build_arg = image_deps["file_build_arg"],
target_compatible_with = ["@platforms//os:linux"],
tags = ["manual"],
tags = ["manual", "no-cache"],
)

# Extract SElinux file_contexts to use later when building ext4 filesystems
Expand Down Expand Up @@ -192,7 +192,7 @@ def icos_build(
k: v
for k, v in (image_deps["rootfs"].items() + [(":version.txt", "/opt/ic/share/version.txt:0644")])
},
tags = ["manual"],
tags = ["manual", "no-cache"],
)

# Inherit tags for this test, to avoid triggering builds for local base images
Expand All @@ -213,16 +213,16 @@ def icos_build(
k: v
for k, v in (image_deps["rootfs"].items() + [(":version-test.txt", "/opt/ic/share/version.txt:0644")])
},
tags = ["manual"],
tags = ["manual", "no-cache"],
)

# When boot_args are fixed, don't bother signing
if "boot_args_template" not in image_deps:
native.alias(name = "partition-root.tzst", actual = ":partition-root-unsigned.tzst", tags = ["manual"])
native.alias(name = "partition-root.tzst", actual = ":partition-root-unsigned.tzst", tags = ["manual", "no-cache"])
native.alias(name = "extra_boot_args", actual = image_deps["extra_boot_args"], tags = ["manual"])

if upgrades:
native.alias(name = "partition-root-test.tzst", actual = ":partition-root-test-unsigned.tzst", tags = ["manual"])
native.alias(name = "partition-root-test.tzst", actual = ":partition-root-test-unsigned.tzst", tags = ["manual", "no-cache"])
native.alias(name = "extra_boot_test_args", actual = image_deps["extra_boot_args"], tags = ["manual"])
else:
native.alias(name = "extra_boot_args_template", actual = image_deps["boot_args_template"], tags = ["manual"])
Expand All @@ -235,7 +235,7 @@ def icos_build(
cmd = "$(location //toolchains/sysimage:proc_wrapper) $(location //toolchains/sysimage:verity_sign.py) -i $< -o $(location :partition-root.tzst) -r $(location partition-root-hash) --dflate $(location //rs/ic_os/build_tools/dflate)",
executable = False,
tools = ["//toolchains/sysimage:proc_wrapper", "//toolchains/sysimage:verity_sign.py", "//rs/ic_os/build_tools/dflate"],
tags = ["manual"],
tags = ["manual", "no-cache"],
)

native.genrule(
Expand All @@ -257,7 +257,7 @@ def icos_build(
outs = ["partition-root-test.tzst", "partition-root-test-hash"],
cmd = "$(location //toolchains/sysimage:proc_wrapper) $(location //toolchains/sysimage:verity_sign.py) -i $< -o $(location :partition-root-test.tzst) -r $(location partition-root-test-hash) --dflate $(location //rs/ic_os/build_tools/dflate)",
tools = ["//toolchains/sysimage:proc_wrapper", "//toolchains/sysimage:verity_sign.py", "//rs/ic_os/build_tools/dflate"],
tags = ["manual"],
tags = ["manual", "no-cache"],
)

native.genrule(
Expand Down Expand Up @@ -285,7 +285,7 @@ def icos_build(
]
)
},
tags = ["manual"],
tags = ["manual", "no-cache"],
)

if upgrades:
Expand All @@ -303,7 +303,7 @@ def icos_build(
]
)
},
tags = ["manual"],
tags = ["manual", "no-cache"],
)

# -------------------- Assemble disk partitions ---------------
Expand All @@ -326,7 +326,7 @@ def icos_build(
":partition-root.tzst",
] + custom_partitions,
expanded_size = image_deps.get("expanded_size", default = None),
tags = ["manual"],
tags = ["manual", "no-cache"],
target_compatible_with = [
"@platforms//os:linux",
],
Expand All @@ -343,7 +343,7 @@ def icos_build(
":partition-root.tzst",
] + custom_partitions,
expanded_size = image_deps.get("expanded_size", default = None),
tags = ["manual", "no-remote-cache"],
tags = ["manual", "no-cache"],
target_compatible_with = [
"@platforms//os:linux",
],
Expand All @@ -363,7 +363,7 @@ def icos_build(
name = "update-img.tar",
boot_partition = ":partition-boot.tzst",
root_partition = ":partition-root.tzst",
tags = ["manual"],
tags = ["manual", "no-cache"],
target_compatible_with = [
"@platforms//os:linux",
],
Expand All @@ -381,7 +381,7 @@ def icos_build(
name = "update-img-test.tar",
boot_partition = ":partition-boot-test.tzst",
root_partition = ":partition-root-test.tzst",
tags = ["manual"],
tags = ["manual", "no-cache"],
target_compatible_with = [
"@platforms//os:linux",
],
Expand Down Expand Up @@ -671,7 +671,7 @@ def boundary_node_icos_build(
build_args = image_deps["build_args"],
file_build_arg = image_deps["file_build_arg"],
target_compatible_with = ["@platforms//os:linux"],
tags = ["manual"],
tags = ["manual", "no-cache"],
)

# Helpful tool to print a hash of all input component files
Expand Down Expand Up @@ -740,7 +740,7 @@ EOF
]
)
},
tags = ["manual"],
tags = ["manual", "no-cache"],
)

ext4_image(
Expand All @@ -764,7 +764,7 @@ EOF
k: v
for k, v in (image_deps["rootfs"].items() + [(":version.txt", "/opt/ic/share/version.txt:0644")])
},
tags = ["manual"],
tags = ["manual", "no-cache"],
)

native.genrule(
Expand All @@ -774,7 +774,7 @@ EOF
cmd = "$(location //toolchains/sysimage:proc_wrapper) $(location //toolchains/sysimage:verity_sign.py) -i $< -o $(location :partition-root.tzst) -r $(location partition-root-hash) --dflate $(location //rs/ic_os/build_tools/dflate)",
executable = False,
tools = ["//toolchains/sysimage:proc_wrapper", "//toolchains/sysimage:verity_sign.py", "//rs/ic_os/build_tools/dflate"],
tags = ["manual"],
tags = ["manual", "no-cache"],
)

native.genrule(
Expand All @@ -799,7 +799,7 @@ EOF
":partition-root.tzst",
],
expanded_size = "50G",
tags = ["manual"],
tags = ["manual", "no-cache"],
target_compatible_with = [
"@platforms//os:linux",
],
Expand Down
5 changes: 4 additions & 1 deletion ic-os/guestos/envs/local-base-dev/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,10 @@ icos_build(
build_local_base_image = True,
ic_version = "//bazel:rc_only_version.txt",
image_deps_func = image_deps,
tags = ["manual"],
tags = [
"manual",
"no-cache",
],
upload_prefix = None, # Do not upload locally built base images
visibility = ["//rs:ic-os-pkg"],
)
5 changes: 4 additions & 1 deletion ic-os/guestos/envs/local-base-prod/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,10 @@ icos_build(
name = "local-base-prod",
build_local_base_image = True,
image_deps_func = image_deps,
tags = ["manual"],
tags = [
"manual",
"no-cache",
],
upload_prefix = None, # Do not upload locally built base images
visibility = ["//rs:ic-os-pkg"],
)
2 changes: 1 addition & 1 deletion ic-os/hostos/defs.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@ def _custom_partitions():
vg_name = "hostlvm",
vg_uuid = "4c7GVZ-Df82-QEcJ-xXtV-JgRL-IjLE-hK0FgA",
pv_uuid = "eu0VQE-HlTi-EyRc-GceP-xZtn-3j6t-iqEwyv",
tags = ["manual"],
tags = ["manual", "no-cache"],
target_compatible_with = [
"@platforms//os:linux",
],
Expand Down
5 changes: 4 additions & 1 deletion ic-os/hostos/envs/local-base-dev/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,10 @@ icos_build(
build_local_base_image = True,
ic_version = "//bazel:rc_only_version.txt",
image_deps_func = image_deps,
tags = ["manual"],
tags = [
"manual",
"no-cache",
],
upload_prefix = None, # Do not upload locally built base images
visibility = ["//rs:ic-os-pkg"],
vuln_scan = False,
Expand Down
5 changes: 4 additions & 1 deletion ic-os/hostos/envs/local-base-prod/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,10 @@ icos_build(
name = "local-base-prod",
build_local_base_image = True,
image_deps_func = image_deps,
tags = ["manual"],
tags = [
"manual",
"no-cache",
],
upload_prefix = None, # Do not upload locally built base images
visibility = ["//rs:ic-os-pkg"],
vuln_scan = False,
Expand Down
8 changes: 4 additions & 4 deletions ic-os/setupos/defs.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -102,15 +102,15 @@ def _custom_partitions(mode):
src = guest_image,
out = "guest-os.img.tar.zst",
allow_symlink = True,
tags = ["manual"],
tags = ["manual", "no-cache"],
)

copy_file(
name = "copy_hostos_img",
src = host_image,
out = "host-os.img.tar.zst",
allow_symlink = True,
tags = ["manual"],
tags = ["manual", "no-cache"],
)

config_dict = {
Expand Down Expand Up @@ -159,7 +159,7 @@ def _custom_partitions(mode):
],
mode = "0644",
package_dir = "data",
tags = ["manual"],
tags = ["manual", "no-cache"],
)

ext4_image(
Expand All @@ -170,7 +170,7 @@ def _custom_partitions(mode):
target_compatible_with = [
"@platforms//os:linux",
],
tags = ["manual"],
tags = ["manual", "no-cache"],
)

return [
Expand Down
5 changes: 4 additions & 1 deletion ic-os/setupos/envs/local-base-dev/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,10 @@ icos_build(
build_local_base_image = True,
ic_version = "//bazel:rc_only_version.txt",
image_deps_func = image_deps,
tags = ["manual"],
tags = [
"manual",
"no-cache",
],
upgrades = False,
upload_prefix = None, # Do not upload locally built base images
visibility = ["//rs:ic-os-pkg"],
Expand Down
5 changes: 4 additions & 1 deletion ic-os/setupos/envs/local-base-prod/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,10 @@ icos_build(
name = "local-base-prod",
build_local_base_image = True,
image_deps_func = image_deps,
tags = ["manual"],
tags = [
"manual",
"no-cache",
],
upgrades = False,
upload_prefix = None, # Do not upload locally built base images
vuln_scan = False,
Expand Down

0 comments on commit ba5e99b

Please sign in to comment.