Skip to content

Commit

Permalink
Cirrus: enable Fedora 36 aarch64 tasks on EC2
Browse files Browse the repository at this point in the history
Also install dependencies from rhcontainerbot/podman-next COPR
instead of fetching binaries from cirrus jobs

Signed-off-by: Lokesh Mandvekar <[email protected]>
  • Loading branch information
lsm5 committed Jul 15, 2022
1 parent 5ceabec commit 539fecf
Show file tree
Hide file tree
Showing 4 changed files with 129 additions and 54 deletions.
144 changes: 104 additions & 40 deletions .cirrus.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,30 +17,26 @@ env:
# Save a little typing (path relative to $CIRRUS_WORKING_DIR)
SCRIPT_BASE: "./contrib/cirrus"
FEDORA_NAME: "fedora-36"
IMAGE_SUFFIX: "c6457378097856512"
IMAGE_SUFFIX: "c5353795591864320"
FEDORA_NETAVARK_IMAGE: "fedora-netavark-${IMAGE_SUFFIX}"
FEDORA_NETAVARK_AARCH64_AMI_ID: "ami-02da46d8fa51e5316"


gcp_credentials: ENCRYPTED[d6efdb7d6d4c61e3831df2193ca6348bb02f26cd931695f69d41930b1965f7dab72a838ca0902f6ed8cde66c7deddae2]


# Default VM to use unless set or modified by task
gce_instance: &standard_vm
image_project: "libpod-218412"
zone: "us-central1-c"
cpu: 2
memory: "4Gb"
disk: 200 # GB, do not set <200 per gcloud warning re: I/O performance
image_name: "${FEDORA_NETAVARK_IMAGE}"
aws_credentials: ENCRYPTED[949b114326ca5686a3aa2990536a479cf8e5a931611b443e50579ea787faa21eb172f6fc0ebc79d7e817e4bebf417940]


build_task:
alias: "build"
# Compiling is very CPU intensive, make it chooch quicker for this task only
gce_instance:
<<: *standard_vm
cpu: 8
memory: "8Gb"
gce_instance: &standard_build_gce_x86_64
image_project: "libpod-218412"
zone: "us-central1-c"
disk: 200 # GB, do not set <200 per gcloud warning re: I/O performance
cpu: 8
memory: "8Gb"
image_name: "${FEDORA_NETAVARK_IMAGE}"
cargo_cache: &cargo_cache
# Populating this cache depends on execution of setup.sh, and runner.sh
# to builds of all release, debug, plus unit-tests.
Expand Down Expand Up @@ -74,30 +70,39 @@ build_task:
upload_caches: [ "cargo", "targets", "bin" ]


build_cross_task:
alias: "build_cross"
cargo_cache:
<<: *cargo_cache
# Don't confuse cache architectures, bad things will happen.
fingerprint_key: "cargo_v2_${DEST_BRANCH}_arm64"
targets_cache:
<<: *targets_cache
fingerprint_key: "targets_v2_${CIRRUS_TAG}${DEST_BRANCH}${CIRRUS_PR}_arm64" # Cache only within same tag, branch, or PR (branch will be 'pull/#')
bin_cache:
<<: *bin_cache
fingerprint_key: "bin_v2_${CIRRUS_TAG}${DEST_BRANCH}${CIRRUS_PR}_arm64" # Cache only within same tag, branch, or PR (branch will be 'pull/#')
build_aarch64_task:
alias: "build_aarch64"
ec2_instance: &standard_build_ec2_aarch64
image: "${FEDORA_NETAVARK_AARCH64_AMI_ID}"
type: t4g.xlarge
region: us-east-1
architecture: arm64 # CAUTION: This has to be "arm64", not "aarch64"
cargo_cache: &cargo_cache_aarch64
folder: "$CARGO_HOME"
fingerprint_key: "cargo_v2_${DEST_BRANCH}_aarch64"
reupload_on_changes: true
targets_cache: &targets_cache_aarch64
folder: "$CARGO_TARGET_DIR"
fingerprint_key: "targets_v2_${CIRRUS_TAG}${DEST_BRANCH}${CIRRUS_PR}_aarch64" # Cache only within same tag, branch, or PR (branch will be 'pull/#')
reupload_on_changes: true
bin_cache: &bin_cache_aarch64
# This simply prevents rebuilding bin/netavark for every subsequent task.
folder: "$CIRRUS_WORKING_DIR/bin"
fingerprint_key: "bin_v2_${CIRRUS_TAG}${DEST_BRANCH}${CIRRUS_PR}_aarch64" # Cache only within same tag, branch, or PR (branch will be 'pull/#')
reupload_on_changes: true
setup_script: *setup
main_script: *main
# Upload cross-compiled binary for collection by success task
# https://cirrus-ci.org/guide/writing-tasks/#artifacts-instruction
binary_artifacts:
path: ./bin/netavark*
upload_caches: [ "cargo", "targets", "bin" ]


validate_task:
alias: "validate"
depends_on:
- "build"
gce_instance: &standard_gce_x86_64
<<: *standard_build_gce_x86_64
cpu: 2
memory: "4Gb"
# From this point forward, all cache's become read-only - meaning
# any changes made in this task aren't re-uploaded to the cache.
# This avoids some flapping between tasks, along with the upload time.
Expand All @@ -113,37 +118,97 @@ validate_task:
setup_script: *setup
main_script: *main


validate_aarch64_task:
alias: "validate_aarch64"
depends_on:
- "build_aarch64"
ec2_instance: *standard_build_ec2_aarch64
cargo_cache: &ro_cargo_cache_aarch64
<<: *cargo_cache_aarch64
reupload_on_changes: false
targets_cache: &ro_targets_cache_aarch64
<<: *targets_cache_aarch64
reupload_on_changes: false
bin_cache: &ro_bin_cache_aarch64
<<: *bin_cache_aarch64
reupload_on_changes: false
setup_script: *setup
main_script: *main


verify_vendor_task:
alias: "verify_vendor"
depends_on:
- "build"
gce_instance: *standard_gce_x86_64
cargo_cache: *ro_cargo_cache
targets_cache: *ro_targets_cache
bin_cache: *ro_bin_cache
setup_script: *setup
main_script: *main


verify_vendor_aarch64_task:
alias: "verify_vendor_aarch64"
depends_on:
- "build_aarch64"
ec2_instance: *standard_build_ec2_aarch64
cargo_cache: *ro_cargo_cache_aarch64
targets_cache: *ro_targets_cache_aarch64
bin_cache: *ro_bin_cache_aarch64
setup_script: *setup
main_script: *main


unit_task:
alias: "unit"
depends_on:
- "build"
gce_instance: *standard_gce_x86_64
cargo_cache: *ro_cargo_cache
targets_cache: *ro_targets_cache
bin_cache: *ro_bin_cache
setup_script: *setup
main_script: *main


unit_aarch64_task:
alias: "unit_aarch64"
depends_on:
- "build_aarch64"
ec2_instance: *standard_build_ec2_aarch64
cargo_cache: *ro_cargo_cache_aarch64
targets_cache: *ro_targets_cache_aarch64
bin_cache: *ro_bin_cache_aarch64
setup_script: *setup
main_script: *main


integration_task:
alias: "integration"
depends_on:
- "unit"
gce_instance: *standard_gce_x86_64
cargo_cache: *ro_cargo_cache
targets_cache: *ro_targets_cache
bin_cache: *ro_bin_cache
setup_script: *setup
main_script: *main


integration_aarch64_task:
alias: "integration_aarch64"
depends_on:
- "unit_aarch64"
ec2_instance: *standard_build_ec2_aarch64
cargo_cache: *ro_cargo_cache_aarch64
targets_cache: *ro_targets_cache_aarch64
bin_cache: *ro_bin_cache_aarch64
setup_script: *setup
main_script: *main


# This task is critical. It updates the "last-used by" timestamp stored
# in metadata for all VM images. This mechanism functions in tandem with
# an out-of-band pruning operation to remove disused VM images.
Expand All @@ -169,6 +234,7 @@ ubuntu20_build_task:
alias: ubuntu20_build
depends_on:
- "build"
gce_instance: *standard_gce_x86_64
container:
cpu: 2
memory: 2
Expand All @@ -181,6 +247,7 @@ centos9_build_task:
alias: centos9_build
depends_on:
- "build"
gce_instance: *standard_gce_x86_64
container:
cpu: 2
memory: 2
Expand All @@ -194,26 +261,23 @@ success_task:
alias: success
depends_on:
- "build"
- "build_cross"
- "build_aarch64"
- "validate"
- "validate_aarch64"
- "verify_vendor"
- "verify_vendor_aarch64"
- "unit"
- "unit_aarch64"
- "integration"
- "integration_aarch64"
- "meta"
- "ubuntu20_build"
- "centos9_build"
ec2_instance: *standard_build_ec2_aarch64
env:
CIRRUS_SHELL: "/bin/sh"
clone_script: *noop
bin_cache: *ro_bin_cache
# The paths used for uploaded artifacts are relative here and in Cirrus
script:
# Cross-compiled binary artifact is required by other CI systems
- curl --fail --location -O --url https://api.cirrus-ci.com/v1/artifact/build/${CIRRUS_BUILD_ID}/build_cross/binary.zip
- unzip binary.zip
- rm -f binary.zip
- mv bin/* ./
- rm -rf bin
bin_cache: *ro_bin_cache_aarch64
# Upload tested binary for consumption downstream
# https://cirrus-ci.org/guide/writing-tasks/#artifacts-instruction
binary_artifacts:
Expand Down
13 changes: 0 additions & 13 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -75,19 +75,6 @@ test: unit integration
build_unit: $(CARGO_TARGET_DIR)
cargo test --no-run

# Test build cross-architecture
# Ref: https://github.com/cross-rs/cross
.PHONY: build_cross
build_cross: build_cross.aarch64-unknown-linux-gnu build_cross.arm-unknown-linux-gnueabi

.PHONY: build_cross.%
build_cross.%: bin $(CARGO_TARGET_DIR)
cargo install cross
rustup target add $*
cross build --target $* $(release)
cp $(CARGO_TARGET_DIR)/$*/$(profile)/netavark \
bin/netavark.$(*)$(if $(debug),.debug,)

.PHONY: unit
unit: $(CARGO_TARGET_DIR)
cargo test
Expand Down
20 changes: 20 additions & 0 deletions contrib/cirrus/runner.sh
Original file line number Diff line number Diff line change
Expand Up @@ -34,12 +34,20 @@ task: https://cirrus-ci.com/task/$CIRRUS_TASK_ID
EOF
}

_run_build_aarch64() {
_run_build
}

_run_validate() {
rustup install stable
rustup default stable
make validate
}

_run_validate_aarch64() {
_run_validate
}

_run_build_cross() {
make build_cross debug=1
make build_cross
Expand All @@ -52,14 +60,26 @@ _run_verify_vendor() {
fi
}

_run_verify_vendor_aarch64() {
_run_verify_vendor
}

_run_unit() {
make unit
}

_run_unit_aarch64() {
_run_unit
}

_run_integration() {
make integration
}

_run_integration_aarch64() {
_run_integration
}

show_env_vars

msg "************************************************************"
Expand Down
6 changes: 5 additions & 1 deletion contrib/cirrus/setup.sh
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,11 @@ msg "************************************************************"
msg "Setting up runtime environment"
msg "************************************************************"

dnf -y install make automake gcc gcc-c++ kernel-devel
dnf -y copr enable rhcontainerbot/podman-next
dnf -y install aardvark-dns

# Remove netavark executable
rm -f /usr/libexec/podman/netavark

show_env_vars

Expand Down

0 comments on commit 539fecf

Please sign in to comment.