From 68b91cbeb286ffcadbd0ea7f8fcc098f96100859 Mon Sep 17 00:00:00 2001 From: Lluis Campos Date: Tue, 14 Jan 2020 19:53:38 +0100 Subject: [PATCH 1/2] MEN-2794: Adjust the expected S3 locations for the binaries The S3 path now follows the pattern: /mender/mender-convert/uboot//-.tar For RPi and BBB these are automatically published form the CI Pipeline of repo mender-convert-integration-scripts while for RockPro64 they have been manually moved (as we expect this to be a one time integration). Reworked a bit also the *_BINARIES variable so that we can keep the u-boot version in the base config files and let the childs only define the a config name. Changelog: None Signed-off-by: Lluis Campos --- configs/beaglebone_black_base_config | 7 +++---- configs/beaglebone_black_debian_emmc_config | 7 +++---- configs/beaglebone_black_debian_sdcard_config | 6 +----- configs/raspberrypi0w_config | 5 +---- configs/raspberrypi3_config | 5 +---- configs/raspberrypi4_config | 5 +---- configs/raspberrypi_config | 6 +++++- configs/rockpro64_config | 6 +++++- configs/rockpro64_emmc_config | 6 +----- configs/rockpro64_sd_config | 5 +---- 10 files changed, 22 insertions(+), 36 deletions(-) diff --git a/configs/beaglebone_black_base_config b/configs/beaglebone_black_base_config index 5878958..65ff7f6 100644 --- a/configs/beaglebone_black_base_config +++ b/configs/beaglebone_black_base_config @@ -1,7 +1,5 @@ # Binaries generated with the following script: -# -# https://github.com/drewmoseley/mender-convert-integration-scripts/blob/master/build-uboot-bbb.sh -# +# https://github.com/mendersoftware/mender-convert-integration-scripts/blob/master/build-uboot-bbb.sh # There are reported issues with GRUB bootloader integration, fallback to U-boot. MENDER_GRUB_EFI_INTEGRATION=n @@ -12,7 +10,8 @@ MENDER_COPY_BOOT_GAP=n # 4MB alignment MENDER_PARTITION_ALIGNMENT="4194304" -BEAGLEBONE_BLACK_BINARIES_URL="${MENDER_STORAGE_URL}/mender-convert/beaglebone/${BEAGLEBONE_BLACK_BINARIES}" +BEAGLEBONE_BLACK_BINARIES="${BEAGLEBONE_BLACK_CONFIG}-2018.07.004.tar" +BEAGLEBONE_BLACK_BINARIES_URL="${MENDER_STORAGE_URL}/mender-convert/uboot/beaglebone/${BEAGLEBONE_BLACK_BINARIES}" function platform_modify() { mkdir -p work/bbb/binaries diff --git a/configs/beaglebone_black_debian_emmc_config b/configs/beaglebone_black_debian_emmc_config index 0e8b3b3..50e513f 100644 --- a/configs/beaglebone_black_debian_emmc_config +++ b/configs/beaglebone_black_debian_emmc_config @@ -1,8 +1,7 @@ # Binaries generated with the following script: -# -# https://github.com/drewmoseley/mender-convert-integration-scripts/blob/master/build-uboot-bbb.sh -# -BEAGLEBONE_BLACK_BINARIES="beaglebone-black-integration-debian-emmc-2018.07.004.tar" +# https://github.com/mendersoftware/mender-convert-integration-scripts/blob/master/build-uboot-bbb.sh + +BEAGLEBONE_BLACK_CONFIG="beaglebone_black_debian_emmc" source configs/beaglebone_black_base_config MENDER_STORAGE_TOTAL_SIZE_MB="3648" MENDER_DEVICE_TYPE="beaglebone-emmc" diff --git a/configs/beaglebone_black_debian_sdcard_config b/configs/beaglebone_black_debian_sdcard_config index 7965557..63a7df7 100644 --- a/configs/beaglebone_black_debian_sdcard_config +++ b/configs/beaglebone_black_debian_sdcard_config @@ -1,8 +1,4 @@ -# Binaries generated with the following script: -# -# https://github.com/drewmoseley/mender-convert-integration-scripts/blob/master/build-uboot-bbb.sh -# -BEAGLEBONE_BLACK_BINARIES="beaglebone-black-integration-debian-sdcard-2018.07.004.tar" +BEAGLEBONE_BLACK_CONFIG="beaglebone_black_debian_sdcard" source configs/beaglebone_black_base_config MENDER_DEVICE_TYPE="beaglebone-sdcard" MENDER_STORAGE_DEVICE="/dev/mmcblk0p" diff --git a/configs/raspberrypi0w_config b/configs/raspberrypi0w_config index e4dd478..fe6c37b 100644 --- a/configs/raspberrypi0w_config +++ b/configs/raspberrypi0w_config @@ -1,7 +1,4 @@ -# Binaries generated with the following script: -# -# https://github.com/drewmoseley/mender-convert-integration-scripts/blob/master/build-uboot-rpi.sh -RASPBERRYPI_BINARIES="raspberrypi0w-integration-2019.01.tar.gz" +RASPBERRYPI_CONFIG="raspberrypi0w" RASPBERRYPI_KERNEL_IMAGE="kernel.img" MENDER_KERNEL_IMAGETYPE=zImage diff --git a/configs/raspberrypi3_config b/configs/raspberrypi3_config index d2a3c40..72f3ae7 100644 --- a/configs/raspberrypi3_config +++ b/configs/raspberrypi3_config @@ -1,7 +1,4 @@ -# Binaries generated with the following script: -# -# https://github.com/drewmoseley/mender-convert-integration-scripts/blob/master/build-uboot-rpi.shraspberrypi-integration-scripts.tar.gz -RASPBERRYPI_BINARIES="raspberrypi3-integration-2019.01.tar.gz" +RASPBERRYPI_CONFIG="raspberrypi3" RASPBERRYPI_KERNEL_IMAGE="kernel7.img" MENDER_KERNEL_IMAGETYPE="zImage" diff --git a/configs/raspberrypi4_config b/configs/raspberrypi4_config index 299b87f..37ec451 100644 --- a/configs/raspberrypi4_config +++ b/configs/raspberrypi4_config @@ -1,7 +1,4 @@ -# Binaries generated with the following script: -# -# https://github.com/drewmoseley/mender-convert-integration-scripts/blob/master/build-uboot-rpi.shraspberrypi-integration-scripts.tar.gz -RASPBERRYPI_BINARIES="raspberrypi4-integration-2019.01.tar.gz" +RASPBERRYPI_CONFIG="raspberrypi4" RASPBERRYPI_KERNEL_IMAGE="kernel7l.img" MENDER_KERNEL_IMAGETYPE="zImage" diff --git a/configs/raspberrypi_config b/configs/raspberrypi_config index da3427b..bd22f55 100644 --- a/configs/raspberrypi_config +++ b/configs/raspberrypi_config @@ -1,3 +1,6 @@ +# Binaries generated with the following script: +# https://github.com/mendersoftware/mender-convert-integration-scripts/blob/master/build-uboot-rpi.sh + # Raspberry Pi does not support GRUB bootloader integration, fallback to U-boot. MENDER_GRUB_EFI_INTEGRATION=n @@ -7,7 +10,8 @@ MENDER_COPY_BOOT_GAP=n # 4MB alignment MENDER_PARTITION_ALIGNMENT="4194304" -RASPBERRYPI_BINARIES_URL="${MENDER_STORAGE_URL}/mender-convert/raspberrypi/${RASPBERRYPI_BINARIES}" +RASPBERRYPI_BINARIES="${RASPBERRYPI_CONFIG}-2019.01.tar.gz" +RASPBERRYPI_BINARIES_URL="${MENDER_STORAGE_URL}/mender-convert/uboot/raspberrypi/${RASPBERRYPI_BINARIES}" function platform_modify() { mkdir -p work/rpi/binaries diff --git a/configs/rockpro64_config b/configs/rockpro64_config index 061a2ea..d011136 100644 --- a/configs/rockpro64_config +++ b/configs/rockpro64_config @@ -1,10 +1,14 @@ +# Binaries generated with the following script: +# https://d1b0l86ne08fsf.cloudfront.net/mender-convert/uboot/rockpro64/integration-scripts.tar.gz + # ROCKPro64 do not support GRUB bootloader integration, fallback to U-boot. MENDER_GRUB_EFI_INTEGRATION=n # We will write a modified bootloader MENDER_COPY_BOOT_GAP=n -ROCKPRO64_BINARIES_URL="${MENDER_STORAGE_URL}/mender-convert/armbian/rockpro64/${ROCKPRO64_BINARIES}" +ROCKPRO64_BINARIES="${ROCKPRO64_CONFIG}-2017.09.tar.gz" +ROCKPRO64_BINARIES_URL="${MENDER_STORAGE_URL}/mender-convert/uboot/rockpro64/${ROCKPRO64_BINARIES}" function platform_modify() { mkdir -p work/rockpro64 diff --git a/configs/rockpro64_emmc_config b/configs/rockpro64_emmc_config index 3ae58f2..f2988ed 100644 --- a/configs/rockpro64_emmc_config +++ b/configs/rockpro64_emmc_config @@ -1,8 +1,4 @@ +ROCKPRO64_CONFIG="rockpro64_emmc" MENDER_STORAGE_DEVICE=/dev/mmcblk1p -# Binaries generated with the following script: -# -# https://d1b0l86ne08fsf.cloudfront.net/mender-convert/armbian/rockpro64/integration-scripts.tar.gz -ROCKPRO64_BINARIES="emmc-boot-integration-2017.09.tar.gz" - source configs/rockpro64_config diff --git a/configs/rockpro64_sd_config b/configs/rockpro64_sd_config index 514f8c3..b3c2b30 100644 --- a/configs/rockpro64_sd_config +++ b/configs/rockpro64_sd_config @@ -1,6 +1,3 @@ -# Binaries generated with the following script: -# -# https://d1b0l86ne08fsf.cloudfront.net/mender-convert/armbian/rockpro64/integration-scripts.tar.gz -ROCKPRO64_BINARIES="sd-boot-integration-2017.09.tar.gz" +ROCKPRO64_CONFIG="rockpro64_sd" source configs/rockpro64_config From 20972c6d58e79a06bffdb5f24fce363131a84609 Mon Sep 17 00:00:00 2001 From: Lluis Campos Date: Tue, 14 Jan 2020 21:17:05 +0100 Subject: [PATCH 2/2] Limit the publish job to only master and release branches The "high privileged" keys will only be available in protected branches, so we won't be able to publish from a PR even if we run the manual job. Changelog: None Signed-off-by: Lluis Campos --- .gitlab-ci.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 9e1dcd4..c9e665a 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -113,11 +113,9 @@ publish:s3: image: debian:buster before_script: - apt update && apt install -yyq awscli - # Fetch artifacts from temporary S3 bucket - aws s3 cp s3://mender-gitlab-tmp-storage/$CI_PROJECT_NAME/$CI_PIPELINE_ID/deploy.tar.gz deploy.tar.gz - tar xzf deploy.tar.gz - script: - echo "Publishing ${RASPBIAN_NAME}-mender-${MENDER_CLIENT_VERSION}.img.xz version to S3" # Prepare high privilege S3 keys (the base keys are for the tmp storage only) @@ -127,3 +125,5 @@ publish:s3: s3://$S3_BUCKET_NAME/${RASPBIAN_NAME}/arm/${RASPBIAN_NAME}-mender-${MENDER_CLIENT_VERSION}.img.xz - aws s3api put-object-acl --acl public-read --bucket $S3_BUCKET_NAME --key ${RASPBIAN_NAME}/arm/${RASPBIAN_NAME}-mender-${MENDER_CLIENT_VERSION}.img.xz + only: + - /^(master|[0-9]+\.[0-9]+\.x)$/